|  | /*****************************************************************************\ | 
|  | *  step_ctx.h - step context declarations | 
|  | ***************************************************************************** | 
|  | *  Copyright (C) 2006 The Regents of the University of California. | 
|  | *  Produced at Lawrence Livermore National Laboratory (cf, DISCLAIMER). | 
|  | *  Written by Morris Jette <jette1@llnl.gov>, | 
|  | *  Christopher J. Morrone <morrone2@llnl.gov> | 
|  | *  CODE-OCEC-09-009. All rights reserved. | 
|  | * | 
|  | *  This file is part of Slurm, a resource management program. | 
|  | *  For details, see <https://slurm.schedmd.com/>. | 
|  | *  Please also read the included file: DISCLAIMER. | 
|  | * | 
|  | *  Slurm is free software; you can redistribute it and/or modify it under | 
|  | *  the terms of the GNU General Public License as published by the Free | 
|  | *  Software Foundation; either version 2 of the License, or (at your option) | 
|  | *  any later version. | 
|  | * | 
|  | *  Slurm is distributed in the hope that it will be useful, but WITHOUT ANY | 
|  | *  WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS | 
|  | *  FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more | 
|  | *  details. | 
|  | * | 
|  | *  You should have received a copy of the GNU General Public License along | 
|  | *  with Slurm; if not, write to the Free Software Foundation, Inc., | 
|  | *  51 Franklin Street, Fifth Floor, Boston, MA 02110-1301  USA. | 
|  | \*****************************************************************************/ | 
|  | #ifndef _STEP_CTX_H | 
|  | #define _STEP_CTX_H | 
|  |  | 
|  | #include <inttypes.h> | 
|  | #include <unistd.h> | 
|  |  | 
|  | #include "slurm/slurm.h" | 
|  |  | 
|  | #include "src/api/step_launch.h" | 
|  |  | 
|  | #define STEP_CTX_MAGIC 0xc7a3 | 
|  |  | 
|  | struct slurm_step_ctx_struct { | 
|  | uint16_t magic;	/* magic number */ | 
|  |  | 
|  | uint32_t job_id;	/* assigned job id */ | 
|  |  | 
|  | job_step_create_request_msg_t *step_req; | 
|  | job_step_create_response_msg_t *step_resp; | 
|  |  | 
|  | /* Used by slurm_step_launch() */ | 
|  | struct step_launch_state *launch_state; | 
|  | uint16_t verbose_level; /* for extra logging decisions in step | 
|  | * launch api */ | 
|  | }; | 
|  |  | 
|  | /* | 
|  | * step_ctx_create_timeout - Create a job step and its context. | 
|  | * IN step_req - job step request | 
|  | * IN timeout - in milliseconds | 
|  | * OUT timed_out - indicate if poll timed-out | 
|  | * RET the step context or NULL on failure with slurm errno set | 
|  | * NOTE: Free allocated memory using slurm_step_ctx_destroy. | 
|  | */ | 
|  | extern slurm_step_ctx_t *step_ctx_create_timeout( | 
|  | job_step_create_request_msg_t *step_req, int timeout, bool *timed_out); | 
|  |  | 
|  | /* | 
|  | * step_ctx_create_no_alloc - Create a job step and its context without | 
|  | *                            getting an allocation. | 
|  | * IN step_req - job step request | 
|  | * IN step_id     - since we are faking it give me the id to use | 
|  | * RET the step context or NULL on failure with slurm errno set | 
|  | * NOTE: Free allocated memory using slurm_step_ctx_destroy. | 
|  | */ | 
|  | extern slurm_step_ctx_t *step_ctx_create_no_alloc( | 
|  | job_step_create_request_msg_t *step_req, uint32_t step_id); | 
|  |  | 
|  | /* | 
|  | * step_ctx_destroy - free allocated memory for a job step context. | 
|  | * IN ctx - job step context generated by slurm_step_ctx_create | 
|  | * RET SLURM_SUCCESS or SLURM_ERROR (with slurm_errno set) | 
|  | */ | 
|  | extern int step_ctx_destroy(slurm_step_ctx_t *ctx); | 
|  |  | 
|  | #endif /* _STEP_CTX_H */ |