Tim Northover | 5cc3dc8 | 2012-12-07 16:50:23 +0000 | [diff] [blame] | 1 | ;; RUN: llc -O0 -mtriple=armv7-linux-gnueabi -filetype=obj %s -o - | \ |
Nico Rieck | ba848e3 | 2013-04-12 04:06:46 +0000 | [diff] [blame^] | 2 | ;; RUN: llvm-readobj -t | FileCheck -check-prefix=ARM %s |
Tim Northover | 5cc3dc8 | 2012-12-07 16:50:23 +0000 | [diff] [blame] | 3 | |
| 4 | ;; RUN: llc -O0 -mtriple=thumbv7-linux-gnueabi -filetype=obj %s -o - | \ |
Nico Rieck | ba848e3 | 2013-04-12 04:06:46 +0000 | [diff] [blame^] | 5 | ;; RUN: llvm-readobj -t | FileCheck -check-prefix=TMB %s |
Tim Northover | 5cc3dc8 | 2012-12-07 16:50:23 +0000 | [diff] [blame] | 6 | |
| 7 | ;; Ensure that if a jump table is generated that it has Mapping Symbols |
| 8 | ;; marking the data-in-code region. |
| 9 | |
| 10 | define void @foo(i32* %ptr) nounwind ssp { |
| 11 | %tmp = load i32* %ptr, align 4 |
| 12 | switch i32 %tmp, label %default [ |
| 13 | i32 11, label %bb0 |
| 14 | i32 10, label %bb1 |
| 15 | i32 8, label %bb2 |
| 16 | i32 4, label %bb3 |
| 17 | i32 2, label %bb4 |
| 18 | i32 6, label %bb5 |
| 19 | i32 9, label %bb6 |
| 20 | i32 15, label %bb7 |
| 21 | i32 1, label %bb8 |
| 22 | i32 3, label %bb9 |
| 23 | i32 5, label %bb10 |
| 24 | i32 30, label %bb11 |
| 25 | i32 31, label %bb12 |
| 26 | i32 13, label %bb13 |
| 27 | i32 14, label %bb14 |
| 28 | i32 20, label %bb15 |
| 29 | i32 19, label %bb16 |
| 30 | i32 17, label %bb17 |
| 31 | i32 18, label %bb18 |
| 32 | i32 21, label %bb19 |
| 33 | i32 22, label %bb20 |
| 34 | i32 16, label %bb21 |
| 35 | i32 24, label %bb22 |
| 36 | i32 25, label %bb23 |
| 37 | i32 26, label %bb24 |
| 38 | i32 27, label %bb25 |
| 39 | i32 28, label %bb26 |
| 40 | i32 23, label %bb27 |
| 41 | i32 12, label %bb28 |
| 42 | ] |
| 43 | |
| 44 | default: |
| 45 | br label %exit |
| 46 | bb0: |
| 47 | br label %exit |
| 48 | bb1: |
| 49 | br label %exit |
| 50 | bb2: |
| 51 | br label %exit |
| 52 | bb3: |
| 53 | br label %exit |
| 54 | bb4: |
| 55 | br label %exit |
| 56 | bb5: |
| 57 | br label %exit |
| 58 | bb6: |
| 59 | br label %exit |
| 60 | bb7: |
| 61 | br label %exit |
| 62 | bb8: |
| 63 | br label %exit |
| 64 | bb9: |
| 65 | br label %exit |
| 66 | bb10: |
| 67 | br label %exit |
| 68 | bb11: |
| 69 | br label %exit |
| 70 | bb12: |
| 71 | br label %exit |
| 72 | bb13: |
| 73 | br label %exit |
| 74 | bb14: |
| 75 | br label %exit |
| 76 | bb15: |
| 77 | br label %exit |
| 78 | bb16: |
| 79 | br label %exit |
| 80 | bb17: |
| 81 | br label %exit |
| 82 | bb18: |
| 83 | br label %exit |
| 84 | bb19: |
| 85 | br label %exit |
| 86 | bb20: |
| 87 | br label %exit |
| 88 | bb21: |
| 89 | br label %exit |
| 90 | bb22: |
| 91 | br label %exit |
| 92 | bb23: |
| 93 | br label %exit |
| 94 | bb24: |
| 95 | br label %exit |
| 96 | bb25: |
| 97 | br label %exit |
| 98 | bb26: |
| 99 | br label %exit |
| 100 | bb27: |
| 101 | br label %exit |
| 102 | bb28: |
| 103 | br label %exit |
| 104 | |
| 105 | |
| 106 | exit: |
| 107 | |
| 108 | ret void |
| 109 | } |
| 110 | |
Nico Rieck | ba848e3 | 2013-04-12 04:06:46 +0000 | [diff] [blame^] | 111 | ;; ARM: Symbol { |
| 112 | ;; ARM: Name: $a |
| 113 | ;; ARM-NEXT: Value: 0x0 |
| 114 | ;; ARM-NEXT: Size: 0 |
| 115 | ;; ARM-NEXT: Binding: Local |
| 116 | ;; ARM-NEXT: Type: None |
| 117 | ;; ARM-NEXT: Other: |
| 118 | ;; ARM-NEXT: Section: [[MIXED_SECT:[^ ]+]] |
Tim Northover | 5cc3dc8 | 2012-12-07 16:50:23 +0000 | [diff] [blame] | 119 | |
Nico Rieck | ba848e3 | 2013-04-12 04:06:46 +0000 | [diff] [blame^] | 120 | ;; ARM: Symbol { |
| 121 | ;; ARM: Name: $a |
| 122 | ;; ARM-NEXT: Value: 0xAC |
| 123 | ;; ARM-NEXT: Size: 0 |
| 124 | ;; ARM-NEXT: Binding: Local |
| 125 | ;; ARM-NEXT: Type: None |
| 126 | ;; ARM-NEXT: Other: |
| 127 | ;; ARM-NEXT: Section: [[MIXED_SECT]] |
Tim Northover | 5cc3dc8 | 2012-12-07 16:50:23 +0000 | [diff] [blame] | 128 | |
Nico Rieck | ba848e3 | 2013-04-12 04:06:46 +0000 | [diff] [blame^] | 129 | ;; ARM: Symbol { |
| 130 | ;; ARM: Name: $d |
| 131 | ;; ARM-NEXT: Value: 0 |
| 132 | ;; ARM-NEXT: Size: 0 |
| 133 | ;; ARM-NEXT: Binding: Local |
| 134 | ;; ARM-NEXT: Type: None |
Tim Northover | 5cc3dc8 | 2012-12-07 16:50:23 +0000 | [diff] [blame] | 135 | |
Nico Rieck | ba848e3 | 2013-04-12 04:06:46 +0000 | [diff] [blame^] | 136 | ;; ARM: Symbol { |
| 137 | ;; ARM: Name: $d |
| 138 | ;; ARM-NEXT: Value: 0x30 |
| 139 | ;; ARM-NEXT: Size: 0 |
| 140 | ;; ARM-NEXT: Binding: Local |
| 141 | ;; ARM-NEXT: Type: None |
| 142 | ;; ARM-NEXT: Other: |
| 143 | ;; ARM-NEXT: Section: [[MIXED_SECT]] |
Tim Northover | 5cc3dc8 | 2012-12-07 16:50:23 +0000 | [diff] [blame] | 144 | |
| 145 | ;; ARM-NOT: ${{[atd]}} |
| 146 | |
Nico Rieck | ba848e3 | 2013-04-12 04:06:46 +0000 | [diff] [blame^] | 147 | ;; TMB: Symbol { |
| 148 | ;; TMB: Name: $d.2 |
| 149 | ;; TMB-NEXT: Value: 0x16 |
| 150 | ;; TMB-NEXT: Size: 0 |
| 151 | ;; TMB-NEXT: Binding: Local |
| 152 | ;; TMB-NEXT: Type: None |
| 153 | ;; TMB-NEXT: Other: |
| 154 | ;; TMB-NEXT: Section: [[MIXED_SECT:[^ ]+]] |
Tim Northover | 5cc3dc8 | 2012-12-07 16:50:23 +0000 | [diff] [blame] | 155 | |
Nico Rieck | ba848e3 | 2013-04-12 04:06:46 +0000 | [diff] [blame^] | 156 | ;; TMB: Symbol { |
| 157 | ;; TMB: Name: $t |
| 158 | ;; TMB-NEXT: Value: 0x0 |
| 159 | ;; TMB-NEXT: Size: 0 |
| 160 | ;; TMB-NEXT: Binding: Local |
| 161 | ;; TMB-NEXT: Type: None |
| 162 | ;; TMB-NEXT: Other: |
| 163 | ;; TMB-NEXT: Section: [[MIXED_SECT]] |
Tim Northover | 5cc3dc8 | 2012-12-07 16:50:23 +0000 | [diff] [blame] | 164 | |
Nico Rieck | ba848e3 | 2013-04-12 04:06:46 +0000 | [diff] [blame^] | 165 | ;; TMB: Symbol { |
| 166 | ;; TMB: Name: $t |
| 167 | ;; TMB-NEXT: Value: 0x36 |
| 168 | ;; TMB-NEXT: Size: 0 |
| 169 | ;; TMB-NEXT: Binding: Local |
| 170 | ;; TMB-NEXT: Type: None |
| 171 | ;; TMB-NEXT: Other: |
| 172 | ;; TMB-NEXT: Section: [[MIXED_SECT]] |
Tim Northover | 5cc3dc8 | 2012-12-07 16:50:23 +0000 | [diff] [blame] | 173 | |
| 174 | |
| 175 | ;; TMB-NOT: ${{[atd]}} |
| 176 | |