mirror of
https://github.com/cirosantilli/linux-kernel-module-cheat.git
synced 2026-01-29 21:14:27 +01:00
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.
This commit is contained in:
@@ -1,8 +1,8 @@
|
||||
/* https://github.com/cirosantilli/linux-kernel-module-cheat#assembly-registers */
|
||||
|
||||
#include "common.h"
|
||||
#include <lkmc.h>
|
||||
|
||||
LKMC_ENTRY
|
||||
LKMC_PROLOGUE
|
||||
|
||||
/* 13 general purpose registers. */
|
||||
mov r0, 0
|
||||
@@ -39,12 +39,12 @@ LKMC_ENTRY
|
||||
* https://stackoverflow.com/questions/32304646/arm-assembly-branch-to-address-inside-register-or-memory/54145818#54145818
|
||||
*/
|
||||
ldr pc, =10f
|
||||
LKMC_FAIL
|
||||
LKMC_ASSERT_FAIL
|
||||
10:
|
||||
|
||||
/* Same with r15, which is the same as pc. */
|
||||
ldr r15, =10f
|
||||
LKMC_FAIL
|
||||
LKMC_ASSERT_FAIL
|
||||
10:
|
||||
|
||||
/* Another example with mov reading from pc. */
|
||||
@@ -60,10 +60,10 @@ pc_addr:
|
||||
b 1f
|
||||
.word 0x12345678
|
||||
1:
|
||||
LKMC_ASSERT_EQ(r0, 0x12345678)
|
||||
LKMC_ASSERT_EQ(r0, =0x12345678)
|
||||
|
||||
/* We can also use fp in GNU GAS assembly. */
|
||||
mov r11, 0
|
||||
mov fp, 1
|
||||
LKMC_ASSERT_EQ(r11, 1)
|
||||
LKMC_EXIT
|
||||
LKMC_ASSERT_EQ(r11, =1)
|
||||
LKMC_EPILOGUE
|
||||
|
||||
Reference in New Issue
Block a user