blob: a3a186bc65e24e21d2a5c2de59ab72ce3894a614 [file] [log] [blame]
njnf39e9a32005-06-12 02:43:17 +00001
2/*--------------------------------------------------------------------*/
3/*--- Process-related libc stuff pub_tool_libcproc.h ---*/
4/*--------------------------------------------------------------------*/
5
6/*
7 This file is part of Valgrind, a dynamic binary instrumentation
8 framework.
9
Elliott Hughesed398002017-06-21 14:41:24 -070010 Copyright (C) 2000-2017 Julian Seward
njnf39e9a32005-06-12 02:43:17 +000011 jseward@acm.org
12
13 This program is free software; you can redistribute it and/or
14 modify it under the terms of the GNU General Public License as
15 published by the Free Software Foundation; either version 2 of the
16 License, or (at your option) any later version.
17
18 This program is distributed in the hope that it will be useful, but
19 WITHOUT ANY WARRANTY; without even the implied warranty of
20 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
21 General Public License for more details.
22
23 You should have received a copy of the GNU General Public License
24 along with this program; if not, write to the Free Software
25 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
26 02111-1307, USA.
27
28 The GNU General Public License is contained in the file COPYING.
29*/
30
31#ifndef __PUB_TOOL_LIBCPROC_H
32#define __PUB_TOOL_LIBCPROC_H
33
florian535fb1b2013-09-15 13:54:34 +000034#include "pub_tool_basics.h" // VG_ macro
35#include "pub_tool_vki.h" // vki_rlimit
36
njnf39e9a32005-06-12 02:43:17 +000037/* ---------------------------------------------------------------------
38 Command-line and environment stuff
39 ------------------------------------------------------------------ */
40
njn08ce7b32009-02-27 03:38:28 +000041/* Client environment. */
florian19f91bb2012-11-10 22:29:54 +000042extern HChar** VG_(client_envp);
njnf39e9a32005-06-12 02:43:17 +000043
44/* Looks up VG_(client_envp) */
florian19f91bb2012-11-10 22:29:54 +000045extern HChar* VG_(getenv) ( const HChar* name );
njnf39e9a32005-06-12 02:43:17 +000046
njn8d9965c2005-06-12 17:47:24 +000047/* Path to all our library/aux files */
florian19f91bb2012-11-10 22:29:54 +000048extern const HChar *VG_(libdir);
njn8d9965c2005-06-12 17:47:24 +000049
njne323a6b2010-07-01 02:35:03 +000050// The name of the LD_PRELOAD-equivalent variable. It varies across
51// platforms.
florian19f91bb2012-11-10 22:29:54 +000052extern const HChar* VG_(LD_PRELOAD_var_name);
njne323a6b2010-07-01 02:35:03 +000053
sewardj8eb8bab2015-07-21 14:44:28 +000054/* Resolves filename of VG_(cl_exec_fd) and copies it to the buffer.
55 Buffer must not be NULL and buf_size must be at least 1.
56 If buffer is not large enough it is terminated with '\0' only
57 when 'terminate_with_NUL == True'. */
58extern void VG_(client_fname)(HChar *buffer, SizeT buf_size,
59 Bool terminate_with_NUL);
60
61/* Concatenates client exename and command line arguments into
62 the buffer. Buffer must not be NULL and buf_size must be
63 at least 1. Buffer is always terminated with '\0'. */
64extern void VG_(client_cmd_and_args)(HChar *buffer, SizeT buf_size);
65
njnf39e9a32005-06-12 02:43:17 +000066/* ---------------------------------------------------------------------
67 Important syscalls
68 ------------------------------------------------------------------ */
69
njne9ba34a2008-10-13 04:19:15 +000070extern Int VG_(waitpid)( Int pid, Int *status, Int options );
florian19f91bb2012-11-10 22:29:54 +000071extern Int VG_(system) ( const HChar* cmd );
sewardj8eb8bab2015-07-21 14:44:28 +000072extern Int VG_(spawn) ( const HChar *filename, const HChar **argv );
njne9ba34a2008-10-13 04:19:15 +000073extern Int VG_(fork) ( void);
sewardj8eb8bab2015-07-21 14:44:28 +000074extern void VG_(execv) ( const HChar* filename, const HChar** argv );
rhyskidd05be8f52015-04-01 12:15:49 +000075extern Int VG_(sysctl) ( Int *name, UInt namelen, void *oldp, SizeT *oldlenp, void *newp, SizeT newlen );
njnf39e9a32005-06-12 02:43:17 +000076
77/* ---------------------------------------------------------------------
sewardj3b290482011-05-06 21:02:55 +000078 Resource limits and capabilities
njnf39e9a32005-06-12 02:43:17 +000079 ------------------------------------------------------------------ */
80
81extern Int VG_(getrlimit) ( Int resource, struct vki_rlimit *rlim );
82extern Int VG_(setrlimit) ( Int resource, const struct vki_rlimit *rlim );
sewardj3b290482011-05-06 21:02:55 +000083extern Int VG_(prctl) (Int option,
84 ULong arg2, ULong arg3, ULong arg4, ULong arg5);
njnf39e9a32005-06-12 02:43:17 +000085
86/* ---------------------------------------------------------------------
87 pids, etc
88 ------------------------------------------------------------------ */
89
sewardj45f4e7c2005-09-27 19:20:21 +000090extern Int VG_(gettid) ( void );
njnf39e9a32005-06-12 02:43:17 +000091extern Int VG_(getpid) ( void );
92extern Int VG_(getppid) ( void );
93extern Int VG_(getpgrp) ( void );
sewardj45f4e7c2005-09-27 19:20:21 +000094extern Int VG_(geteuid) ( void );
95extern Int VG_(getegid) ( void );
njnf39e9a32005-06-12 02:43:17 +000096
97/* ---------------------------------------------------------------------
98 Timing
99 ------------------------------------------------------------------ */
100
njnb63ca162007-03-28 12:16:55 +0000101// Returns the number of milliseconds passed since the progam started
102// (roughly; it gets initialised partway through Valgrind's initialisation
103// steps).
njnf39e9a32005-06-12 02:43:17 +0000104extern UInt VG_(read_millisecond_timer) ( void );
florian82b92852015-01-08 14:43:29 +0000105extern Int VG_(gettimeofday)(struct vki_timeval *tv, struct vki_timezone *tz);
njnf39e9a32005-06-12 02:43:17 +0000106
njne9ba34a2008-10-13 04:19:15 +0000107/* ---------------------------------------------------------------------
108 atfork
109 ------------------------------------------------------------------ */
110
111typedef void (*vg_atfork_t)(ThreadId);
112extern void VG_(atfork)(vg_atfork_t pre, vg_atfork_t parent, vg_atfork_t child);
113
114
njnf39e9a32005-06-12 02:43:17 +0000115#endif // __PUB_TOOL_LIBCPROC_H
116
117/*--------------------------------------------------------------------*/
118/*--- end ---*/
119/*--------------------------------------------------------------------*/