Files
linux-kernel-module-cheat/userland/arch/arm/add.S
Ciro Santilli 六四事件 法轮功 5f935ee53d readme: verify all non-README links with asciidoctor/extract-header-ids and git grep
Fix all the ~30 failures it found!
2019-06-09 00:00:00 +00:00

59 lines
1.1 KiB
ArmAsm

/* https://github.com/cirosantilli/linux-kernel-module-cheat#arm-data-processing-instructions */
#include <lkmc.h>
LKMC_PROLOGUE
/* Immediate encoding.
*
* r1 = r0 + 2
*/
mov r0, 1
/* r1 = r0 + 2 */
add r1, r0, 2
LKMC_ASSERT_EQ(r1, =3)
/* If src == dest, we can omit one of them.
*
* r0 = r0 + 2
*/
mov r0, 1
add r0, 2
LKMC_ASSERT_EQ(r0, =3)
/* Same as above but explicit. */
mov r0, 1
add r0, r0, 2
LKMC_ASSERT_EQ(r0, =3)
#if 0
/* But we cannot omit the register if there is a shift when using .syntx unified:
* https://github.com/cirosantilli/linux-kernel-module-cheat#arm-shift-suffixes
*/
.syntax unified
/* Error: garbage following instruction */
add r0, r1, lsl 1
/* OK */
add r0, r0, r1, lsl 1
#endif
/* Register encoding.
*
* r2 = r0 + r1
*/
mov r0, 1
mov r1, 2
add r2, r0, r1
LKMC_ASSERT_EQ(r2, =3)
/* Register encoding, omit implicit register.
*
* r1 = r1 + r0
*/
mov r0, 1
mov r1, 2
add r1, r0
LKMC_ASSERT_EQ(r1, =3)
LKMC_EPILOGUE