blob: 2c346f3aadc36489e493db85a0f5e9b0ddf4058f [file] [log] [blame]
/*****************************************************************************\
* 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 */