File: scalar_spawn.c

package info (click to toggle)
valgrind 1%3A3.24.0-3
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 176,332 kB
  • sloc: ansic: 795,029; exp: 26,134; xml: 23,472; asm: 14,393; cpp: 9,397; makefile: 7,464; sh: 6,122; perl: 5,446; python: 1,498; javascript: 981; awk: 166; csh: 1
file content (72 lines) | stat: -rw-r--r-- 1,683 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
/* Scalar test for new spawn syscall available on Solaris 11. */

#include "scalar.h"

#include <sys/spawn_impl.h>

__attribute__((noinline))
static void sys_spawn(void)
{
   GO(SYS_spawn, "5s 7m");
   SY(SYS_spawn, x0 + 1, x0 + 1, x0 - 1, x0 + 1, x0 - 1); FAIL;
}

__attribute__((noinline))
static void sys_spawn2(void)
{
   kspawn_attr_t ksa;
   ksa.ksa_version = x0 + SPAWN_VERSION;
   ksa.ksa_size = x0 + sizeof(ksa);
   ksa.ksa_attr_off = x0 + 0;
   ksa.ksa_path_off = x0 + 0;
   ksa.ksa_shell_off = x0 + 0;
   char *argenv = "";

   GO(SYS_spawn, "9s 1m");
   SY(SYS_spawn, x0 + 1, x0 + &ksa, sizeof(ksa), x0 + argenv, x0 + 1); FAIL;
}

__attribute__((noinline))
static void sys_spawn3(void)
{
   kspawn_attr_t ksa;
   ksa.ksa_version = x0 + SPAWN_VERSION;
   ksa.ksa_size = x0 + 0xbadcaffe;
   ksa.ksa_attr_off = x0 + 0xbadcaffe;
   ksa.ksa_attr_size = x0 + 1;
   ksa.ksa_path_off = x0 + 0xdeadcaffe;
   ksa.ksa_path_size = x0 + 2;
   ksa.ksa_shell_off = x0 + 0xdeadcaffe;
   ksa.ksa_shell_size = x0 + 3;
   char *argenv = "\1arg1\0\1arg2\0\1arg3\0\0\1env1\0\1env2\0\0";

   GO(SYS_spawn, "13s 4m");
   SY(SYS_spawn, x0 + 1, x0 + &ksa, x0 + 0xbadcaffe,
      x0 + argenv, x0 + sizeof(argenv)); FAIL;
}

__attribute__((noinline))
static void sys_spawn4(void)
{
   char path[] = "/bin/sh";
   char *argenv = "\2arg1\0\0";

   GO(SYS_spawn, "4s 0m");
   SY(SYS_spawn, path, x0, x0, x0 + argenv, x0 + sizeof(argenv));
   FAILx(EINVAL);
}

int main(void)
{
   /* Uninitialised, but we know px[0] is 0x0. */
   long *px = malloc(sizeof(long));
   x0 = px[0];

   /* SYS_spawn                   2 */
   sys_spawn();
   sys_spawn2();
   sys_spawn3();
   sys_spawn4();

   return 0;
}