Files
linux-kernel-module-cheat/userland/arch/aarch64/adr.S
Ciro Santilli 六四事件 法轮功 c8c4f89854 asm: make use regular asserts that will just work on baremetal
Previously had wonky line pointer in asm_main. New interface simpler and more portable.

Add tests for ASSERT_EQ_ and family in arm and aarch64, previously on x86_64.

ASSERT_EQ_ and family in ARM can now either take =123, =addr or var, before this
the = was added on macros so var was not possible.

Define the main function directly in assembly, the C driver was useless.
2019-05-23 00:00:00 +00:00

22 lines
647 B
ArmAsm

/* https://github.com/cirosantilli/linux-kernel-module-cheat#arm-adr-instruction */
#include <lkmc.h>
.data
data_label:
.word 0x1234678
LKMC_PROLOGUE
/* This is not possible in v7 because the label is in another section.
* objdump says that this generates a R_AARCH64_ADR_PRE relocation.
* which looks specific to ADR, and therefore makes it more likely
* that there was no such relocation in v7.
*
* This relocation is particularly important because str does not have a
* pc-relative mode in ARMv8.
*/
adr x0, data_label
ldr x1, =data_label
label:
LKMC_ASSERT_EQ_REG(x0, x1)
LKMC_EPILOGUE