origin-alignment.ll 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. ; RUN: opt < %s -msan -msan-check-access-address=0 -msan-track-origins=1 -S | FileCheck -check-prefix=CHECK -check-prefix=CHECK-ORIGINS1 %s
  2. ; RUN: opt < %s -msan -msan-check-access-address=0 -msan-track-origins=2 -S | FileCheck -check-prefix=CHECK -check-prefix=CHECK-ORIGINS2 %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. ; Check origin instrumentation of stores.
  6. ; Check that debug info for origin propagation code is set correctly.
  7. @a8 = global i8 0, align 8
  8. @a4 = global i8 0, align 4
  9. @a2 = global i8 0, align 2
  10. @a1 = global i8 0, align 1
  11. ; 8-aligned store => 8-aligned origin store, origin address is not realigned
  12. define void @Store8(i8 %x) sanitize_memory {
  13. entry:
  14. store i8 %x, i8* @a8, align 8
  15. ret void
  16. }
  17. ; CHECK-LABEL: @Store8
  18. ; CHECK-ORIGINS1: [[ORIGIN:%[01-9a-z]+]] = load {{.*}} @__msan_param_origin_tls
  19. ; CHECK-ORIGINS2: [[ORIGIN0:%[01-9a-z]+]] = load {{.*}} @__msan_param_origin_tls
  20. ; CHECK-ORIGINS2: [[ORIGIN:%[01-9a-z]+]] = call i32 @__msan_chain_origin(i32 [[ORIGIN0]])
  21. ; CHECK: store i32 [[ORIGIN]], i32* inttoptr (i64 add (i64 and (i64 ptrtoint {{.*}} to i32*), align 8
  22. ; CHECK: ret void
  23. ; 4-aligned store => 4-aligned origin store, origin address is not realigned
  24. define void @Store4(i8 %x) sanitize_memory {
  25. entry:
  26. store i8 %x, i8* @a4, align 4
  27. ret void
  28. }
  29. ; CHECK-LABEL: @Store4
  30. ; CHECK-ORIGINS1: [[ORIGIN:%[01-9a-z]+]] = load {{.*}} @__msan_param_origin_tls
  31. ; CHECK-ORIGINS2: [[ORIGIN0:%[01-9a-z]+]] = load {{.*}} @__msan_param_origin_tls
  32. ; CHECK-ORIGINS2: [[ORIGIN:%[01-9a-z]+]] = call i32 @__msan_chain_origin(i32 [[ORIGIN0]])
  33. ; CHECK: store i32 [[ORIGIN]], i32* inttoptr (i64 add (i64 and (i64 ptrtoint {{.*}} to i32*), align 4
  34. ; CHECK: ret void
  35. ; 2-aligned store => 4-aligned origin store, origin address is realigned
  36. define void @Store2(i8 %x) sanitize_memory {
  37. entry:
  38. store i8 %x, i8* @a2, align 2
  39. ret void
  40. }
  41. ; CHECK-LABEL: @Store2
  42. ; CHECK-ORIGINS1: [[ORIGIN:%[01-9a-z]+]] = load {{.*}} @__msan_param_origin_tls
  43. ; CHECK-ORIGINS2: [[ORIGIN0:%[01-9a-z]+]] = load {{.*}} @__msan_param_origin_tls
  44. ; CHECK-ORIGINS2: [[ORIGIN:%[01-9a-z]+]] = call i32 @__msan_chain_origin(i32 [[ORIGIN0]])
  45. ; CHECK: store i32 [[ORIGIN]], i32* inttoptr (i64 and (i64 add (i64 and (i64 ptrtoint {{.*}} i64 -4) to i32*), align 4
  46. ; CHECK: ret void
  47. ; 1-aligned store => 4-aligned origin store, origin address is realigned
  48. define void @Store1(i8 %x) sanitize_memory {
  49. entry:
  50. store i8 %x, i8* @a1, align 1
  51. ret void
  52. }
  53. ; CHECK-LABEL: @Store1
  54. ; CHECK-ORIGINS1: [[ORIGIN:%[01-9a-z]+]] = load {{.*}} @__msan_param_origin_tls
  55. ; CHECK-ORIGINS2: [[ORIGIN0:%[01-9a-z]+]] = load {{.*}} @__msan_param_origin_tls
  56. ; CHECK-ORIGINS2: [[ORIGIN:%[01-9a-z]+]] = call i32 @__msan_chain_origin(i32 [[ORIGIN0]])
  57. ; CHECK: store i32 [[ORIGIN]], i32* inttoptr (i64 and (i64 add (i64 and (i64 ptrtoint {{.*}} i64 -4) to i32*), align 4
  58. ; CHECK: ret void