File: scalar_supp.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 (22 lines) | stat: -rw-r--r-- 541 bytes parent folder | download | duplicates (14)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <stdlib.h>
#include <unistd.h>
#include <sys/syscall.h>

int main(void)
{
   // uninitialised, but we know pi[0] is 0x0
   int* pi  = malloc(sizeof(int));

   // uninitialised, but we know pc[0] points to 0x0
   char** pc  = malloc(sizeof(char*));
   
   // Five errors:  
   // - the syscall number itself is undefined (but we know it's
   //   0 + __NR_write :)
   // - each of the scalar args are undefined
   // - the 2nd arg points to unaddressable memory.
   syscall(pi[0]+__NR_write, pi[0], pc[0], pi[0]+1);

   return 0;
}