mirror of
https://github.com/cirosantilli/linux-kernel-module-cheat.git
synced 2026-01-28 20:44:26 +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#arm-data-processing-instructions */
|
||||
|
||||
#include "common.h"
|
||||
#include <lkmc.h>
|
||||
|
||||
LKMC_ENTRY
|
||||
LKMC_PROLOGUE
|
||||
|
||||
/* Immediate encoding.
|
||||
*
|
||||
@@ -11,7 +11,7 @@ LKMC_ENTRY
|
||||
mov r0, 1
|
||||
/* r1 = r0 + 2 */
|
||||
add r1, r0, 2
|
||||
LKMC_ASSERT_EQ(r1, 3)
|
||||
LKMC_ASSERT_EQ(r1, =3)
|
||||
|
||||
/* If src == dest, we can omit one of them.
|
||||
*
|
||||
@@ -19,12 +19,12 @@ LKMC_ENTRY
|
||||
*/
|
||||
mov r0, 1
|
||||
add r0, 2
|
||||
LKMC_ASSERT_EQ(r0, 3)
|
||||
LKMC_ASSERT_EQ(r0, =3)
|
||||
|
||||
/* Same as above but explicit. */
|
||||
mov r0, 1
|
||||
add r0, r0, 2
|
||||
LKMC_ASSERT_EQ(r0, 3)
|
||||
LKMC_ASSERT_EQ(r0, =3)
|
||||
|
||||
#if 0
|
||||
/* But we cannot omit the register if there is a shift when using .syntx unified:
|
||||
@@ -44,7 +44,7 @@ LKMC_ENTRY
|
||||
mov r0, 1
|
||||
mov r1, 2
|
||||
add r2, r0, r1
|
||||
LKMC_ASSERT_EQ(r2, 3)
|
||||
LKMC_ASSERT_EQ(r2, =3)
|
||||
|
||||
/* Register encoding, omit implicit register.
|
||||
*
|
||||
@@ -53,6 +53,6 @@ LKMC_ENTRY
|
||||
mov r0, 1
|
||||
mov r1, 2
|
||||
add r1, r0
|
||||
LKMC_ASSERT_EQ(r1, 3)
|
||||
LKMC_ASSERT_EQ(r1, =3)
|
||||
|
||||
LKMC_EXIT
|
||||
LKMC_EPILOGUE
|
||||
|
||||
Reference in New Issue
Block a user