|  | /*****************************************************************************\ | 
|  | * src/common/io_hdr.h - IO connection header functions | 
|  | ***************************************************************************** | 
|  | *  Copyright (C) 2002 The Regents of the University of California. | 
|  | *  Produced at Lawrence Livermore National Laboratory (cf, DISCLAIMER). | 
|  | *  Written by Mark A. Grondona <mgrondona@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. | 
|  | * | 
|  | *  In addition, as a special exception, the copyright holders give permission | 
|  | *  to link the code of portions of this program with the OpenSSL library under | 
|  | *  certain conditions as described in each individual source file, and | 
|  | *  distribute linked combinations including the two. You must obey the GNU | 
|  | *  General Public License in all respects for all of the code used other than | 
|  | *  OpenSSL. If you modify file(s) with this exception, you may extend this | 
|  | *  exception to your version of the file(s), but you are not obligated to do | 
|  | *  so. If you do not wish to do so, delete this exception statement from your | 
|  | *  version.  If you delete this exception statement from all source files in | 
|  | *  the program, then also delete it here. | 
|  | * | 
|  | *  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. | 
|  | \*****************************************************************************/ | 
|  |  | 
|  | /* | 
|  | * srun I/O socket connection sequences: | 
|  | * | 
|  | * Connection Initialization: | 
|  | * | 
|  | * srun via io_initial_client_connect(): | 
|  | *	slurmstepd sends: (packed via io_init_msg_pack()) | 
|  | *	     uint32_t: length of packet | 
|  | *	     packed io_init_msg_t | 
|  | *	srun receives via io_init_msg_read_from_fd() | 
|  | *	srun validates via io_init_msg_validate() | 
|  | * | 
|  | * sattach via io_client_connect(): | 
|  | * | 
|  | * | 
|  | * Same message format sent bidirectionally after initialization: | 
|  | *	packed io_hdr_t via io_hdr_pack() | 
|  | *	io_hdr_t.length bytes of payload | 
|  | * | 
|  | *	srun only sends types: | 
|  | *		SLURM_IO_CONNECTION_TEST | 
|  | *		SLURM_IO_STDIN | 
|  | *		SLURM_IO_ALLSTDIN | 
|  | * | 
|  | *	slurmstepd honors task_read_info.type to determine where messages sent. | 
|  | * | 
|  | * Connection ends with io_hdr_t.length=0 packet with no payload | 
|  | */ | 
|  |  | 
|  | #ifndef _HAVE_IO_HDR_H | 
|  | #define _HAVE_IO_HDR_H | 
|  |  | 
|  | #include <inttypes.h> | 
|  |  | 
|  | #include "src/common/pack.h" | 
|  |  | 
|  | #define SLURM_IO_MAX_MSG_LEN 1024 | 
|  |  | 
|  | typedef enum { | 
|  | SLURM_IO_INVALID = -1, | 
|  | SLURM_IO_STDIN = 0, | 
|  | SLURM_IO_STDOUT = 1, | 
|  | SLURM_IO_STDERR = 2, | 
|  | SLURM_IO_ALLSTDIN = 3, | 
|  | SLURM_IO_CONNECTION_TEST = 4, | 
|  | SLURM_IO_INVALID_MAX | 
|  | } io_hdr_type_t; | 
|  |  | 
|  | typedef struct { | 
|  | uint16_t      version; | 
|  | char          *io_key; | 
|  | uint32_t      nodeid; | 
|  | uint32_t      stdout_objs; | 
|  | uint32_t      stderr_objs; | 
|  | } io_init_msg_t; | 
|  |  | 
|  |  | 
|  | typedef struct { | 
|  | io_hdr_type_t type; | 
|  | uint16_t      gtaskid; | 
|  | uint16_t      ltaskid; | 
|  | uint32_t      length; | 
|  | } io_hdr_t; | 
|  |  | 
|  | /* | 
|  | * IO Header is always written/read with the exact same number of bytes | 
|  | * Changing this count will break older srun clients as this packet is | 
|  | * unversioned. | 
|  | */ | 
|  | #define IO_HDR_PACKET_BYTES 10 | 
|  |  | 
|  | /* | 
|  | * Return the packed size of an IO header in bytes; | 
|  | */ | 
|  | void io_hdr_pack(io_hdr_t *hdr, buf_t *buffer); | 
|  | /* | 
|  | * Pack io_hdr_t into buffer | 
|  | * IN hdr - struct to pack | 
|  | * IN buffer - destination buffer to populate | 
|  | * RET SLURM_SUCCESS or | 
|  | * 	EAGAIN if buffer does not container entire packet | 
|  | * 	or error | 
|  | */ | 
|  | int io_hdr_unpack(io_hdr_t *hdr, buf_t *buffer); | 
|  | int io_hdr_read_fd(int fd, void *tls_conn, io_hdr_t *hdr); | 
|  |  | 
|  | /* | 
|  | * Validate io init msg | 
|  | */ | 
|  | int io_init_msg_validate(io_init_msg_t *msg, const char *sig); | 
|  | int io_init_msg_write_to_fd(int fd, void *tls_conn, io_init_msg_t *msg); | 
|  | int io_init_msg_read_from_fd(int fd, void *tls_conn, io_init_msg_t *msg); | 
|  |  | 
|  | #endif /* !_HAVE_IO_HDR_H */ |