Files
linux-kernel-module-cheat/userland/arch/aarch64/fadd_vector.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

35 lines
854 B
ArmAsm

/* https://github.com/cirosantilli/linux-kernel-module-cheat#armv8-aarch64-fadd-vector-instruction
*
* Add a bunch of floating point numbers in one go.
*/
#include <lkmc.h>
LKMC_PROLOGUE
.data
input0_4s: .float 1.5, 2.5, 3.5, 4.5
input1_4s: .float 5.5, 6.5, 7.5, 8.5
expect_4s: .float 7.0, 9.0, 11.0, 13.0
input0_2d: .double 1.5, 2.5
input1_2d: .double 5.5, 6.5
expect_2d: .double 7.0, 9.0
.bss
output: .skip 16
.text
#define TEST(size) \
adr x0, input0_ ## size; \
ld1 {v0. ## size}, [x0]; \
adr x1, input1_ ## size; \
ld1 {v1. ## size}, [x1]; \
fadd 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