|  | /*****************************************************************************\ | 
|  | *  track_script.h - Track scripts running asynchronously | 
|  | ***************************************************************************** | 
|  | *  Copyright (C) SchedMD LLC. | 
|  | * | 
|  | *  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. | 
|  | \*****************************************************************************/ | 
|  |  | 
|  | #ifndef __TRACK_SCRIPT_H__ | 
|  | #define __TRACK_SCRIPT_H__ | 
|  |  | 
|  | #include "config.h" | 
|  |  | 
|  | #include <inttypes.h> | 
|  |  | 
|  | /* Init track_script system */ | 
|  | extern void track_script_init(void); | 
|  |  | 
|  | /* Finish track_script system */ | 
|  | extern void track_script_fini(void); | 
|  |  | 
|  | /* Flush all scripts from track_script system */ | 
|  | extern void track_script_flush(void); | 
|  |  | 
|  | /* Flush tracked scripts for given job_id */ | 
|  | extern void track_script_flush_job(uint32_t job_id); | 
|  |  | 
|  | /* | 
|  | * create, initialize, and add a track_script_rec_t to the track_script system. | 
|  | * IN job_id - Job id we are running this script under | 
|  | * IN cpid - If non-zero this track_script_rec_t will implicitly call | 
|  | *           track_script_add | 
|  | * IN tid - thread id of thread we are tracking | 
|  | */ | 
|  | extern void track_script_rec_add(uint32_t job_id, pid_t cpid, pthread_t tid); | 
|  |  | 
|  | /* | 
|  | * Return true if the script was SIGKILL'd (usually by track_script_flush() or | 
|  | * track_script_flush_job()). | 
|  | * | 
|  | * IN tid - thread id that is tracking the script | 
|  | * IN status - exit status of the script. If the exit status has not yet been | 
|  | *             obtained (by calling waitpid), then passing 0 here will still | 
|  | *             return true if track_script_flush() was called. | 
|  | * IN waitpid_called - pass true if waitpid(2) has been called to reap the | 
|  | *                     PID and get the exit status. If true, then this will | 
|  | *                     signal the cleanup thread that is waiting for this | 
|  | *                     script to complete. | 
|  | * | 
|  | * RET true if the WTERMSIG(status) == SIGKILL; or true if track_script_flush | 
|  | *     was called | 
|  | */ | 
|  | extern bool track_script_killed(pthread_t tid, int status, bool waitpid_called); | 
|  |  | 
|  | /* Remove this thread from the track_script system */ | 
|  | extern void track_script_remove(pthread_t tid); | 
|  |  | 
|  | /* Set the thread's cpid (script pid) or clear with 0 */ | 
|  | extern void track_script_reset_cpid(pthread_t tid, pid_t cpid); | 
|  |  | 
|  | #endif // __TRACK_SCRIPT_H__ |