|
| 1 | +; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py |
| 2 | +; RUN: llc -mtriple=amdgcn-amd-amdhsa -mcpu=gfx942 -start-before=amdgpu-isel -amdgpu-use-sdag-ptradd=1 < %s | FileCheck --check-prefixes=GFX942,GFX942_PTRADD %s |
| 3 | +; RUN: llc -mtriple=amdgcn-amd-amdhsa -mcpu=gfx942 -start-before=amdgpu-isel -amdgpu-use-sdag-ptradd=0 < %s | FileCheck --check-prefixes=GFX942,GFX942_LEGACY %s |
| 4 | + |
| 5 | +; Tests for undef and poison DAG folds for the ISD::PTRADD SelectionDAG opcode. |
| 6 | +; If any additions are generated for these tests, the folds don't work. |
| 7 | + |
| 8 | +define ptr @poison_offset(ptr %p, i64 %offset) { |
| 9 | +; GFX942-LABEL: poison_offset: |
| 10 | +; GFX942: ; %bb.0: |
| 11 | +; GFX942-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0) |
| 12 | +; GFX942-NEXT: v_mov_b32_e32 v1, 0 |
| 13 | +; GFX942-NEXT: s_setpc_b64 s[30:31] |
| 14 | + %gep1 = getelementptr i8, ptr %p, i64 poison |
| 15 | + ret ptr %gep1 |
| 16 | +} |
| 17 | + |
| 18 | +define ptr @poison_base(ptr %p, i64 %offset) { |
| 19 | +; GFX942-LABEL: poison_base: |
| 20 | +; GFX942: ; %bb.0: |
| 21 | +; GFX942-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0) |
| 22 | +; GFX942-NEXT: v_mov_b32_e32 v1, 0 |
| 23 | +; GFX942-NEXT: s_setpc_b64 s[30:31] |
| 24 | + %gep1 = getelementptr i8, ptr poison, i64 %offset |
| 25 | + ret ptr %gep1 |
| 26 | +} |
| 27 | + |
| 28 | +define ptr @undef_offset(ptr %p, i64 %offset) { |
| 29 | +; GFX942-LABEL: undef_offset: |
| 30 | +; GFX942: ; %bb.0: |
| 31 | +; GFX942-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0) |
| 32 | +; GFX942-NEXT: v_mov_b32_e32 v1, 0 |
| 33 | +; GFX942-NEXT: s_setpc_b64 s[30:31] |
| 34 | + %gep1 = getelementptr i8, ptr %p, i64 undef |
| 35 | + ret ptr %gep1 |
| 36 | +} |
| 37 | + |
| 38 | +define ptr @undef_base(ptr %p, i64 %offset) { |
| 39 | +; GFX942-LABEL: undef_base: |
| 40 | +; GFX942: ; %bb.0: |
| 41 | +; GFX942-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0) |
| 42 | +; GFX942-NEXT: v_mov_b32_e32 v1, 0 |
| 43 | +; GFX942-NEXT: s_setpc_b64 s[30:31] |
| 44 | + %gep1 = getelementptr i8, ptr undef, i64 %offset |
| 45 | + ret ptr %gep1 |
| 46 | +} |
| 47 | +;; NOTE: These prefixes are unused and the list is autogenerated. Do not add tests below this line: |
| 48 | +; GFX942_LEGACY: {{.*}} |
| 49 | +; GFX942_PTRADD: {{.*}} |
0 commit comments