/* * test relax * addi <-> addei! : for addei : register number must be in 0-15, offset : 4b, only 16b -> 32b * (1)addi rD, simm16 : rD = rD + simm16, -32768 <= simm16 <= 32767 * (2)addei! rD, imm4 : rD = rD + 2**imm4 * addi <-> subei! : for addei : register number must be in 0-15, offset : 4b, only 16b -> 32b * (1)addi rD, simm16 : rD = rD + simm16, -32768 <= simm16 <= 32767 * (2)subei! rD, imm4 : rD = rD + 2**imm4 * Author: ligang */ /* This macro transform 16b instruction to 32b. */ .macro tran1632 insn32, insn16, sign .align 4 \insn16 r0, 0 #16b -> 32b \insn32 r0, \sign * 1 \insn16 r15, 4 #16b -> 32b \insn32 r15, \sign * 16 \insn16 r15, 14 #16b -> 32b \insn32 r15, \sign * 1024 * 16 \insn16 r8, 3 #No transform \insn16 r8, 3 #No transform \insn16 r15, 15 #No transform. Because 2**15 = 32768, extend range of addi \insn32 r15, 0x7FFF .endm .text tran1632 "addi.c", "addei!", 1 tran1632 "addi.c", "subei!", -1