
This brings our tree to NetBSD 7.0, as found on -current on the 10-10-2015. This updates: - LLVM to 3.6.1 - GCC to GCC 5.1 - Replace minix/commands/zdump with usr.bin/zdump - external/bsd/libelf has moved to /external/bsd/elftoolchain/ - Import ctwm - Drop sprintf from libminc Change-Id: I149836ac18e9326be9353958bab9b266efb056f0
16 lines
682 B
C
16 lines
682 B
C
// REQUIRES: aarch64-registered-target
|
|
// RUN: %clang_cc1 -triple aarch64_be-linux-gnu -ffreestanding -emit-llvm -O0 -o - %s | FileCheck --check-prefix IR %s
|
|
// RUN: %clang_cc1 -triple aarch64_be-linux-gnu -ffreestanding -S -O1 -o - %s | FileCheck --check-prefix ARM %s
|
|
|
|
struct bt3 { signed b2:10; signed b3:10; } b16;
|
|
|
|
// Get the high 32-bits and then shift appropriately for big-endian.
|
|
signed callee_b0f(struct bt3 bp11) {
|
|
// IR: callee_b0f(i64 [[ARG:%.*]])
|
|
// IR: store i64 [[ARG]], i64* [[PTR:%.*]]
|
|
// IR: [[BITCAST:%.*]] = bitcast i64* [[PTR]] to i8*
|
|
// IR: call void @llvm.memcpy.p0i8.p0i8.i64(i8* {{.*}}, i8* [[BITCAST]], i64 4
|
|
// ARM: asr x0, x0, #54
|
|
return bp11.b2;
|
|
}
|