Files
2019-07-07 00:00:01 +00:00

28 lines
573 B
ArmAsm

/* https://cirosantilli.com/linux-kernel-module-cheat#x86-cmpxchg-instruction */
#include <lkmc.h>
LKMC_PROLOGUE
/* rax != r13 */
mov $0, %rax
mov $1, %r13
mov $2, %r14
cmpxchg %r14, %r13
mov %rax, %r12
LKMC_ASSERT(jnz)
LKMC_ASSERT_EQ(%rax, $1)
LKMC_ASSERT_EQ(%r13, $1)
LKMC_ASSERT_EQ(%r14, $2)
/* rax == r13 */
mov $0, %rax
mov $0, %r13
mov $2, %r14
cmpxchg %r14, %r13
mov %rax, %r12
LKMC_ASSERT(jz)
LKMC_ASSERT_EQ(%rax, $0)
LKMC_ASSERT_EQ(%r13, $2)
LKMC_ASSERT_EQ(%r14, $2)
LKMC_EPILOGUE