| ; RUN: llc < %s -march=bpfel -mattr=+alu32 -verify-machineinstrs | FileCheck %s |
| ; RUN: llc < %s -march=bpfeb -mattr=+alu32 -verify-machineinstrs | FileCheck %s |
| ; |
| ; Source Code: |
| ; struct t { |
| ; unsigned char a; |
| ; unsigned char b; |
| ; unsigned char c; |
| ; }; |
| ; extern void foo(ptr); |
| ; int test() { |
| ; struct t v = { |
| ; .b = 2, |
| ; }; |
| ; foo(&v); |
| ; return 0; |
| ; } |
| ; Compilation flag: |
| ; clang -target bpf -O2 -S -emit-llvm t.c |
| |
| %struct.t = type { i8, i8, i8 } |
| |
| @__const.test.v = private unnamed_addr constant %struct.t { i8 0, i8 2, i8 0 }, align 1 |
| |
| ; Function Attrs: nounwind |
| define dso_local i32 @test() local_unnamed_addr { |
| entry: |
| %v1 = alloca [3 x i8], align 1 |
| call void @llvm.lifetime.start.p0(i64 3, ptr nonnull %v1) |
| call void @llvm.memcpy.p0.p0.i64(ptr nonnull align 1 dereferenceable(3) %v1, ptr nonnull align 1 dereferenceable(3) @__const.test.v, i64 3, i1 false) |
| call void @foo(ptr nonnull %v1) |
| call void @llvm.lifetime.end.p0(i64 3, ptr nonnull %v1) |
| ret i32 0 |
| } |
| ; CHECK-NOT: w{{[0-9]+}} = *(u16 *) |
| ; CHECK-NOT: w{{[0-9]+}} = *(u8 *) |
| ; CHECK: *(u16 *)(r10 - 4) = w{{[0-9]+}} |
| ; CHECK: *(u8 *)(r10 - 2) = w{{[0-9]+}} |
| |
| ; Function Attrs: argmemonly nounwind willreturn |
| declare void @llvm.lifetime.start.p0(i64 immarg, ptr nocapture) |
| |
| ; Function Attrs: argmemonly nounwind willreturn |
| declare void @llvm.memcpy.p0.p0.i64(ptr noalias nocapture writeonly, ptr noalias nocapture readonly, i64, i1 immarg) |
| |
| declare dso_local void @foo(ptr) local_unnamed_addr |
| |
| ; Function Attrs: argmemonly nounwind willreturn |
| declare void @llvm.lifetime.end.p0(i64 immarg, ptr nocapture) |