File: scalar_supp.c

package info (click to toggle)
valgrind 1%3A3.2.1-1
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k
  • size: 27,372 kB
  • ctags: 23,091
  • sloc: ansic: 192,648; xml: 10,723; sh: 4,750; perl: 4,023; makefile: 2,103; asm: 1,813; cpp: 140; haskell: 139
file content (22 lines) | stat: -rw-r--r-- 541 bytes parent folder | download | duplicates (13)
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;
}