aboutsummaryrefslogtreecommitdiff
path: root/arch/riscv/kernel/tests/module_test/test_sub64.S
diff options
context:
space:
mode:
authorGravatar Charlie Jenkins <charlie@rivosinc.com> 2023-11-01 11:33:01 -0700
committerGravatar Palmer Dabbelt <palmer@rivosinc.com> 2023-11-07 14:59:32 -0800
commitaf71bc194916b10f9b394f9b14419d99700a5e67 (patch)
tree3ba1d884a72d6407c576fba8bff7c1d71a7caa1b /arch/riscv/kernel/tests/module_test/test_sub64.S
parentriscv: Add remaining module relocations (diff)
downloadlinux-af71bc194916b10f9b394f9b14419d99700a5e67.tar.gz
linux-af71bc194916b10f9b394f9b14419d99700a5e67.tar.bz2
linux-af71bc194916b10f9b394f9b14419d99700a5e67.zip
riscv: Add tests for riscv module loading
Add test cases for the two main groups of relocations added: SUB and SET, along with uleb128. Signed-off-by: Charlie Jenkins <charlie@rivosinc.com> Link: https://lore.kernel.org/r/20231101-module_relocations-v9-3-8dfa3483c400@rivosinc.com Signed-off-by: Palmer Dabbelt <palmer@rivosinc.com>
Diffstat (limited to 'arch/riscv/kernel/tests/module_test/test_sub64.S')
-rw-r--r--arch/riscv/kernel/tests/module_test/test_sub64.S25
1 files changed, 25 insertions, 0 deletions
diff --git a/arch/riscv/kernel/tests/module_test/test_sub64.S b/arch/riscv/kernel/tests/module_test/test_sub64.S
new file mode 100644
index 000000000000..a59e8afa88fd
--- /dev/null
+++ b/arch/riscv/kernel/tests/module_test/test_sub64.S
@@ -0,0 +1,25 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/*
+ * Copyright (C) 2023 Rivos Inc.
+ */
+
+.text
+.global test_sub64
+test_sub64:
+#ifdef CONFIG_32BIT
+ lw a0, sub64
+#else
+ ld a0, sub64
+#endif
+ addi a0, a0, -32
+ ret
+first:
+ .space 32
+second:
+
+.data
+sub64:
+ .reloc sub64, R_RISCV_ADD64, second
+ .reloc sub64, R_RISCV_SUB64, first
+ .word 0
+ .word 0