mirror of
https://github.com/cirosantilli/linux-kernel-module-cheat.git
synced 2026-01-23 10:15:57 +01:00
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.
33 lines
867 B
ArmAsm
33 lines
867 B
ArmAsm
/* https://github.com/cirosantilli/linux-kernel-module-cheat#armv8-aarch64-add-vector-instruction
|
|
*
|
|
* Add a bunch of integers in one go.
|
|
*/
|
|
|
|
#include <lkmc.h>
|
|
|
|
LKMC_PROLOGUE
|
|
.data
|
|
input0: .long 0xF1F1F1F1, 0xF2F2F2F2, 0xF3F3F3F3, 0xF4F4F4F4
|
|
input1: .long 0x12121212, 0x13131313, 0x14141414, 0x15151515
|
|
expect_4s: .long 0x04040403, 0x06060605, 0x08080807, 0x0A0A0A09
|
|
expect_2d: .long 0x04040403, 0x06060606, 0x08080807, 0x0A0A0A0A
|
|
.bss
|
|
output: .skip 16
|
|
.text
|
|
#define TEST(size) \
|
|
adr x0, input0; \
|
|
ld1 {v0. ## size}, [x0]; \
|
|
adr x1, input1; \
|
|
ld1 {v1. ## size}, [x1]; \
|
|
add v2. ## size, v0. ## size, v1. ## size; \
|
|
adr x0, output; \
|
|
st1 {v2. ## size}, [x0]; \
|
|
LKMC_ASSERT_MEMCMP(output, expect_ ## size, =0x10)
|
|
|
|
/* 4x 32-bit */
|
|
TEST(4s)
|
|
/* 2x 64-bit */
|
|
TEST(2d)
|
|
#undef TEST
|
|
LKMC_EPILOGUE
|