blob: b18d0201aa6eb0e9860cea6a959cc60325583e35 [file] [log] [blame] [edit]
/*
* slurm-perl.h - prototypes of msg-hv converting functions
*/
#ifndef _SLURM_PERL_H
#define _SLURM_PERL_H
#include <msg.h>
/* these declaration are not in slurm.h */
#define xmalloc(__sz) \
slurm_xmalloc (__sz, __FILE__, __LINE__, __FUNCTION__)
#define xfree(__p) \
slurm_xfree((void **)&(__p), __FILE__, __LINE__, __FUNCTION__)
extern void slurm_xfree(void **, const char *, int, const char *);
extern void *slurm_xmalloc(size_t, const char *, int, const char *);
extern void slurm_api_set_conf_file(char *pathname);
extern void slurm_api_clear_config(void);
extern void slurm_list_iterator_destroy(ListIterator itr);
/*********** entity reason/state/flags string functions **********/
extern char *slurm_preempt_mode_string(uint16_t preempt_mode);
extern uint16_t slurm_preempt_mode_num(const char *preempt_mode);
extern char *slurm_job_reason_string(enum job_state_reason inx);
extern char *slurm_job_state_string(uint16_t inx);
extern char *slurm_job_state_string_compact(uint16_t inx);
extern int slurm_job_state_num(const char *state_name);
extern char *slurm_node_state_string(uint16_t inx);
extern char *slurm_node_state_string_compact(uint16_t inx);
extern char *slurm_reservation_flags_string(uint16_t inx);
extern void slurm_private_data_string(uint16_t private_data,
char *str, int str_len);
extern void slurm_accounting_enforce_string(uint16_t enforce,
char *str, int str_len);
extern char *slurm_conn_type_string(enum connection_type conn_type);
extern char *slurm_node_use_string(enum node_use_type node_use);
extern char *slurm_bg_block_state_string(uint16_t state);
/********** resource allocation related conversion functions **********/
extern int hv_to_job_desc_msg(HV *hv, job_desc_msg_t *job_desc);
extern void free_job_desc_msg_memory(job_desc_msg_t *msg);
extern int resource_allocation_response_msg_to_hv(
resource_allocation_response_msg_t *resp_msg, HV *hv);
extern int job_alloc_info_response_msg_to_hv(job_alloc_info_response_msg_t
*resp_msg, HV *hv);
extern int submit_response_msg_to_hv(submit_response_msg_t *resp_msg, HV *hv);
extern int job_sbcast_cred_msg_to_hv(job_sbcast_cred_msg_t *msg, HV *hv);
/********** resource allocation callback functions **********/
extern void set_sarb_cb(SV *callback);
extern void sarb_cb(uint32_t job_id);
extern void set_sacb(HV *callbacks);
extern slurm_allocation_callbacks_t sacb;
/********** job info conversion functions **********/
extern int job_info_to_hv(job_info_t *job_info, HV *hv);
extern int job_info_msg_to_hv(job_info_msg_t *job_info_msg, HV *hv);
extern int hv_to_job_info(HV *hv, job_info_t *job_info);
extern int hv_to_job_info_msg(HV *hv, job_info_msg_t *job_info_msg);
/********** step info conversion functions **********/
extern int job_step_info_to_hv(job_step_info_t *step_info, HV *hv);
extern int hv_to_job_step_info(HV *hv, job_step_info_t *step_info);
extern int job_step_info_response_msg_to_hv(job_step_info_response_msg_t
*job_step_info_msg, HV *hv);
extern int hv_to_job_step_info_response_msg(HV *hv,
job_step_info_response_msg_t *job_step_info_msg);
extern int slurm_step_layout_to_hv(slurm_step_layout_t *step_layout, HV *hv);
extern int job_step_pids_to_hv(job_step_pids_t *pids, HV *hv);
extern int job_step_pids_response_msg_to_hv(job_step_pids_response_msg_t
*pids_msg, HV *hv);
extern int job_step_stat_to_hv(job_step_stat_t *stat, HV *hv);
extern int job_step_stat_response_msg_to_hv(job_step_stat_response_msg_t
*stat_msg, HV *hv);
/********** node info conversion functions **********/
extern int node_info_to_hv(node_info_t *node_info, uint16_t node_scaling, HV *hv);
extern int hv_to_node_info(HV *hv, node_info_t *node_info);
extern int node_info_msg_to_hv(node_info_msg_t *node_info_msg, HV *hv);
extern int hv_to_node_info_msg(HV *hv, node_info_msg_t *node_info_msg);
extern int hv_to_update_node_msg(HV *hv, update_node_msg_t *update_msg);
/********** block info conversion functions **********/
extern int block_info_to_hv(block_info_t *block_info, HV *hv);
extern int hv_to_block_info(HV *hv, block_info_t *block_info);
extern int block_info_msg_to_hv(block_info_msg_t *block_info_msg, HV *hv);
extern int hv_to_block_info_msg(HV *hv, block_info_msg_t *block_info_msg);
extern int hv_to_update_block_msg(HV *hv, update_block_msg_t *update_msg);
/********** partition info conversion functions **********/
extern int partition_info_to_hv(partition_info_t *part_info, HV *hv);
extern int hv_to_partition_info(HV *hv, partition_info_t *part_info);
extern int partition_info_msg_to_hv(partition_info_msg_t *part_info_msg, HV *hv);
extern int hv_to_partition_info_msg(HV *hv, partition_info_msg_t *part_info_msg);
extern int hv_to_update_part_msg(HV *hv, update_part_msg_t *part_msg);
extern int hv_to_delete_part_msg(HV *hv, delete_part_msg_t *delete_msg);
/********** ctl config conversion functions **********/
extern int slurm_ctl_conf_to_hv(slurm_ctl_conf_t *conf, HV *hv);
extern int hv_to_slurm_ctl_conf(HV *hv, slurm_ctl_conf_t *conf);
extern int slurmd_status_to_hv(slurmd_status_t *status, HV *hv);
extern int hv_to_slurmd_status(HV *hv, slurmd_status_t *status);
extern int hv_to_step_update_request_msg(HV *hv, step_update_request_msg_t *update_msg);
/********** reservation info conversion functions **********/
extern int reserve_info_to_hv(reserve_info_t *reserve_info, HV *hv);
extern int hv_to_reserve_info(HV *hv, reserve_info_t *resv_info);
extern int reserve_info_msg_to_hv(reserve_info_msg_t *resv_info_msg, HV *hv);
extern int hv_to_reserve_info_msg(HV *hv, reserve_info_msg_t *resv_info_msg);
extern int hv_to_update_reservation_msg(HV *hv, resv_desc_msg_t *resv_msg);
extern int hv_to_delete_reservation_msg(HV *hv, reservation_name_msg_t *resv_name);
/********* trigger info conversion functions **********/
extern int trigger_info_to_hv(trigger_info_t *info, HV *hv);
extern int hv_to_trigger_info(HV *hv, trigger_info_t *info);
extern int trigger_info_msg_to_hv(trigger_info_msg_t *msg, HV *hv);
/********** topo info conversion functions **********/
extern int topo_info_to_hv(topo_info_t *topo_info, HV *hv);
extern int hv_to_topo_info(HV *hv, topo_info_t *topo_info);
extern int topo_info_response_msg_to_hv(topo_info_response_msg_t *topo_info_msg, HV *hv);
extern int hv_to_topo_info_response_msg(HV *hv, topo_info_response_msg_t *topo_info_msg);
/********** step launching functions **********/
extern int hv_to_slurm_step_ctx_params(HV *hv, slurm_step_ctx_params_t *params);
extern int hv_to_slurm_step_launch_params(HV *hv, slurm_step_launch_params_t
*params);
extern void free_slurm_step_launch_params_memory(slurm_step_launch_params_t
*params);
/********** step launching callback functions **********/
extern void set_slcb(HV *callbacks);
extern slurm_step_launch_callbacks_t slcb;
#endif /* _SLURM_PERL_H */