2016-09-24 17:03:55 +00:00
|
|
|
PATTERNS
|
2016-09-24 15:20:40 +00:00
|
|
|
|
2016-09-24 20:46:08 +00:00
|
|
|
/* Special */
|
|
|
|
|
|
|
|
reg;
|
|
|
|
|
|
|
|
PAIR(BLOCK4, BLOCK4);
|
|
|
|
|
|
|
|
|
|
|
|
/* Miscellaneous special things */
|
|
|
|
|
|
|
|
PUSH4(in:reg)
|
|
|
|
emit "push %in"
|
|
|
|
cost 4;
|
|
|
|
|
|
|
|
reg = POP4
|
|
|
|
outs out:ANY
|
|
|
|
emit "pop %out"
|
|
|
|
cost 4;
|
|
|
|
|
|
|
|
RET
|
|
|
|
emit "ret"
|
|
|
|
cost 4;
|
|
|
|
|
|
|
|
SETRET4(in:reg)
|
|
|
|
emit "mov r0, %in"
|
|
|
|
cost 4;
|
|
|
|
|
|
|
|
/* Memory operations */
|
|
|
|
|
2016-09-24 17:03:55 +00:00
|
|
|
STORE4(addr:address, value:reg)
|
2016-09-24 15:20:40 +00:00
|
|
|
ins value:GPR
|
|
|
|
emit "str %value, %addr"
|
|
|
|
cost 4;
|
|
|
|
|
2016-09-24 16:31:35 +00:00
|
|
|
reg = LOAD4(addr:address)
|
2016-09-24 15:20:40 +00:00
|
|
|
outs dest:ANY
|
2016-09-24 20:46:08 +00:00
|
|
|
emit "ldr %dest, %addr"
|
|
|
|
cost 4;
|
|
|
|
|
|
|
|
reg = LOAD1(addr:address)
|
|
|
|
outs dest:ANY
|
|
|
|
emit "ldrb %dest, %addr"
|
|
|
|
cost 4;
|
|
|
|
|
|
|
|
reg = CIU14(LOAD1(addr:address))
|
|
|
|
outs dest:ANY
|
|
|
|
emit "ldrb %dest, %addr"
|
|
|
|
cost 4;
|
|
|
|
|
|
|
|
|
|
|
|
/* Locals */
|
|
|
|
|
|
|
|
reg = in:LOCAL4
|
|
|
|
outs out:GPR
|
|
|
|
emit "add %out, fp, #%in.ivalue"
|
2016-09-24 15:20:40 +00:00
|
|
|
cost 4;
|
|
|
|
|
2016-09-24 20:46:08 +00:00
|
|
|
address = in:LOCAL4
|
|
|
|
fragment "[fp, #%in.ivalue]";
|
|
|
|
|
|
|
|
|
|
|
|
/* Memory addressing modes */
|
|
|
|
|
2016-09-24 16:31:35 +00:00
|
|
|
address = ADD4(addr:reg, offset:CONST)
|
2016-09-24 15:20:40 +00:00
|
|
|
ins addr:GPR
|
|
|
|
fragment "[%addr, #%offset.ivalue]";
|
|
|
|
|
|
|
|
address = addr:reg
|
|
|
|
ins addr:GPR
|
|
|
|
fragment "[%addr]";
|
|
|
|
|
2016-09-24 20:46:08 +00:00
|
|
|
|
|
|
|
/* Branches */
|
|
|
|
|
|
|
|
JUMP(addr:BLOCK4)
|
|
|
|
emit "b %addr.bvalue"
|
|
|
|
cost 4;
|
|
|
|
|
|
|
|
CJUMPEQ(value:tristate, PAIR(true:BLOCK4, false:BLOCK4))
|
|
|
|
emit "beq %trueblock.bvalue"
|
|
|
|
emit "bne %falseblock.bvalue"
|
|
|
|
cost 8;
|
|
|
|
|
|
|
|
|
|
|
|
/* Comparisons */
|
|
|
|
|
|
|
|
tristate = COMPARES4(val1:reg, val2:aluparam)
|
|
|
|
outs CC
|
|
|
|
emit "cmp %val1, %val2"
|
|
|
|
cost 4;
|
|
|
|
|
|
|
|
reg = tristate
|
|
|
|
emit "mov %out, #0"
|
|
|
|
emit "movlt %out, #-1"
|
|
|
|
emit "movgt %out, #1"
|
|
|
|
cost 12;
|
|
|
|
|
|
|
|
|
|
|
|
/* Conversions */
|
|
|
|
|
|
|
|
reg = CII14(CIU41(value:reg))
|
|
|
|
outs out:GPR
|
|
|
|
emit "sxtb %out, %value"
|
|
|
|
cost 4;
|
|
|
|
|
|
|
|
reg = CIU41(in:reg)
|
|
|
|
outs out:GPR
|
|
|
|
emit "and %out, %in, #0xff"
|
|
|
|
cost 4;
|
|
|
|
|
|
|
|
|
|
|
|
/* ALU operations */
|
2016-09-24 15:20:40 +00:00
|
|
|
|
2016-09-24 16:31:35 +00:00
|
|
|
reg = ADD4(left:reg, right:aluparam)
|
2016-09-24 15:20:40 +00:00
|
|
|
ins left:GPR, right:GPR
|
|
|
|
outs out:GPR
|
|
|
|
emit "add %out, %left, %right"
|
|
|
|
cost 4;
|
|
|
|
|
2016-09-24 16:31:35 +00:00
|
|
|
reg = ADD4(left:aluparam, right:reg)
|
2016-09-24 15:20:40 +00:00
|
|
|
ins left:GPR, right:GPR
|
|
|
|
outs out:GPR
|
|
|
|
emit "add %out, %right, %left"
|
|
|
|
cost 4;
|
|
|
|
|
2016-09-24 16:31:35 +00:00
|
|
|
aluparam = value:CONST4
|
2016-09-24 15:20:40 +00:00
|
|
|
fragment "#%value.ivalue";
|
|
|
|
|
|
|
|
aluparam = reg;
|
|
|
|
|
|
|
|
reg = value:aluparam
|
|
|
|
outs out:GPR
|
|
|
|
emit "mov %out, %value"
|
|
|
|
cost 4;
|
|
|
|
|
2016-09-24 16:31:35 +00:00
|
|
|
reg = value:LABEL4
|
2016-09-24 15:20:40 +00:00
|
|
|
outs out:GPR
|
2016-09-24 20:46:08 +00:00
|
|
|
emit "adr %out, %value.lvalue"
|
|
|
|
cost 4;
|
|
|
|
|
|
|
|
reg = value:BLOCK4
|
|
|
|
outs out:GPR
|
|
|
|
emit "adr %out, %value.bvalue"
|
2016-09-24 15:20:40 +00:00
|
|
|
cost 4;
|
|
|
|
|
2016-09-24 16:31:35 +00:00
|
|
|
reg = value:CONST4
|
2016-09-24 15:20:40 +00:00
|
|
|
outs out:GPR
|
|
|
|
emit "ldr %out, #value.lvalue"
|
|
|
|
cost 4;
|