diff options
author | Charlie Jenkins <charlie@rivosinc.com> | 2023-11-01 11:33:01 -0700 |
---|---|---|
committer | Palmer Dabbelt <palmer@rivosinc.com> | 2023-11-07 14:59:32 -0800 |
commit | af71bc194916b10f9b394f9b14419d99700a5e67 (patch) | |
tree | 3ba1d884a72d6407c576fba8bff7c1d71a7caa1b /arch/riscv/kernel/tests/module_test/test_sub64.S | |
parent | riscv: Add remaining module relocations (diff) | |
download | linux-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.S | 25 |
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 |