Yaxun Liu | af3d4db | 2017-05-23 16:15:53 +0000 | [diff] [blame] | 1 | // RUN: %clang_cc1 -verify -fsyntax-only -triple amdgcn -target-cpu verde -S -emit-llvm -o - %s |
Yaxun Liu | 6d96f163 | 2017-05-18 18:51:09 +0000 | [diff] [blame] | 2 | // RUN: %clang_cc1 -verify -fsyntax-only -triple amdgcn--opencl -target-cpu verde -S -emit-llvm -o - %s |
Tom Stellard | a96344b | 2014-08-21 13:58:40 +0000 | [diff] [blame] | 3 | // expected-no-diagnostics |
| 4 | |
| 5 | // Record lowering was crashing on SI and newer targets, because it |
| 6 | // was using the wrong size for test::ptr. Since global memory |
| 7 | // has 64-bit pointers, sizeof(test::ptr) should be 8. |
| 8 | |
| 9 | struct test_as0 {int *ptr;}; |
| 10 | constant int as0[sizeof(struct test_as0) == 4 ? 1 : -1] = { 0 }; |
| 11 | |
| 12 | struct test_as1 {global int *ptr;}; |
| 13 | constant int as1[sizeof(struct test_as1) == 8 ? 1 : -1] = { 0 }; |
| 14 | |
| 15 | struct test_as2 {constant int *ptr;}; |
| 16 | constant int as2[sizeof(struct test_as2) == 8 ? 1 : -1] = { 0 }; |
| 17 | |
| 18 | struct test_as3 {local int *ptr;}; |
| 19 | constant int as3[sizeof(struct test_as3) == 4 ? 1 : -1] = { 0 }; |