1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
|
/*
* test relax
* bittst.c <-> bittst! : register number must be in 0-15
* Author: ligang
*/
/* This macro transform 32b instruction to 16b. */
.macro tran3216 insn32, insn16
\insn32 r0, 2 #32b -> 16b
\insn16 r0, 2
\insn32 r15, 4 #32b -> 16b
\insn16 r15, 4
\insn32 r15, 1 #32b -> 16b
\insn16 r15, 1
\insn16 r15, 3
\insn32 r15, 3 #32b -> 16b
\insn32 r8, 2 #32b -> 16b
\insn32 r8, 2 #32b -> 16b
\insn32 r15, 1 #No transform
\insn32 r26, 4
.endm
/* This macro transform 16b instruction to 32b. */
.macro tran1632 insn32, insn16
.align 4
\insn16 r0, 2 #16b -> 32b
\insn32 r20, 2
\insn16 r15, 4 #16b -> 32b
\insn32 r25, 4
\insn16 r15, 1 #16b -> 32b
\insn32 r25, 1
\insn16 r8, 1 #No transform
\insn16 r8, 1 #No transform
\insn16 r6, 4 #No transform
\insn32 r6, 4 #32b -> 16b
\insn32 r7, 3 #32b -> 16b
\insn16 r7, 3 #No transform
.endm
.text
tran3216 "bittst.c", "bittst!"
tran1632 "bittst.c", "bittst!"
|