[lld] abd80ec - [ELF][test] Improve gitBitcodeMachineKind tests
Fangrui Song via llvm-commits
llvm-commits at lists.llvm.org
Tue Sep 7 11:38:48 PDT 2021
Author: Fangrui Song
Date: 2021-09-07T11:38:43-07:00
New Revision: abd80ecf6ed8f013b8c78fb00a2637dfc81e50cb
URL: https://github.com/llvm/llvm-project/commit/abd80ecf6ed8f013b8c78fb00a2637dfc81e50cb
DIFF: https://github.com/llvm/llvm-project/commit/abd80ecf6ed8f013b8c78fb00a2637dfc81e50cb.diff
LOG: [ELF][test] Improve gitBitcodeMachineKind tests
Added:
lld/test/ELF/lto/ppc.ll
lld/test/ELF/lto/riscv.ll
Modified:
lld/test/ELF/lto/aarch64.ll
Removed:
lld/test/ELF/lto/ppc64le.ll
lld/test/ELF/lto/riscv32.ll
lld/test/ELF/lto/riscv64.ll
################################################################################
diff --git a/lld/test/ELF/lto/aarch64.ll b/lld/test/ELF/lto/aarch64.ll
index a6f6ceeb38608..5aba466eaf6a1 100644
--- a/lld/test/ELF/lto/aarch64.ll
+++ b/lld/test/ELF/lto/aarch64.ll
@@ -10,6 +10,7 @@
; RUN: ld.lld %t/be.o -o %t/be
; RUN: llvm-readobj -h %t/be | FileCheck %s --check-prefixes=CHECK,BE
+; CHECK: Class: 64-bit
; LE: DataEncoding: LittleEndian
; BE: DataEncoding: BigEndian
; CHECK: Machine: EM_AARCH64
diff --git a/lld/test/ELF/lto/ppc.ll b/lld/test/ELF/lto/ppc.ll
new file mode 100644
index 0000000000000..38312e8e530c5
--- /dev/null
+++ b/lld/test/ELF/lto/ppc.ll
@@ -0,0 +1,51 @@
+; REQUIRES: ppc
+;; Test we can infer the e_machine value EM_PPC/EM_PPC64 from a bitcode file.
+
+; RUN: split-file %s %t
+; RUN: llvm-as %t/32le.ll -o %t/32le.o
+; RUN: ld.lld %t/32le.o -o %t/32le
+; RUN: llvm-readobj -h %t/32le | FileCheck %s --check-prefix=LE32
+
+; RUN: llvm-as %t/32be.ll -o %t/32be.o
+; RUN: ld.lld %t/32be.o -o %t/32be
+; RUN: llvm-readobj -h %t/32be | FileCheck %s --check-prefix=BE32
+
+; RUN: llvm-as %t/64.ll -o %t/64.o
+; RUN: ld.lld %t/64.o -o %t/64
+; RUN: llvm-readobj -h %t/64 | FileCheck %s --check-prefix=LE64
+
+; LE32: Class: 32-bit
+; LE32: DataEncoding: LittleEndian
+; LE32: Machine: EM_PPC (
+
+; BE32: Class: 32-bit
+; BE32: DataEncoding: BigEndian
+; BE32: Machine: EM_PPC (
+
+; LE64: Class: 64-bit
+; LE64: DataEncoding: LittleEndian
+; LE64: Machine: EM_PPC64
+
+;--- 32le.ll
+target datalayout = "e-m:e-p:32:32-i64:64-n32"
+target triple = "powerpcle-pc-freebsd"
+
+define void @_start() {
+ ret void
+}
+
+;--- 32be.ll
+target datalayout = "E-m:e-p:32:32-i64:64-n32"
+target triple = "powerpc-unknown-linux-gnu"
+
+define void @_start() {
+ ret void
+}
+
+;--- 64.ll
+target datalayout = "e-m:e-i64:64-n32:64-S128-v256:256:256-v512:512:512"
+target triple = "powerpc64le-unknown-linux-gnu"
+
+define void @_start() {
+ ret void
+}
diff --git a/lld/test/ELF/lto/ppc64le.ll b/lld/test/ELF/lto/ppc64le.ll
deleted file mode 100644
index 917b47231843e..0000000000000
--- a/lld/test/ELF/lto/ppc64le.ll
+++ /dev/null
@@ -1,12 +0,0 @@
-; REQUIRES: ppc
-
-; RUN: llvm-as %s -o %t.o
-; RUN: ld.lld %t.o -o %t
-
-target datalayout = "e-m:e-i64:64-n32:64"
-target triple = "powerpc64le-unknown-linux-gnu"
-
-define void @__start() {
- entry:
- ret void
-}
diff --git a/lld/test/ELF/lto/riscv.ll b/lld/test/ELF/lto/riscv.ll
new file mode 100644
index 0000000000000..6bacadfba005f
--- /dev/null
+++ b/lld/test/ELF/lto/riscv.ll
@@ -0,0 +1,32 @@
+; REQUIRES: riscv
+;; Test we can infer the e_machine value EM_RISCV from a bitcode file.
+
+; RUN: split-file %s %t
+; RUN: llvm-as %t/32.ll -o %t/32.o
+; RUN: ld.lld %t/32.o -o %t/32
+; RUN: llvm-readobj -h %t/32 | FileCheck %s --check-prefixes=CHECK,RV32
+
+; RUN: llvm-as %t/64.ll -o %t/64.o
+; RUN: ld.lld %t/64.o -o %t/64
+; RUN: llvm-readobj -h %t/64 | FileCheck %s --check-prefixes=CHECK,RV64
+
+; RV32: Class: 32-bit
+; RV64: Class: 64-bit
+; CHECK: DataEncoding: LittleEndian
+; CHECK: Machine: EM_RISCV
+
+;--- 32.ll
+target datalayout = "e-m:e-p:32:32-i64:64-n32-S128"
+target triple = "riscv32-unknown-elf"
+
+define void @_start() {
+ ret void
+}
+
+;--- 64.ll
+target datalayout = "e-m:e-p:64:64-i64:64-i128:128-n64-S128"
+target triple = "riscv64-unknown-elf"
+
+define void @_start() {
+ ret void
+}
diff --git a/lld/test/ELF/lto/riscv32.ll b/lld/test/ELF/lto/riscv32.ll
deleted file mode 100644
index 1fe5547748fc3..0000000000000
--- a/lld/test/ELF/lto/riscv32.ll
+++ /dev/null
@@ -1,10 +0,0 @@
-; REQUIRES: riscv
-
-; RUN: llvm-as %s -o %t.o
-; RUN: ld.lld %t.o -o %t
-target datalayout = "e-m:e-p:32:32-i64:64-n32-S128"
-target triple = "riscv32-unknown-elf"
-
-define void @f() {
- ret void
-}
diff --git a/lld/test/ELF/lto/riscv64.ll b/lld/test/ELF/lto/riscv64.ll
deleted file mode 100644
index 59de1de4a8d91..0000000000000
--- a/lld/test/ELF/lto/riscv64.ll
+++ /dev/null
@@ -1,10 +0,0 @@
-; REQUIRES: riscv
-
-; RUN: llvm-as %s -o %t.o
-; RUN: ld.lld %t.o -o %t
-target datalayout = "e-m:e-p:64:64-i64:64-i128:128-n64-S128"
-target triple = "riscv64-unknown-elf"
-
-define void @f() {
- ret void
-}
More information about the llvm-commits
mailing list