/* * slurm-perl.h - prototypes of msg-hv converting functions */ #ifndef _SLURM_PERL_H #define _SLURM_PERL_H #include /* these declaration are not in slurm.h */ #ifndef xfree #define xfree(__p) \ slurm_xfree((void **)&(__p), __FILE__, __LINE__, __func__) #define xmalloc(__sz) \ slurm_xcalloc(1, __sz, true, false, __FILE__, __LINE__, __func__) #endif extern void slurm_xfree(void **, const char *, int, const char *); extern void *slurm_xcalloc(size_t, size_t, bool, bool, const char *, int, const char *); 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(uint32_t inx); extern char *slurm_job_state_string_compact(uint32_t inx); extern int slurm_job_state_num(const char *state_name); extern char *slurm_node_state_string(uint32_t inx); extern char *slurm_node_state_string_compact(uint32_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); /********** 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 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); extern int srun_job_complete_msg_to_hv(srun_job_complete_msg_t *msg, HV *hv); extern int srun_timeout_msg_to_hv(srun_timeout_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, 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); /********** 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 */