mirror of
https://github.com/Zenithsiz/ftmemsim-valgrind.git
synced 2026-02-03 18:13:01 +00:00
There was some code to handle /proc/curproc/file (a symlink to the exe that wee need to bodge as it refers to the tool exe). But it was neither tested nor working. Can't use the same technique as Linux and Solaris which have more complete /proc filesystems where each pid has symlinks for each open file, which we use for the guest. Instead need to copy the path ourselves. So move sys_readlink out of generic. Simplify the handling of the resolved guest exe name - store it in a global like VG_(args_the_exename).
73 lines
2.6 KiB
C
73 lines
2.6 KiB
C
|
|
/*--------------------------------------------------------------------*/
|
|
/*--- Misc client state info pub_tool_clientstate.h ---*/
|
|
/*--------------------------------------------------------------------*/
|
|
|
|
/*
|
|
This file is part of Valgrind, a dynamic binary instrumentation
|
|
framework.
|
|
|
|
Copyright (C) 2000-2017 Julian Seward
|
|
jseward@acm.org
|
|
|
|
This program 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.
|
|
|
|
This program 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 this program; if not, see <http://www.gnu.org/licenses/>.
|
|
|
|
The GNU General Public License is contained in the file COPYING.
|
|
*/
|
|
|
|
#ifndef __PUB_TOOL_CLIENTSTATE_H
|
|
#define __PUB_TOOL_CLIENTSTATE_H
|
|
|
|
#include "pub_tool_basics.h" // VG_ macro
|
|
#include "pub_tool_xarray.h" // XArray
|
|
|
|
/* Note, this header requires pub_{core,tool}_xarray.h to be
|
|
included ahead of it. */
|
|
|
|
// Command line pieces, after they have been extracted from argv in
|
|
// m_main.main(). These are all NULL-terminated vectors.
|
|
|
|
/* Args for the client. */
|
|
extern XArray* /* of HChar* */ VG_(args_for_client);
|
|
|
|
/* Args for V. This is the concatenation of the following:
|
|
- contents of ~/.valgrindrc
|
|
- contents of $VALGRIND_OPTS
|
|
- contents of ./.valgrindrc
|
|
- args from the command line
|
|
in the stated order.
|
|
|
|
Only the last of these is passed onwards to child Valgrinds at
|
|
client sys_execve, since the children will re-acquire the first 3
|
|
categories for themselves. Therefore we also record the number of
|
|
these no-pass-at-execve arguments -- that is what
|
|
VG_(args_for_valgrind_noexecpass) is. */
|
|
extern XArray* /* of HChar* */ VG_(args_for_valgrind);
|
|
|
|
/* Number of leading args in VG_(args_for_valgrind) not to pass on at
|
|
exec time. */
|
|
extern Int VG_(args_for_valgrind_noexecpass);
|
|
|
|
/* The name of the client executable, as specified on the command
|
|
line. */
|
|
extern const HChar* VG_(args_the_exename);
|
|
|
|
extern const HChar* VG_(resolved_exename);
|
|
|
|
#endif // __PUB_TOOL_CLIENTSTATE_H
|
|
|
|
/*--------------------------------------------------------------------*/
|
|
/*--- end ---*/
|
|
/*--------------------------------------------------------------------*/
|