FreeBSD: add file descriptor tracking for _umtx_op
[valgrind.git] / coregrind / m_initimg / initimg-linux.c
blob5359189bf69181f8f22317c1a7ac9d5a8b6b5988
2 /*--------------------------------------------------------------------*/
3 /*--- Startup: create initial process image on Linux ---*/
4 /*--- initimg-linux.c ---*/
5 /*--------------------------------------------------------------------*/
7 /*
8 This file is part of Valgrind, a dynamic binary instrumentation
9 framework.
11 Copyright (C) 2000-2017 Julian Seward
12 jseward@acm.org
14 This program is free software; you can redistribute it and/or
15 modify it under the terms of the GNU General Public License as
16 published by the Free Software Foundation; either version 2 of the
17 License, or (at your option) any later version.
19 This program is distributed in the hope that it will be useful, but
20 WITHOUT ANY WARRANTY; without even the implied warranty of
21 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
22 General Public License for more details.
24 You should have received a copy of the GNU General Public License
25 along with this program; if not, see <http://www.gnu.org/licenses/>.
27 The GNU General Public License is contained in the file COPYING.
30 #if defined(VGO_linux)
32 #include "pub_core_basics.h"
33 #include "pub_core_vki.h"
34 #include "pub_core_debuglog.h"
35 #include "pub_core_libcbase.h"
36 #include "pub_core_libcassert.h"
37 #include "pub_core_libcfile.h"
38 #include "pub_core_libcproc.h"
39 #include "pub_core_libcprint.h"
40 #include "pub_core_xarray.h"
41 #include "pub_core_clientstate.h"
42 #include "pub_core_aspacemgr.h"
43 #include "pub_core_mallocfree.h"
44 #include "pub_core_machine.h"
45 #include "pub_core_ume.h"
46 #include "pub_core_options.h"
47 #include "pub_core_syscall.h"
48 #include "pub_core_tooliface.h" /* VG_TRACK */
49 #include "pub_core_threadstate.h" /* ThreadArchState */
50 #include "pub_core_pathscan.h" /* find_executable */
51 #include "pub_core_initimg.h" /* self */
53 /* --- !!! --- EXTERNAL HEADERS start --- !!! --- */
54 #define _GNU_SOURCE
55 #define _FILE_OFFSET_BITS 64
56 /* This is for ELF types etc, and also the AT_ constants. */
57 #include <elf.h>
58 /* --- !!! --- EXTERNAL HEADERS end --- !!! --- */
61 /*====================================================================*/
62 /*=== Loading the client ===*/
63 /*====================================================================*/
65 /* Load the client whose name is VG_(argv_the_exename). */
67 static void load_client ( /*MOD*/ExeInfo* info,
68 /*OUT*/Addr* client_ip,
69 /*OUT*/Addr* client_toc)
71 const HChar* exe_name;
72 Int ret;
73 SysRes res;
75 vg_assert( VG_(args_the_exename) != NULL);
76 exe_name = VG_(find_executable)( VG_(args_the_exename) );
78 if (!exe_name) {
79 VG_(printf)("valgrind: %s: command not found\n", VG_(args_the_exename));
80 VG_(exit)(127); // 127 is Posix NOTFOUND
83 ret = VG_(do_exec)(exe_name, info);
84 if (ret < 0) {
85 VG_(printf)("valgrind: could not execute '%s'\n", exe_name);
86 VG_(exit)(1);
89 // The client was successfully loaded! Continue.
91 /* Get hold of a file descriptor which refers to the client
92 executable. This is needed for attaching to GDB. */
93 res = VG_(open)(exe_name, VKI_O_RDONLY, VKI_S_IRUSR);
94 if (!sr_isError(res))
95 VG_(cl_exec_fd) = sr_Res(res);
97 /* Copy necessary bits of 'info' that were filled in */
98 *client_ip = info->init_ip;
99 *client_toc = info->init_toc;
100 VG_(brk_base) = VG_(brk_limit) = VG_PGROUNDUP(info->brkbase);
104 /*====================================================================*/
105 /*=== Setting up the client's environment ===*/
106 /*====================================================================*/
108 /* Prepare the client's environment. This is basically a copy of our
109 environment, except:
111 LD_PRELOAD=$VALGRIND_LIB/vgpreload_core-PLATFORM.so:
112 ($VALGRIND_LIB/vgpreload_TOOL-PLATFORM.so:)?
113 $LD_PRELOAD
115 If this is missing, then it is added.
117 Also, remove any binding for VALGRIND_LAUNCHER=. The client should
118 not be able to see this.
120 If this needs to handle any more variables it should be hacked
121 into something table driven. The copy is VG_(malloc)'d space.
123 static HChar** setup_client_env ( HChar** origenv, const HChar* toolname, Bool use_stack_cache_tunable)
125 vg_assert(origenv);
126 vg_assert(toolname);
128 const HChar* preload_core = "vgpreload_core";
129 const HChar* ld_preload = "LD_PRELOAD=";
130 const HChar* v_launcher = VALGRIND_LAUNCHER "=";
131 Int ld_preload_len = VG_(strlen)( ld_preload );
132 Int v_launcher_len = VG_(strlen)( v_launcher );
133 Bool ld_preload_done = False;
134 Int vglib_len = VG_(strlen)(VG_(libdir));
135 Bool debug = False;
137 HChar** cpp;
138 HChar** ret;
139 HChar* preload_tool_path;
140 Int envc, i;
142 /* Alloc space for the vgpreload_core.so path and vgpreload_<tool>.so
143 paths. We might not need the space for vgpreload_<tool>.so, but it
144 doesn't hurt to over-allocate briefly. The 16s are just cautious
145 slop. */
146 Int preload_core_path_len = vglib_len + VG_(strlen)(preload_core)
147 + sizeof(VG_PLATFORM) + 16;
148 Int preload_tool_path_len = vglib_len + VG_(strlen)(toolname)
149 + sizeof(VG_PLATFORM) + 16;
150 Int preload_string_len = preload_core_path_len + preload_tool_path_len;
151 HChar* preload_string = VG_(malloc)("initimg-linux.sce.1",
152 preload_string_len);
153 /* Determine if there's a vgpreload_<tool>_<platform>.so file, and setup
154 preload_string. */
155 preload_tool_path = VG_(malloc)("initimg-linux.sce.2", preload_tool_path_len);
156 VG_(snprintf)(preload_tool_path, preload_tool_path_len,
157 "%s/vgpreload_%s-%s.so", VG_(libdir), toolname, VG_PLATFORM);
158 if (VG_(access)(preload_tool_path, True/*r*/, False/*w*/, False/*x*/) == 0) {
159 VG_(snprintf)(preload_string, preload_string_len, "%s/%s-%s.so:%s",
160 VG_(libdir), preload_core, VG_PLATFORM, preload_tool_path);
161 } else {
162 VG_(snprintf)(preload_string, preload_string_len, "%s/%s-%s.so",
163 VG_(libdir), preload_core, VG_PLATFORM);
165 VG_(free)(preload_tool_path);
167 VG_(debugLog)(2, "initimg", "preload_string:\n");
168 VG_(debugLog)(2, "initimg", " \"%s\"\n", preload_string);
170 /* Count the original size of the env */
171 if (debug) VG_(printf)("\n\n");
172 envc = 0;
173 for (cpp = origenv; cpp && *cpp; cpp++) {
174 envc++;
175 if (debug) VG_(printf)("XXXXXXXXX: BEFORE %s\n", *cpp);
178 /* Allocate a new space
179 * Size is envc + 1 new entry + maybe one for GLIBC_TUNABLES + NULL */
180 ret = VG_(malloc) ("initimg-linux.sce.3",
181 sizeof(HChar *) * (envc+1+1+(use_stack_cache_tunable ? 1 : 0)));
183 /* copy it over */
184 for (cpp = ret; *origenv; ) {
185 if (debug) VG_(printf)("XXXXXXXXX: COPY %s\n", *origenv);
186 *cpp++ = *origenv++;
188 *cpp = NULL;
190 vg_assert(envc == (cpp - ret));
192 /* Walk over the new environment, mashing as we go */
193 for (cpp = ret; cpp && *cpp; cpp++) {
194 if (VG_(memcmp)(*cpp, ld_preload, ld_preload_len) == 0) {
195 Int len = VG_(strlen)(*cpp) + preload_string_len;
196 HChar *cp = VG_(malloc)("initimg-linux.sce.4", len);
198 VG_(snprintf)(cp, len, "%s%s:%s",
199 ld_preload, preload_string, (*cpp)+ld_preload_len);
201 *cpp = cp;
203 ld_preload_done = True;
205 if (use_stack_cache_tunable) {
206 /* overwrite value found with zeroes */
207 const HChar* search_string = "glibc.pthread.stack_cache_size=";
208 HChar* val;
209 if ((val = VG_(strstr)(*cpp, search_string))) {
210 val += VG_(strlen)(search_string);
211 while (*val != '\0' && *val != ':') {
212 *val++ = '0';
214 use_stack_cache_tunable = False;
217 if (debug) VG_(printf)("XXXXXXXXX: MASH %s\n", *cpp);
220 /* Add the missing bits */
221 if (!ld_preload_done) {
222 Int len = ld_preload_len + preload_string_len;
223 HChar *cp = VG_(malloc) ("initimg-linux.sce.5", len);
225 VG_(snprintf)(cp, len, "%s%s", ld_preload, preload_string);
227 ret[envc++] = cp;
228 if (debug) VG_(printf)("XXXXXXXXX: ADD %s\n", cp);
231 if (use_stack_cache_tunable) {
232 ret[envc++] = VG_(strdup)("initimg-linux.sce.6", "GLIBC_TUNABLES=glibc.pthread.stack_cache_size=0");
235 /* ret[0 .. envc-1] is live now. */
236 /* Find and remove a binding for VALGRIND_LAUNCHER. */
237 for (i = 0; i < envc; i++)
238 if (0 == VG_(memcmp)(ret[i], v_launcher, v_launcher_len))
239 break;
241 if (i < envc) {
242 for (; i < envc-1; i++)
243 ret[i] = ret[i+1];
244 envc--;
247 VG_(free)(preload_string);
248 ret[envc] = NULL;
250 for (i = 0; i < envc; i++) {
251 if (debug) VG_(printf)("XXXXXXXXX: FINAL %s\n", ret[i]);
254 return ret;
258 /*====================================================================*/
259 /*=== Setting up the client's stack ===*/
260 /*====================================================================*/
262 #ifndef AT_DCACHEBSIZE
263 #define AT_DCACHEBSIZE 19
264 #endif /* AT_DCACHEBSIZE */
266 #ifndef AT_ICACHEBSIZE
267 #define AT_ICACHEBSIZE 20
268 #endif /* AT_ICACHEBSIZE */
270 #ifndef AT_UCACHEBSIZE
271 #define AT_UCACHEBSIZE 21
272 #endif /* AT_UCACHEBSIZE */
274 #ifndef AT_BASE_PLATFORM
275 #define AT_BASE_PLATFORM 24
276 #endif /* AT_BASE_PLATFORM */
278 #ifndef AT_RANDOM
279 #define AT_RANDOM 25
280 #endif /* AT_RANDOM */
282 #ifndef AT_HWCAP2
283 #define AT_HWCAP2 26
284 #endif /* AT_HWCAP2 */
286 #ifndef AT_EXECFN
287 #define AT_EXECFN 31
288 #endif /* AT_EXECFN */
290 #ifndef AT_SYSINFO
291 #define AT_SYSINFO 32
292 #endif /* AT_SYSINFO */
294 #ifndef AT_SYSINFO_EHDR
295 #define AT_SYSINFO_EHDR 33
296 #endif /* AT_SYSINFO_EHDR */
298 #ifndef AT_SECURE
299 #define AT_SECURE 23 /* secure mode boolean */
300 #endif /* AT_SECURE */
302 /* Add a string onto the string table, and return its address */
303 static HChar *copy_str(HChar **tab, const HChar *str)
305 HChar *cp = *tab;
306 HChar *orig = cp;
308 while(*str)
309 *cp++ = *str++;
310 *cp++ = '\0';
312 if (0)
313 VG_(printf)("copied %p \"%s\" len %lld\n", orig, orig, (Long)(cp-orig));
315 *tab = cp;
317 return orig;
321 /* ----------------------------------------------------------------
323 This sets up the client's initial stack, containing the args,
324 environment and aux vector.
326 The format of the stack is:
328 higher address +-----------------+ <- clstack_end
330 : string table :
332 +-----------------+
333 | AT_NULL |
335 | auxv |
336 +-----------------+
337 | NULL |
339 | envp |
340 +-----------------+
341 | NULL |
343 | argv |
344 +-----------------+
345 | argc |
346 lower address +-----------------+ <- sp
347 | undefined |
350 Allocate and create the initial client stack. It is allocated down
351 from clstack_end, which was previously determined by the address
352 space manager. The returned value is the SP value for the client.
354 The client's auxv is created by copying and modifying our own one.
355 As a side effect of scanning our own auxv, some important bits of
356 info are collected:
358 VG_(cache_line_size_ppc32) // ppc32 only -- cache line size
359 VG_(have_altivec_ppc32) // ppc32 only -- is Altivec supported?
361 ---------------------------------------------------------------- */
363 struct auxv
365 Word a_type;
366 union {
367 void *a_ptr;
368 Word a_val;
369 } u;
372 static
373 struct auxv *find_auxv(UWord* sp)
375 sp++; // skip argc (Nb: is word-sized, not int-sized!)
377 while (*sp != 0) // skip argv
378 sp++;
379 sp++;
381 while (*sp != 0) // skip env
382 sp++;
383 sp++;
385 #if defined(VGA_ppc32) || defined(VGA_ppc64be) || defined(VGA_ppc64le)
386 # if defined AT_IGNOREPPC
387 while (*sp == AT_IGNOREPPC) // skip AT_IGNOREPPC entries
388 sp += 2;
389 # endif
390 #endif
392 return (struct auxv *)sp;
395 static
396 Addr setup_client_stack( void* init_sp,
397 HChar** orig_envp,
398 const ExeInfo* info,
399 UInt** client_auxv,
400 Addr clstack_end,
401 SizeT clstack_max_size,
402 const VexArchInfo* vex_archinfo )
404 /* The HW configuration setting (hwcaps) of the target can be
405 * checked against the Vex settings of the host platform as given
406 * by the values in vex_archinfo.
409 SysRes res;
410 HChar **cpp;
411 HChar *strtab; /* string table */
412 HChar *stringbase;
413 Addr *ptr;
414 struct auxv *auxv;
415 const struct auxv *orig_auxv;
416 const struct auxv *cauxv;
417 unsigned stringsize; /* total size of strings in bytes */
418 unsigned auxsize; /* total size of auxv in bytes */
419 Int argc; /* total argc */
420 Int envc; /* total number of env vars */
421 unsigned stacksize; /* total client stack size */
422 Addr client_SP; /* client stack base (initial SP) */
423 Addr clstack_start;
424 Int i;
426 vg_assert(VG_IS_PAGE_ALIGNED(clstack_end+1));
427 vg_assert( VG_(args_for_client) );
429 /* use our own auxv as a prototype */
430 orig_auxv = find_auxv(init_sp);
432 /* ==================== compute sizes ==================== */
434 /* first of all, work out how big the client stack will be */
435 stringsize = 0;
437 /* paste on the extra args if the loader needs them (ie, the #!
438 interpreter and its argument) */
439 argc = 0;
440 if (info->interp_name != NULL) {
441 argc++;
442 stringsize += VG_(strlen)(info->interp_name) + 1;
444 if (info->interp_args != NULL) {
445 argc++;
446 stringsize += VG_(strlen)(info->interp_args) + 1;
449 /* now scan the args we're given... */
450 stringsize += VG_(strlen)( VG_(args_the_exename) ) + 1;
452 for (i = 0; i < VG_(sizeXA)( VG_(args_for_client) ); i++) {
453 argc++;
454 stringsize += VG_(strlen)( * (HChar**)
455 VG_(indexXA)( VG_(args_for_client), i ))
456 + 1;
459 /* ...and the environment */
460 envc = 0;
461 for (cpp = orig_envp; cpp && *cpp; cpp++) {
462 envc++;
463 stringsize += VG_(strlen)(*cpp) + 1;
466 /* now, how big is the auxv? */
467 auxsize = sizeof(*auxv); /* there's always at least one entry: AT_NULL */
468 for (cauxv = orig_auxv; cauxv->a_type != AT_NULL; cauxv++) {
469 if (cauxv->a_type == AT_PLATFORM ||
470 cauxv->a_type == AT_BASE_PLATFORM)
471 stringsize += VG_(strlen)(cauxv->u.a_ptr) + 1;
472 else if (cauxv->a_type == AT_RANDOM)
473 stringsize += 16;
474 else if (cauxv->a_type == AT_EXECFN)
475 stringsize += VG_(strlen)(VG_(args_the_exename)) + 1;
476 auxsize += sizeof(*cauxv);
479 # if defined(VGP_ppc32_linux) || defined(VGP_ppc64be_linux) \
480 || defined(VGP_ppc64le_linux)
481 auxsize += 2 * sizeof(*cauxv);
482 # endif
484 /* OK, now we know how big the client stack is */
485 stacksize =
486 sizeof(Word) + /* argc */
487 sizeof(HChar **) + /* argc[0] == exename */
488 sizeof(HChar **)*argc + /* argv */
489 sizeof(HChar **) + /* terminal NULL */
490 sizeof(HChar **)*envc + /* envp */
491 sizeof(HChar **) + /* terminal NULL */
492 auxsize + /* auxv */
493 VG_ROUNDUP(stringsize, sizeof(Word)); /* strings (aligned) */
495 if (0) VG_(printf)("stacksize = %u\n", stacksize);
497 /* client_SP is the client's stack pointer */
498 client_SP = clstack_end - stacksize;
499 client_SP = VG_ROUNDDN(client_SP, 16); /* make stack 16 byte aligned */
501 /* base of the string table (aligned) */
502 stringbase = strtab = (HChar *)clstack_end
503 - VG_ROUNDUP(stringsize, sizeof(int));
505 clstack_start = VG_PGROUNDDN(client_SP);
507 /* The max stack size */
508 clstack_max_size = VG_PGROUNDUP(clstack_max_size);
510 if (0)
511 VG_(printf)("stringsize=%u auxsize=%u stacksize=%u maxsize=0x%lx\n"
512 "clstack_start %p\n"
513 "clstack_end %p\n",
514 stringsize, auxsize, stacksize, clstack_max_size,
515 (void*)clstack_start, (void*)clstack_end);
517 /* ==================== allocate space ==================== */
519 { SizeT anon_size = clstack_end - clstack_start + 1;
520 SizeT resvn_size = clstack_max_size - anon_size;
521 Addr anon_start = clstack_start;
522 Addr resvn_start = anon_start - resvn_size;
523 SizeT inner_HACK = 0;
524 Bool ok;
526 /* So far we've only accounted for space requirements down to the
527 stack pointer. If this target's ABI requires a redzone below
528 the stack pointer, we need to allocate an extra page, to
529 handle the worst case in which the stack pointer is almost at
530 the bottom of a page, and so there is insufficient room left
531 over to put the redzone in. In this case the simple thing to
532 do is allocate an extra page, by shrinking the reservation by
533 one page and growing the anonymous area by a corresponding
534 page. */
535 vg_assert(VG_STACK_REDZONE_SZB >= 0);
536 vg_assert(VG_STACK_REDZONE_SZB < VKI_PAGE_SIZE);
537 if (VG_STACK_REDZONE_SZB > 0) {
538 vg_assert(resvn_size > VKI_PAGE_SIZE);
539 resvn_size -= VKI_PAGE_SIZE;
540 anon_start -= VKI_PAGE_SIZE;
541 anon_size += VKI_PAGE_SIZE;
544 vg_assert(VG_IS_PAGE_ALIGNED(anon_size));
545 vg_assert(VG_IS_PAGE_ALIGNED(resvn_size));
546 vg_assert(VG_IS_PAGE_ALIGNED(anon_start));
547 vg_assert(VG_IS_PAGE_ALIGNED(resvn_start));
548 vg_assert(resvn_start == clstack_end + 1 - clstack_max_size);
550 # ifdef ENABLE_INNER
551 inner_HACK = 1024*1024; // create 1M non-fault-extending stack
552 # endif
554 if (0)
555 VG_(printf)("%#lx 0x%lx %#lx 0x%lx\n",
556 resvn_start, resvn_size, anon_start, anon_size);
558 /* Create a shrinkable reservation followed by an anonymous
559 segment. Together these constitute a growdown stack. */
560 res = VG_(mk_SysRes_Error)(0);
561 ok = VG_(am_create_reservation)(
562 resvn_start,
563 resvn_size -inner_HACK,
564 SmUpper,
565 anon_size +inner_HACK
567 if (ok) {
568 /* allocate a stack - mmap enough space for the stack */
569 res = VG_(am_mmap_anon_fixed_client)(
570 anon_start -inner_HACK,
571 anon_size +inner_HACK,
572 info->stack_prot
575 if ((!ok) || sr_isError(res)) {
576 /* Allocation of the stack failed. We have to stop. */
577 VG_(printf)("valgrind: "
578 "I failed to allocate space for the application's stack.\n");
579 VG_(printf)("valgrind: "
580 "This may be the result of a very large --main-stacksize=\n");
581 VG_(printf)("valgrind: setting. Cannot continue. Sorry.\n\n");
582 VG_(exit)(1);
585 vg_assert(ok);
586 vg_assert(!sr_isError(res));
588 /* Record stack extent -- needed for stack-change code. */
589 VG_(clstk_start_base) = anon_start -inner_HACK;
590 VG_(clstk_end) = VG_(clstk_start_base) + anon_size +inner_HACK -1;
594 /* ==================== create client stack ==================== */
596 ptr = (Addr*)client_SP;
598 /* --- client argc --- */
599 *ptr++ = argc + 1;
601 /* --- client argv --- */
602 if (info->interp_name)
603 *ptr++ = (Addr)copy_str(&strtab, info->interp_name);
604 if (info->interp_args)
605 *ptr++ = (Addr)copy_str(&strtab, info->interp_args);
607 *ptr++ = (Addr)copy_str(&strtab, VG_(args_the_exename));
609 for (i = 0; i < VG_(sizeXA)( VG_(args_for_client) ); i++) {
610 *ptr++ = (Addr)copy_str(
611 &strtab,
612 * (HChar**) VG_(indexXA)( VG_(args_for_client), i )
615 *ptr++ = 0;
617 /* --- envp --- */
618 VG_(client_envp) = (HChar **)ptr;
619 for (cpp = orig_envp; cpp && *cpp; ptr++, cpp++)
620 *ptr = (Addr)copy_str(&strtab, *cpp);
621 *ptr++ = 0;
623 /* --- auxv --- */
624 auxv = (struct auxv *)ptr;
625 *client_auxv = (UInt *)auxv;
626 VG_(client_auxv) = (UWord *)*client_auxv;
627 // ??? According to 'man proc', auxv is a array of unsigned long
628 // terminated by two zeros. Why is valgrind working with UInt ?
629 // We do not take ULong* (as ULong 8 bytes on a 32 bits),
630 // => we take UWord*
632 # if defined(VGP_ppc32_linux) || defined(VGP_ppc64be_linux) \
633 || defined(VGP_ppc64le_linux)
634 auxv[0].a_type = AT_IGNOREPPC;
635 auxv[0].u.a_val = AT_IGNOREPPC;
636 auxv[1].a_type = AT_IGNOREPPC;
637 auxv[1].u.a_val = AT_IGNOREPPC;
638 auxv += 2;
639 # endif
641 for (; orig_auxv->a_type != AT_NULL; auxv++, orig_auxv++) {
643 /* copy the entry... */
644 *auxv = *orig_auxv;
646 /* ...and fix up / examine the copy */
647 switch(auxv->a_type) {
649 case AT_IGNORE:
650 case AT_PHENT:
651 case AT_PAGESZ:
652 case AT_FLAGS:
653 case AT_NOTELF:
654 case AT_UID:
655 case AT_EUID:
656 case AT_GID:
657 case AT_EGID:
658 case AT_CLKTCK:
659 # if !defined(VGPV_arm_linux_android) \
660 && !defined(VGPV_x86_linux_android) \
661 && !defined(VGPV_mips32_linux_android) \
662 && !defined(VGPV_arm64_linux_android)
663 case AT_FPUCW: /* missing on android */
664 # endif
665 /* All these are pointerless, so we don't need to do
666 anything about them. */
667 break;
669 case AT_PHDR:
670 if (info->phdr == 0)
671 auxv->a_type = AT_IGNORE;
672 else
673 auxv->u.a_val = info->phdr;
674 break;
676 case AT_PHNUM:
677 if (info->phdr == 0)
678 auxv->a_type = AT_IGNORE;
679 else
680 auxv->u.a_val = info->phnum;
681 break;
683 case AT_BASE:
684 auxv->u.a_val = info->interp_offset;
685 break;
687 case AT_PLATFORM:
688 case AT_BASE_PLATFORM:
689 /* points to a platform description string */
690 auxv->u.a_ptr = copy_str(&strtab, orig_auxv->u.a_ptr);
691 break;
693 case AT_ENTRY:
694 auxv->u.a_val = info->entry;
695 break;
697 case AT_HWCAP:
698 # if defined(VGP_arm_linux)
699 { Bool has_neon = (auxv->u.a_val & VKI_HWCAP_NEON) > 0;
700 VG_(debugLog)(2, "initimg",
701 "ARM has-neon from-auxv: %s\n",
702 has_neon ? "YES" : "NO");
703 VG_(machine_arm_set_has_NEON)( has_neon );
704 # define VKI_HWCAP_TLS 32768
705 Bool has_tls = (auxv->u.a_val & VKI_HWCAP_TLS) > 0;
706 # undef VKI_HWCAP_TLS
707 VG_(debugLog)(2, "initimg",
708 "ARM has-tls from-auxv: %s\n",
709 has_tls ? "YES" : "NO");
710 /* If real hw sets properly HWCAP_TLS, we might
711 use this info to decide to really execute set_tls syscall
712 in syswrap-arm-linux.c rather than to base this on
713 conditional compilation. */
715 # elif defined(VGP_s390x_linux)
717 /* Out of the hardware features available on the platform,
718 advertise those "below" TE, as well as the ones explicitly
719 ORed in the expression below. Anything else, such as TE
720 itself, is not supported by Valgrind. */
721 auxv->u.a_val &= ((VKI_HWCAP_S390_TE - 1)
722 | VKI_HWCAP_S390_VXRS
723 | VKI_HWCAP_S390_VXRS_EXT
724 | VKI_HWCAP_S390_VXRS_EXT2
725 | VKI_HWCAP_S390_DFLT
726 | VKI_HWCAP_S390_NNPA);
728 # elif defined(VGP_arm64_linux)
730 /* Limit the AT_HWCAP to just those features we explicitly
731 support in VEX. */
732 #define ARM64_SUPPORTED_HWCAP (VKI_HWCAP_ATOMICS \
733 | VKI_HWCAP_AES \
734 | VKI_HWCAP_PMULL \
735 | VKI_HWCAP_SHA1 \
736 | VKI_HWCAP_SHA2 \
737 | VKI_HWCAP_SHA512 \
738 | VKI_HWCAP_CRC32 \
739 | VKI_HWCAP_FP \
740 | VKI_HWCAP_ASIMD \
741 | VKI_HWCAP_ASIMDDP)
742 auxv->u.a_val &= ARM64_SUPPORTED_HWCAP;
744 # endif
745 break;
746 # if defined(VGP_ppc64be_linux) || defined(VGP_ppc64le_linux)
747 case AT_HWCAP2: {
748 Bool auxv_2_07, hw_caps_2_07;
749 Bool auxv_3_0, hw_caps_3_0;
750 Bool auxv_3_1, hw_caps_3_1;
751 Bool auxv_scv_supported;
753 /* The HWCAP2 field may contain an arch_2_07 entry that indicates
754 * if the processor is compliant with the 2.07 ISA. (i.e. Power 8
755 * or beyond). The Valgrind vai.hwcaps value
756 * (coregrind/m_machine.c) has the VEX_HWCAPS_PPC64_ISA2_07
757 * flag set so Valgrind knows about Power8. Need to pass the
758 * HWCAP2 value along so the user level programs can detect that
759 * the processor supports ISA 2.07 and beyond.
761 /* Power Architecture 64-Bit ELF V2 ABI Specification
762 July 21, 2014, version 1.0, Page 124
763 www-03.ibm.com/technologyconnect/tgcm/TGCMServlet.wss?alias=OpenPOWER&linkid=1n0000
765 AT_HWCAP2
766 The a_val member of this entry is a bit map of hardware
767 capabilities. Some bit mask values include:
769 PPC_FEATURE2_ARCH_2_07 0x80000000
770 PPC_FEATURE2_HAS_HTM 0x40000000
771 PPC_FEATURE2_HAS_DSCR 0x20000000
772 PPC_FEATURE2_HAS_EBB 0x10000000
773 PPC_FEATURE2_HAS_ISEL 0x08000000
774 PPC_FEATURE2_HAS_TAR 0x04000000
775 PPC_FEATURE2_HAS_VCRYPTO 0x02000000
776 PPC_FEATURE2_HTM_NOSC 0x01000000
777 PPC_FEATURE2_ARCH_3_00 0x00800000
778 PPC_FEATURE2_HAS_IEEE128 0x00400000
779 PPC_FEATURE2_DARN 0x00200000
780 PPC_FEATURE2_SCV 0x00100000
781 PPC_FEATURE2_HTM_NO_SUSPEND 0x00080000
782 PPC_FEATURE2_ARCH_3_1 0x00040000
783 PPC_FEATURE2_MMA 0x00020000
785 auxv_2_07 = (auxv->u.a_val & 0x80000000ULL) == 0x80000000ULL;
786 hw_caps_2_07 = (vex_archinfo->hwcaps & VEX_HWCAPS_PPC64_ISA2_07)
787 == VEX_HWCAPS_PPC64_ISA2_07;
789 /* Verify the PPC_FEATURE2_ARCH_2_07 setting in HWCAP2
790 * matches the setting in VEX HWCAPS.
792 vg_assert(auxv_2_07 == hw_caps_2_07);
794 /* Power ISA version 3.0B
795 March 29, 2017
796 https://ibm.ent.box.com/s/1hzcwkwf8rbju5h9iyf44wm94amnlcrv
798 https://openpowerfoundation.org/technical/resource-catalog/
799 http://openpowerfoundation.org/wp-content/uploads/resources/leabi/leabi-20170510.pdf
800 64-bit ELF V2 ABI specification for Power. HWCAP2 bit pattern
801 for ISA 3.0, page 112.
804 /* ISA 3.0 */
805 auxv_3_0 = (auxv->u.a_val & 0x00800000ULL) == 0x00800000ULL;
806 hw_caps_3_0 = (vex_archinfo->hwcaps & VEX_HWCAPS_PPC64_ISA3_0)
807 == VEX_HWCAPS_PPC64_ISA3_0;
809 /* Verify the PPC_FEATURE2_ARCH_3_00 setting in HWCAP2
810 * matches the setting in VEX HWCAPS.
812 vg_assert(auxv_3_0 == hw_caps_3_0);
814 /* Power ISA version 3.1
815 https://ibm.ent.box.com/s/hhjfw0x0lrbtyzmiaffnbxh2fuo0fog0
817 64-bit ELF V? ABI specification for Power. HWCAP2 bit pattern
818 for ISA 3.0, page ?.
820 ADD PUBLIC LINK WHEN AVAILABLE
823 /* Check for SCV support, Can not test scv instruction to see
824 if the system supports scv. Issuing an scv intruction on a
825 system that does not have scv in the HWCAPS results in a
826 message in dmsg "Facility 'SCV' unavailable (12), exception".
827 Will have to just use the scv setting from HWCAPS2 to determine
828 if the host supports scv. */
829 auxv_scv_supported = (auxv->u.a_val & 0x00100000ULL)
830 == 0x00100000ULL;
832 VG_(machine_ppc64_set_scv_support)(auxv_scv_supported);
834 /* ISA 3.1 */
835 auxv_3_1 = (auxv->u.a_val & 0x00040000ULL) == 0x00040000ULL;
836 hw_caps_3_1 = (vex_archinfo->hwcaps & VEX_HWCAPS_PPC64_ISA3_1)
837 == VEX_HWCAPS_PPC64_ISA3_1;
839 /* Verify the PPC_FEATURE2_ARCH_3_1 setting in HWCAP2
840 * matches the setting in VEX HWCAPS.
842 vg_assert(auxv_3_1 == hw_caps_3_1);
844 /* Mask unrecognized HWCAP bits. Only keep the bits that have
845 * explicit support in VEX. Filter out HTM bits since the
846 * transaction begin instruction (tbegin) is always failed in
847 * Valgrind causing the code to execute the failure path.
848 * The DARN random number (bug #411189) and the SCV syscall
849 * (bug #431157) have been fixed. Can now include them in the
850 * HWCAP bits.
852 auxv->u.a_val &= (0x80000000ULL /* ARCH_2_07 */
853 | 0x20000000ULL /* DSCR */
854 | 0x10000000ULL /* EBB */
855 | 0x08000000ULL /* ISEL */
856 | 0x04000000ULL /* TAR */
857 | 0x04000000ULL /* VEC_CRYPTO */
858 | 0x00800000ULL /* ARCH_3_00 */
859 #if defined(VGP_ppc64le_linux)
860 /* Should also be supported on ppc64be,
861 but see https://bugs.kde.org/show_bug.cgi?id=469097 */
862 | 0x00100000ULL /* PPC_FEATURE2_SCV */
863 #endif
864 | 0x00400000ULL /* HAS_IEEE128 */
865 | 0x00200000ULL /* PPC_FEATURE2_DARN */
866 | 0x00040000ULL /* ARCH_3_1 */
867 | 0x00020000ULL); /* MMA instruction support */
870 break;
871 # endif
873 case AT_ICACHEBSIZE:
874 case AT_DCACHEBSIZE:
875 case AT_UCACHEBSIZE:
876 # if defined(VGP_ppc32_linux)
877 /* acquire cache info */
878 if (auxv->u.a_val > 0) {
879 VG_(machine_ppc32_set_clszB)( auxv->u.a_val );
880 VG_(debugLog)(2, "initimg",
881 "PPC32 icache line size %u (type %u)\n",
882 (UInt)auxv->u.a_val, (UInt)auxv->a_type );
884 # elif defined(VGP_ppc64be_linux) || defined(VGP_ppc64le_linux)
885 /* acquire cache info */
886 if (auxv->u.a_val > 0) {
887 VG_(machine_ppc64_set_clszB)( auxv->u.a_val );
888 VG_(debugLog)(2, "initimg",
889 "PPC64 icache line size %u (type %u)\n",
890 (UInt)auxv->u.a_val, (UInt)auxv->a_type );
892 # endif
893 break;
895 # if defined(VGP_ppc32_linux) || defined(VGP_ppc64be_linux) \
896 || defined(VGP_ppc64le_linux)
897 case AT_IGNOREPPC:
898 break;
899 # endif
901 case AT_SECURE:
902 /* If this is 1, then it means that this program is
903 running suid, and therefore the dynamic linker should
904 be careful about LD_PRELOAD, etc. However, since
905 stage1 (the thing the kernel actually execve's) should
906 never be SUID, and we need LD_PRELOAD to work for the
907 client, we set AT_SECURE to 0. */
908 auxv->u.a_val = 0;
909 break;
911 case AT_SYSINFO:
912 /* Trash this, because we don't reproduce it */
913 auxv->a_type = AT_IGNORE;
914 break;
916 # if !defined(VGP_ppc32_linux) && !defined(VGP_ppc64be_linux) \
917 && !defined(VGP_ppc64le_linux) \
918 && !defined(VGP_mips32_linux) && !defined(VGP_mips64_linux) \
919 && !defined(VGP_nanomips_linux) \
920 && !defined(VGP_s390x_linux)
921 case AT_SYSINFO_EHDR: {
922 /* Trash this, because we don't reproduce it */
923 const NSegment* ehdrseg = VG_(am_find_nsegment)((Addr)auxv->u.a_ptr);
924 vg_assert(ehdrseg);
925 VG_(am_munmap_valgrind)(ehdrseg->start, ehdrseg->end - ehdrseg->start);
926 auxv->a_type = AT_IGNORE;
927 break;
929 # endif
931 case AT_RANDOM:
932 /* points to 16 random bytes - we need to ensure this is
933 propagated to the client as glibc will assume it is
934 present if it is built for kernel 2.6.29 or later */
935 auxv->u.a_ptr = strtab;
936 VG_(memcpy)(strtab, orig_auxv->u.a_ptr, 16);
937 strtab += 16;
938 break;
940 case AT_EXECFN:
941 /* points to the executable filename */
942 auxv->u.a_ptr = copy_str(&strtab, VG_(args_the_exename));
943 break;
945 default:
946 /* stomp out anything we don't know about */
947 VG_(debugLog)(2, "initimg",
948 "stomping auxv entry %llu\n",
949 (ULong)auxv->a_type);
950 auxv->a_type = AT_IGNORE;
951 break;
954 *auxv = *orig_auxv;
955 vg_assert(auxv->a_type == AT_NULL);
957 vg_assert((strtab-stringbase) == stringsize);
959 /* client_SP is pointing at client's argc/argv */
961 if (0) VG_(printf)("startup SP = %#lx\n", client_SP);
962 return client_SP;
966 /* Allocate the client data segment. It is an expandable anonymous
967 mapping abutting a shrinkable reservation of size max_dseg_size.
968 The data segment starts at VG_(brk_base), which is page-aligned,
969 and runs up to VG_(brk_limit), which isn't. */
971 static void setup_client_dataseg ( SizeT max_size )
973 Bool ok;
974 SysRes sres;
975 Addr anon_start = VG_(brk_base);
976 SizeT anon_size = VKI_PAGE_SIZE;
977 Addr resvn_start = anon_start + anon_size;
978 SizeT resvn_size = max_size - anon_size;
980 vg_assert(VG_IS_PAGE_ALIGNED(anon_size));
981 vg_assert(VG_IS_PAGE_ALIGNED(resvn_size));
982 vg_assert(VG_IS_PAGE_ALIGNED(anon_start));
983 vg_assert(VG_IS_PAGE_ALIGNED(resvn_start));
985 /* Because there's been no brk activity yet: */
986 vg_assert(VG_(brk_base) == VG_(brk_limit));
988 /* Try to create the data seg and associated reservation where
989 VG_(brk_base) says. */
990 ok = VG_(am_create_reservation)(
991 resvn_start,
992 resvn_size,
993 SmLower,
994 anon_size
997 if (!ok) {
998 /* Hmm, that didn't work. Well, let aspacem suggest an address
999 it likes better, and try again with that. */
1000 anon_start = VG_(am_get_advisory_client_simple)
1001 ( 0/*floating*/, anon_size+resvn_size, &ok );
1002 if (ok) {
1003 resvn_start = anon_start + anon_size;
1004 ok = VG_(am_create_reservation)(
1005 resvn_start,
1006 resvn_size,
1007 SmLower,
1008 anon_size
1010 if (ok)
1011 VG_(brk_base) = VG_(brk_limit) = anon_start;
1013 /* that too might have failed, but if it has, we're hosed: there
1014 is no Plan C. */
1016 vg_assert(ok);
1018 /* We make the data segment (heap) executable because LinuxThreads on
1019 ppc32 creates trampolines in this area. Also, on x86/Linux the data
1020 segment is RWX natively, at least according to /proc/self/maps.
1021 Also, having a non-executable data seg would kill any program which
1022 tried to create code in the data seg and then run it. */
1023 sres = VG_(am_mmap_anon_fixed_client)(
1024 anon_start,
1025 anon_size,
1026 VKI_PROT_READ|VKI_PROT_WRITE|VKI_PROT_EXEC
1028 vg_assert(!sr_isError(sres));
1029 vg_assert(sr_Res(sres) == anon_start);
1033 * In glibc 2.34 we need to use the TUNABLE mechanism to
1034 * disable stack cache when --sim-hints=no-nptl-pthread-stackcache
1035 * is specified. This needs to be done in the same manner
1036 * as LD_PRELOAD.
1038 * See https://bugs.kde.org/show_bug.cgi?id=444488
1040 static Bool need_stack_cache_tunable(HChar** argv)
1042 while (argv && *argv) {
1043 if (VG_(strncmp)(*argv, "--sim-hints=", VG_(strlen)("--sim-hints=")) == 0) {
1044 if (VG_(strstr)(*argv, "no-nptl-pthread-stackcache")) {
1045 return True;
1048 ++argv;
1050 return False;
1053 /*====================================================================*/
1054 /*=== TOP-LEVEL: VG_(setup_client_initial_image) ===*/
1055 /*====================================================================*/
1057 /* Create the client's initial memory image. */
1058 IIFinaliseImageInfo VG_(ii_create_image)( IICreateImageInfo iicii,
1059 const VexArchInfo* vex_archinfo )
1061 ExeInfo info;
1062 HChar** env = NULL;
1064 IIFinaliseImageInfo iifii = {
1065 .clstack_max_size = 0,
1066 .initial_client_SP = 0,
1067 .initial_client_IP = 0,
1068 .initial_client_TOC = 0,
1069 .client_auxv = NULL,
1070 .arch_elf_state = VKI_INIT_ARCH_ELF_STATE,
1073 //--------------------------------------------------------------
1074 // Load client executable, finding in $PATH if necessary
1075 // p: get_helprequest_and_toolname() [for 'exec', 'need_help']
1076 // p: layout_remaining_space [so there's space]
1077 //--------------------------------------------------------------
1078 VG_(debugLog)(1, "initimg", "Loading client\n");
1080 if (VG_(args_the_exename) == NULL)
1081 VG_(err_missing_prog)();
1083 VG_(memset)(&info, 0, sizeof(info));
1084 info.arch_elf_state = &iifii.arch_elf_state;
1086 load_client(&info, &iifii.initial_client_IP, &iifii.initial_client_TOC);
1088 //--------------------------------------------------------------
1089 // Set up client's environment
1090 // p: set-libdir [for VG_(libdir)]
1091 // p: get_helprequest_and_toolname [for toolname]
1092 //--------------------------------------------------------------
1093 VG_(debugLog)(1, "initimg", "Setup client env\n");
1094 env = setup_client_env(iicii.envp, iicii.toolname, need_stack_cache_tunable(iicii.argv));
1096 //--------------------------------------------------------------
1097 // Setup client stack, eip, and VG_(client_arg[cv])
1098 // p: load_client() [for 'info']
1099 // p: fix_environment() [for 'env']
1100 //--------------------------------------------------------------
1102 /* When allocating space for the client stack on Linux, take
1103 notice of the --main-stacksize value. This makes it possible
1104 to run programs with very large (primary) stack requirements
1105 simply by specifying --main-stacksize. */
1106 /* Logic is as follows:
1107 - by default, use the client's current stack rlimit
1108 - if that exceeds 16M, clamp to 16M
1109 - if a larger --main-stacksize value is specified, use that instead
1110 - in all situations, the minimum allowed stack size is 1M
1112 void* init_sp = iicii.argv - 1;
1113 SizeT m1 = 1024 * 1024;
1114 SizeT m16 = 16 * m1;
1115 SizeT szB = (SizeT)VG_(client_rlimit_stack).rlim_cur;
1116 if (szB < m1) szB = m1;
1117 if (szB > m16) szB = m16;
1118 if (VG_(clo_main_stacksize) > 0) szB = VG_(clo_main_stacksize);
1119 if (szB < m1) szB = m1;
1120 szB = VG_PGROUNDUP(szB);
1121 VG_(debugLog)(1, "initimg",
1122 "Setup client stack: size will be %lu\n", szB);
1124 iifii.clstack_max_size = szB;
1126 iifii.initial_client_SP
1127 = setup_client_stack( init_sp, env,
1128 &info, &iifii.client_auxv,
1129 iicii.clstack_end, iifii.clstack_max_size,
1130 vex_archinfo );
1132 VG_(free)(env);
1134 VG_(debugLog)(2, "initimg",
1135 "Client info: "
1136 "initial_IP=%p initial_TOC=%p brk_base=%p\n",
1137 (void*)(iifii.initial_client_IP),
1138 (void*)(iifii.initial_client_TOC),
1139 (void*)VG_(brk_base) );
1140 VG_(debugLog)(2, "initimg",
1141 "Client info: "
1142 "initial_SP=%p max_stack_size=%lu\n",
1143 (void*)(iifii.initial_client_SP),
1144 iifii.clstack_max_size );
1147 //--------------------------------------------------------------
1148 // Setup client data (brk) segment. Initially a 1-page segment
1149 // which abuts a shrinkable reservation.
1150 // p: load_client() [for 'info' and hence VG_(brk_base)]
1151 //--------------------------------------------------------------
1153 SizeT m1 = 1024 * 1024;
1154 SizeT m8 = 8 * m1;
1155 SizeT dseg_max_size = (SizeT)VG_(client_rlimit_data).rlim_cur;
1156 VG_(debugLog)(1, "initimg", "Setup client data (brk) segment\n");
1157 if (dseg_max_size < m1) dseg_max_size = m1;
1158 if (dseg_max_size > m8) dseg_max_size = m8;
1159 dseg_max_size = VG_PGROUNDUP(dseg_max_size);
1161 setup_client_dataseg( dseg_max_size );
1164 VG_(free)(info.interp_name); info.interp_name = NULL;
1165 VG_(free)(info.interp_args); info.interp_args = NULL;
1166 return iifii;
1170 /*====================================================================*/
1171 /*=== TOP-LEVEL: VG_(finalise_thread1state) ===*/
1172 /*====================================================================*/
1174 /* Just before starting the client, we may need to make final
1175 adjustments to its initial image. Also we need to set up the VEX
1176 guest state for thread 1 (the root thread) and copy in essential
1177 starting values. This is handed the IIFinaliseImageInfo created by
1178 VG_(ii_create_image).
1180 void VG_(ii_finalise_image)( IIFinaliseImageInfo iifii )
1182 ThreadArchState* arch = &VG_(threads)[1].arch;
1184 /* On Linux we get client_{ip/sp/toc}, and start the client with
1185 all other registers zeroed. */
1187 # if defined(VGP_x86_linux)
1188 vg_assert(0 == sizeof(VexGuestX86State) % LibVEX_GUEST_STATE_ALIGN);
1190 /* Zero out the initial state, and set up the simulated FPU in a
1191 sane way. */
1192 LibVEX_GuestX86_initialise(&arch->vex);
1194 /* Zero out the shadow areas. */
1195 VG_(memset)(&arch->vex_shadow1, 0, sizeof(VexGuestX86State));
1196 VG_(memset)(&arch->vex_shadow2, 0, sizeof(VexGuestX86State));
1198 /* Put essential stuff into the new state. */
1199 arch->vex.guest_ESP = iifii.initial_client_SP;
1200 arch->vex.guest_EIP = iifii.initial_client_IP;
1202 /* initialise %cs, %ds and %ss to point at the operating systems
1203 default code, data and stack segments. Also %es (see #291253). */
1204 asm volatile("movw %%cs, %0" : : "m" (arch->vex.guest_CS));
1205 asm volatile("movw %%ds, %0" : : "m" (arch->vex.guest_DS));
1206 asm volatile("movw %%ss, %0" : : "m" (arch->vex.guest_SS));
1207 asm volatile("movw %%es, %0" : : "m" (arch->vex.guest_ES));
1209 # elif defined(VGP_amd64_linux)
1210 vg_assert(0 == sizeof(VexGuestAMD64State) % LibVEX_GUEST_STATE_ALIGN);
1212 /* Zero out the initial state, and set up the simulated FPU in a
1213 sane way. */
1214 LibVEX_GuestAMD64_initialise(&arch->vex);
1216 /* Zero out the shadow areas. */
1217 VG_(memset)(&arch->vex_shadow1, 0, sizeof(VexGuestAMD64State));
1218 VG_(memset)(&arch->vex_shadow2, 0, sizeof(VexGuestAMD64State));
1220 /* Put essential stuff into the new state. */
1221 arch->vex.guest_RSP = iifii.initial_client_SP;
1222 arch->vex.guest_RIP = iifii.initial_client_IP;
1224 # elif defined(VGP_ppc32_linux)
1225 vg_assert(0 == sizeof(VexGuestPPC32State) % LibVEX_GUEST_STATE_ALIGN);
1227 /* Zero out the initial state, and set up the simulated FPU in a
1228 sane way. */
1229 LibVEX_GuestPPC32_initialise(&arch->vex);
1231 /* Zero out the shadow areas. */
1232 VG_(memset)(&arch->vex_shadow1, 0, sizeof(VexGuestPPC32State));
1233 VG_(memset)(&arch->vex_shadow2, 0, sizeof(VexGuestPPC32State));
1235 /* Put essential stuff into the new state. */
1236 arch->vex.guest_GPR1 = iifii.initial_client_SP;
1237 arch->vex.guest_CIA = iifii.initial_client_IP;
1239 # elif defined(VGP_ppc64be_linux) || defined(VGP_ppc64le_linux)
1240 vg_assert(0 == sizeof(VexGuestPPC64State) % LibVEX_GUEST_STATE_ALIGN);
1242 /* Zero out the initial state, and set up the simulated FPU in a
1243 sane way. */
1244 LibVEX_GuestPPC64_initialise(&arch->vex);
1246 /* Zero out the shadow areas. */
1247 VG_(memset)(&arch->vex_shadow1, 0, sizeof(VexGuestPPC64State));
1248 VG_(memset)(&arch->vex_shadow2, 0, sizeof(VexGuestPPC64State));
1250 /* Put essential stuff into the new state. */
1251 arch->vex.guest_GPR1 = iifii.initial_client_SP;
1252 arch->vex.guest_GPR2 = iifii.initial_client_TOC;
1253 arch->vex.guest_CIA = iifii.initial_client_IP;
1254 #if defined(VGP_ppc64le_linux)
1255 arch->vex.guest_GPR12 = iifii.initial_client_IP;
1256 #endif
1258 # elif defined(VGP_arm_linux)
1259 /* Zero out the initial state, and set up the simulated FPU in a
1260 sane way. */
1261 LibVEX_GuestARM_initialise(&arch->vex);
1263 /* Zero out the shadow areas. */
1264 VG_(memset)(&arch->vex_shadow1, 0, sizeof(VexGuestARMState));
1265 VG_(memset)(&arch->vex_shadow2, 0, sizeof(VexGuestARMState));
1267 arch->vex.guest_R13 = iifii.initial_client_SP;
1268 arch->vex.guest_R15T = iifii.initial_client_IP;
1270 /* This is just EABI stuff. */
1271 // FIXME jrs: what's this for?
1272 arch->vex.guest_R1 = iifii.initial_client_SP;
1274 # elif defined(VGP_arm64_linux)
1275 /* Zero out the initial state. */
1276 LibVEX_GuestARM64_initialise(&arch->vex);
1278 /* Zero out the shadow areas. */
1279 VG_(memset)(&arch->vex_shadow1, 0, sizeof(VexGuestARM64State));
1280 VG_(memset)(&arch->vex_shadow2, 0, sizeof(VexGuestARM64State));
1282 arch->vex.guest_XSP = iifii.initial_client_SP;
1283 arch->vex.guest_PC = iifii.initial_client_IP;
1285 # elif defined(VGP_s390x_linux)
1286 vg_assert(0 == sizeof(VexGuestS390XState) % LibVEX_GUEST_STATE_ALIGN);
1288 /* Zero out the initial state. This also sets the guest_fpc to 0, which
1289 is also done by the kernel for the fpc during execve. */
1290 LibVEX_GuestS390X_initialise(&arch->vex);
1292 /* Mark all registers as undefined ... */
1293 VG_(memset)(&arch->vex_shadow1, 0xFF, sizeof(VexGuestS390XState));
1294 VG_(memset)(&arch->vex_shadow2, 0x00, sizeof(VexGuestS390XState));
1295 /* ... except SP, FPC, and IA */
1296 arch->vex_shadow1.guest_SP = 0;
1297 arch->vex_shadow1.guest_fpc = 0;
1298 arch->vex_shadow1.guest_IA = 0;
1300 /* Put essential stuff into the new state. */
1301 arch->vex.guest_SP = iifii.initial_client_SP;
1302 arch->vex.guest_IA = iifii.initial_client_IP;
1303 /* See sys_execve in <linux>/arch/s390/kernel/process.c */
1304 arch->vex.guest_fpc = 0;
1306 /* Tell the tool about the registers we just wrote */
1307 VG_TRACK(post_reg_write, Vg_CoreStartup, /*tid*/1, VG_O_STACK_PTR, 8);
1308 VG_TRACK(post_reg_write, Vg_CoreStartup, /*tid*/1, VG_O_FPC_REG, 4);
1309 VG_TRACK(post_reg_write, Vg_CoreStartup, /*tid*/1, VG_O_INSTR_PTR, 8);
1311 /* At the end of this function there is code to mark all guest state
1312 registers as defined. For s390 that would be wrong, because the ABI
1313 says that all registers except SP, IA, and FPC are undefined upon
1314 process startup. */
1315 #define PRECISE_GUEST_REG_DEFINEDNESS_AT_STARTUP 1
1317 # elif defined(VGP_mips32_linux) || defined(VGP_nanomips_linux)
1318 vg_assert(0 == sizeof(VexGuestMIPS32State) % LibVEX_GUEST_STATE_ALIGN);
1319 /* Zero out the initial state, and set up the simulated FPU in a
1320 sane way. */
1321 LibVEX_GuestMIPS32_initialise(&arch->vex);
1323 /* Zero out the shadow areas. */
1324 VG_(memset)(&arch->vex_shadow1, 0, sizeof(VexGuestMIPS32State));
1325 VG_(memset)(&arch->vex_shadow2, 0, sizeof(VexGuestMIPS32State));
1327 arch->vex.guest_r29 = iifii.initial_client_SP;
1328 arch->vex.guest_PC = iifii.initial_client_IP;
1329 arch->vex.guest_r31 = iifii.initial_client_SP;
1331 # if !defined(VGP_nanomips_linux)
1332 if (iifii.arch_elf_state.overall_fp_mode == VKI_FP_FR1) {
1333 arch->vex.guest_CP0_status |= MIPS_CP0_STATUS_FR;
1336 # endif
1337 # elif defined(VGP_mips64_linux)
1338 vg_assert(0 == sizeof(VexGuestMIPS64State) % LibVEX_GUEST_STATE_ALIGN);
1339 /* Zero out the initial state, and set up the simulated FPU in a
1340 sane way. */
1341 LibVEX_GuestMIPS64_initialise(&arch->vex);
1343 /* Zero out the shadow areas. */
1344 VG_(memset)(&arch->vex_shadow1, 0, sizeof(VexGuestMIPS64State));
1345 VG_(memset)(&arch->vex_shadow2, 0, sizeof(VexGuestMIPS64State));
1347 arch->vex.guest_r29 = iifii.initial_client_SP;
1348 arch->vex.guest_PC = iifii.initial_client_IP;
1349 arch->vex.guest_r31 = iifii.initial_client_SP;
1351 # else
1352 # error Unknown platform
1353 # endif
1355 # if !defined(PRECISE_GUEST_REG_DEFINEDNESS_AT_STARTUP)
1356 /* Tell the tool that we just wrote to the registers. */
1357 VG_TRACK( post_reg_write, Vg_CoreStartup, /*tid*/1, /*offset*/0,
1358 sizeof(VexGuestArchState));
1359 # endif
1361 /* Tell the tool about the client data segment and then kill it which will
1362 make it inaccessible/unaddressable. */
1363 const NSegment *seg = VG_(am_find_nsegment)(VG_(brk_base));
1364 vg_assert(seg);
1365 vg_assert(seg->kind == SkAnonC);
1366 VG_TRACK(new_mem_brk, VG_(brk_base), seg->end + 1 - VG_(brk_base),
1367 1/*tid*/);
1368 VG_TRACK(die_mem_brk, VG_(brk_base), seg->end + 1 - VG_(brk_base));
1371 #endif // defined(VGO_linux)
1373 /*--------------------------------------------------------------------*/
1374 /*--- ---*/
1375 /*--------------------------------------------------------------------*/