Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / clang / test / CodeGenObjC / bitfield-access.m
blob0ba73776b21251532f251df38226f476a9c9d4be
1 // RUN: %clang_cc1 -triple i386-apple-darwin10 -fobjc-runtime=macosx-fragile-10.5 -emit-llvm -o %t1 %s
2 // RUN: FileCheck -check-prefix=CHECK-I386 < %t1 %s
4 // RUN: %clang_cc1 -triple armv6-apple-darwin10 -fobjc-runtime=macosx-fragile-10.5 -target-abi apcs-gnu -emit-llvm -o %t2 %s
5 // RUN: FileCheck -check-prefix=CHECK-ARM < %t2 %s
7 @interface I0 { 
8 @public
9     unsigned x:15;
10     unsigned y: 1;
11
12 @end
14 // Check that we don't try to use an i32 load here, which would reach beyond the
15 // end of the structure.
17 // CHECK-I386-LABEL: define{{.*}} i32 @f0(
18 // CHECK-I386:   [[t0_0:%.*]] = load i8, ptr {{.*}}, align 1
19 // CHECK-I386:   lshr i8 [[t0_0]], 7
20 // CHECK-I386: }
21 int f0(I0 *a) {
22   return a->y;
25 // Check that we can handled straddled loads.
27 // CHECK-ARM-LABEL: define{{.*}} i32 @f1(
28 // CHECK-ARM:    [[t1_ptr:%.*]] = getelementptr
29 // CHECK-ARM:    [[t1_0:%.*]] = load i40, ptr [[t1_ptr]], align 1
30 // CHECK-ARM:    [[t1_1:%.*]] = lshr i40 [[t1_0]], 1
31 // CHECK-ARM:    [[t1_2:%.*]] = and i40 [[t1_1]],
32 // CHECK-ARM:                   trunc i40 [[t1_2]] to i32
33 // CHECK-ARM: }
34 @interface I1 {
35 @public
36     unsigned x: 1;
37     unsigned y:32;
39 @end
41 int f1(I1 *a) { return a->y; }