James Molloy | 90d6101 | 2014-08-29 10:17:52 +0000 | [diff] [blame] | 1 | // RUN: %clang_cc1 -triple aarch64_be-linux-gnu -ffreestanding -emit-llvm -O0 -o - %s | FileCheck --check-prefix IR %s |
James Molloy | 491cefb | 2014-05-07 17:41:15 +0000 | [diff] [blame] | 2 | |
| 3 | struct bt3 { signed b2:10; signed b3:10; } b16; |
| 4 | |
James Molloy | 90d6101 | 2014-08-29 10:17:52 +0000 | [diff] [blame] | 5 | // Get the high 32-bits and then shift appropriately for big-endian. |
James Molloy | 491cefb | 2014-05-07 17:41:15 +0000 | [diff] [blame] | 6 | signed callee_b0f(struct bt3 bp11) { |
James Molloy | 90d6101 | 2014-08-29 10:17:52 +0000 | [diff] [blame] | 7 | // IR: callee_b0f(i64 [[ARG:%.*]]) |
Ulrich Weigand | 6e2cea6 | 2015-07-10 11:31:43 +0000 | [diff] [blame] | 8 | // IR: store i64 [[ARG]], i64* [[PTR:%.*]], align 8 |
James Molloy | 90d6101 | 2014-08-29 10:17:52 +0000 | [diff] [blame] | 9 | // IR: [[BITCAST:%.*]] = bitcast i64* [[PTR]] to i8* |
Pete Cooper | 3b39e88 | 2015-11-19 05:55:59 +0000 | [diff] [blame] | 10 | // IR: call void @llvm.memcpy.p0i8.p0i8.i64(i8* {{.*}}, i8* [[BITCAST]], i64 4 |
James Molloy | 491cefb | 2014-05-07 17:41:15 +0000 | [diff] [blame] | 11 | return bp11.b2; |
| 12 | } |