Home | History | Annotate | Download | only in asan_tests
      1 ; Test that loads of local pointers to allocation functions and stores
      2 ; of pointers to allocation functions are instrumented.
      3 
      4 ; REQUIRES: allow_dump
      5 
      6 ; RUN: %p2i -i %s --args -verbose=inst -threads=0 -fsanitize-address \
      7 ; RUN:     -allow-externally-defined-symbols | FileCheck --check-prefix=DUMP %s
      8 
      9 declare external i32 @malloc(i32)
     10 declare external i32 @realloc(i32, i32)
     11 declare external i32 @calloc(i32, i32)
     12 declare external void @free(i32)
     13 
     14 define internal void @func(i32 %store_loc) {
     15   %store_dest = inttoptr i32 %store_loc to i32*
     16 
     17   %malloc_ptr = bitcast i32 (i32)* @malloc to i32*
     18   %realloc_ptr = bitcast i32 (i32, i32)* @realloc to i32*
     19   %calloc_ptr = bitcast i32 (i32, i32)* @calloc to i32*
     20   %free_ptr = bitcast void (i32)* @free to i32*
     21 
     22   %malloc_addr = ptrtoint i32 (i32)* @malloc to i32
     23   %realloc_addr = ptrtoint i32 (i32, i32)* @realloc to i32
     24   %calloc_addr = ptrtoint i32 (i32, i32)* @calloc to i32
     25   %free_addr = ptrtoint void (i32)* @free to i32
     26 
     27   store i32 %malloc_addr, i32* %store_dest, align 1
     28   store i32 %realloc_addr, i32* %store_dest, align 1
     29   store i32 %calloc_addr, i32* %store_dest, align 1
     30   store i32 %free_addr, i32* %store_dest, align 1
     31 
     32   %local_malloc = load i32, i32* %malloc_ptr, align 1
     33   %local_realloc = load i32, i32* %realloc_ptr, align 1
     34   %local_calloc = load i32, i32* %calloc_ptr, align 1
     35   %local_free = load i32, i32* %free_ptr, align 1
     36 
     37   %local_mallocfunc = inttoptr i32 %local_malloc to i32 (i32)*
     38   %local_reallocfunc = inttoptr i32 %local_realloc to i32 (i32, i32)*
     39   %local_callocfunc = inttoptr i32 %local_calloc to i32 (i32, i32)*
     40   %local_freefunc = inttoptr i32 %local_free to void (i32)*
     41 
     42   %buf = call i32 %local_mallocfunc(i32 42)
     43   call void %local_freefunc(i32 %buf)
     44   ret void
     45 }
     46 
     47 ; DUMP-LABEL: ================ Instrumented CFG ================
     48 ; DUMP-NEXT: @func(i32 %store_loc) {
     49 ; DUMP-NEXT: __0:
     50 ; DUMP-NEXT:   call void @__asan_check_store(i32 %store_loc, i32 4)
     51 ; DUMP-NEXT:   store i32 @__asan_malloc, i32* %store_loc, align 1
     52 ; DUMP-NEXT:   store i32 @__asan_realloc, i32* %store_loc, align 1
     53 ; DUMP-NEXT:   store i32 @__asan_calloc, i32* %store_loc, align 1
     54 ; DUMP-NEXT:   store i32 @__asan_free, i32* %store_loc, align 1
     55 ; DUMP-NEXT:   call void @__asan_check_load(i32 @__asan_malloc, i32 4)
     56 ; DUMP-NEXT:   %local_malloc = load i32, i32* @__asan_malloc, align 1
     57 ; DUMP-NEXT:   call void @__asan_check_load(i32 @__asan_realloc, i32 4)
     58 ; DUMP-NEXT:   %local_realloc = load i32, i32* @__asan_realloc, align 1
     59 ; DUMP-NEXT:   call void @__asan_check_load(i32 @__asan_calloc, i32 4)
     60 ; DUMP-NEXT:   %local_calloc = load i32, i32* @__asan_calloc, align 1
     61 ; DUMP-NEXT:   call void @__asan_check_load(i32 @__asan_free, i32 4)
     62 ; DUMP-NEXT:   %local_free = load i32, i32* @__asan_free, align 1
     63 ; DUMP-NEXT:   %buf = call i32 %local_malloc(i32 42)
     64 ; DUMP-NEXT:   call void %local_free(i32 %buf)
     65 ; DUMP-NEXT:   ret void
     66 ; DUMP-NEXT: }
     67