stack_dynamic_alloca.ll 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. ; RUN: opt < %s -asan -asan-module -asan-stack-dynamic-alloca \
  2. ; RUN: -asan-use-after-return -S | FileCheck %s
  3. target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"
  4. target triple = "x86_64-unknown-linux-gnu"
  5. define void @Func1() sanitize_address {
  6. entry:
  7. ; CHECK-LABEL: Func1
  8. ; CHECK: entry:
  9. ; CHECK: load i32, i32* @__asan_option_detect_stack_use_after_return
  10. ; CHECK: <label>:[[UAR_ENABLED_BB:[0-9]+]]
  11. ; CHECK: [[FAKE_STACK_RT:%[0-9]+]] = call i64 @__asan_stack_malloc_
  12. ; CHECK: <label>:[[FAKE_STACK_BB:[0-9]+]]
  13. ; CHECK: [[FAKE_STACK:%[0-9]+]] = phi i64 [ 0, %entry ], [ [[FAKE_STACK_RT]], %[[UAR_ENABLED_BB]] ]
  14. ; CHECK: icmp eq i64 [[FAKE_STACK]], 0
  15. ; CHECK: <label>:[[NO_FAKE_STACK_BB:[0-9]+]]
  16. ; CHECK: %MyAlloca = alloca i8, i64
  17. ; CHECK: [[ALLOCA:%[0-9]+]] = ptrtoint i8* %MyAlloca
  18. ; CHECK: phi i64 [ [[FAKE_STACK]], %[[FAKE_STACK_BB]] ], [ [[ALLOCA]], %[[NO_FAKE_STACK_BB]] ]
  19. ; CHECK: ret void
  20. %XXX = alloca [20 x i8], align 1
  21. %arr.ptr = bitcast [20 x i8]* %XXX to i8*
  22. store volatile i8 0, i8* %arr.ptr
  23. ret void
  24. }
  25. ; Test that dynamic alloca is not used for functions with inline assembly.
  26. define void @Func2() sanitize_address {
  27. entry:
  28. ; CHECK-LABEL: Func2
  29. ; CHECK: alloca [96 x i8]
  30. ; CHECK: ret void
  31. %XXX = alloca [20 x i8], align 1
  32. %arr.ptr = bitcast [20 x i8]* %XXX to i8*
  33. store volatile i8 0, i8* %arr.ptr
  34. call void asm sideeffect "mov %%rbx, %%rcx", "~{dirflag},~{fpsr},~{flags}"() nounwind
  35. ret void
  36. }