Files
clang-p2996/llvm/test/CodeGen/BPF/objdump_static_var.ll
Fangrui Song 806761a762 [test] Change llc -march= to -mtriple=
The issue is uncovered by #47698: for IR files without a target triple,
-mtriple= specifies the full target triple while -march= merely sets the
architecture part of the default target triple, leaving a target triple which
may not make sense, e.g. riscv64-apple-darwin.

Therefore, -march= is error-prone and not recommended for tests without a target
triple. The issue has been benign as we recognize $unknown-apple-darwin as ELF instead
of rejecting it outrightly.
2023-09-11 14:42:37 -07:00

39 lines
1.1 KiB
LLVM

; RUN: llc -mtriple=bpfel -filetype=obj -o - %s | llvm-objdump --no-print-imm-hex -d - | FileCheck --check-prefix=CHECK %s
; RUN: llc -mtriple=bpfeb -filetype=obj -o - %s | llvm-objdump --no-print-imm-hex -d - | FileCheck --check-prefix=CHECK %s
; src:
; static volatile long a = 2;
; static volatile int b = 3;
; int test() { return a + b; }
@a = internal global i64 2, align 8
@b = internal global i32 3, align 4
; Function Attrs: norecurse nounwind
define dso_local i32 @test() local_unnamed_addr #0 {
%1 = load volatile i64, ptr @a, align 8, !tbaa !2
; CHECK: r1 = 0 ll
; CHECK: r1 = *(u64 *)(r1 + 0)
%2 = load volatile i32, ptr @b, align 4, !tbaa !6
; CHECK: r2 = 8 ll
; CHECK: r0 = *(u32 *)(r2 + 0)
%3 = trunc i64 %1 to i32
%4 = add i32 %2, %3
; CHECK: r0 += r1
ret i32 %4
; CHECK: exit
}
attributes #0 = { norecurse nounwind }
!llvm.module.flags = !{!0}
!llvm.ident = !{!1}
!0 = !{i32 1, !"wchar_size", i32 4}
!1 = !{!"clang version 8.0.20181009 "}
!2 = !{!3, !3, i64 0}
!3 = !{!"long", !4, i64 0}
!4 = !{!"omnipotent char", !5, i64 0}
!5 = !{!"Simple C/C++ TBAA"}
!6 = !{!7, !7, i64 0}
!7 = !{!"int", !4, i64 0}