/*--------------------------------------------------------------------*/ /*--- A home for miscellaneous bits of information which pertain ---*/ /*--- to the client's state. ---*/ /*--- m_clientstate.c ---*/ /*--------------------------------------------------------------------*/ /* This file is part of Valgrind, a dynamic binary instrumentation framework. Copyright (C) 2000-2015 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, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA. The GNU General Public License is contained in the file COPYING. */ #include "pub_core_basics.h" #include "pub_core_vki.h" #include "pub_core_xarray.h" #include "pub_core_clientstate.h" /*-----------------------------------------------------------------*/ /*--- ---*/ /*--- Basic globals about the address space. ---*/ /*--- ---*/ /*-----------------------------------------------------------------*/ /* Client address space, lowest to highest (see top of ume.c) */ // TODO: get rid of as many of these as possible. /* ***Initial*** lowest address of the stack segment of the main thread. The main stack will grow if needed but VG_(clstk_start_base) will not be changed according to the growth. */ Addr VG_(clstk_start_base) = 0; /* Initial highest address of the stack segment of the main thread. */ Addr VG_(clstk_end) = 0; UWord VG_(clstk_id) = 0; /* Maximum size of the main thread's client stack. */ SizeT VG_(clstk_max_size) = 0; /* Solaris and Linux only, specifies where the client auxv is. This is set up as part of setup_client_stack() in initimg-{linux,solaris}.c. */ UWord* VG_(client_auxv) = NULL; Addr VG_(brk_base) = 0; /* start of brk */ Addr VG_(brk_limit) = 0; /* current brk */ /* A fd which refers to the client executable. */ Int VG_(cl_exec_fd) = -1; /* A fd which refers to the fake /proc/<pid>/cmdline in /tmp. */ Int VG_(cl_cmdline_fd) = -1; /* A fd which refers to the fake /proc/<pid>/auxv in /tmp. */ Int VG_(cl_auxv_fd) = -1; #if defined(VGO_solaris) /* A fd which refers to the fake /proc/<pid>/psinfo in /tmp. */ Int VG_(cl_psinfo_fd) = -1; #endif /* VGO_solaris */ // Command line pieces, after they have been extracted from argv in // m_main.main(). The payload vectors are allocated in VG_AR_CORE // (the default arena). They are never freed. /* Args for the client. */ XArray* /* of HChar* */ VG_(args_for_client) = NULL; /* Args for V (augments, then those from the launcher). */ XArray* /* of HChar* */ VG_(args_for_valgrind) = NULL; /* How many of the above not to pass on at execve time? */ Int VG_(args_for_valgrind_noexecpass) = 0; /* The name of the client executable, as specified on the command line. */ const HChar* VG_(args_the_exename) = NULL; // Client's original rlimit data and rlimit stack struct vki_rlimit VG_(client_rlimit_data); struct vki_rlimit VG_(client_rlimit_stack); // Name of the launcher, as extracted from VALGRIND_LAUNCHER at // startup. HChar* VG_(name_of_launcher) = NULL; /* Application-visible file descriptor limits */ Int VG_(fd_soft_limit) = -1; Int VG_(fd_hard_limit) = -1; /* Useful addresses extracted from the client */ /* Where is the __libc_freeres_wrapper routine we made? */ Addr VG_(client___libc_freeres_wrapper) = 0; /* x86-linux only: where is glibc's _dl_sysinfo_int80 function? Finding it isn't essential, but knowing where it is does sometimes help produce better back traces. See big comment in VG_(get_StackTrace) in m_stacktrace.c for further info. */ Addr VG_(client__dl_sysinfo_int80) = 0; /* Address of the (internal) glibc nptl pthread stack cache size, declared as: static size_t stack_cache_actsize; in nptl/allocatestack.c */ SizeT* VG_(client__stack_cache_actsize__addr) = 0; #if defined(VGO_solaris) /* Address of variable vg_vfork_fildes in vgpreload_core.so.0 (vg_preloaded.c). */ Int* VG_(vfork_fildes_addr) = 0; #endif /*--------------------------------------------------------------------*/ /*--- end ---*/ /*--------------------------------------------------------------------*/