Implement methods that enable expansion of load immediate
macro instruction (li) in the assembler.
We have identified three possible expansions depending on
the size of immediate operand:
1) for 0 ≤ j ≤ 65535.
li d,j =>
ori d,$zero,j
2) for −32768 ≤ j < 0.
li d,j =>
addiu d,$zero,j
3) for any other value of j that is representable as a 32-bit integer.
li d,j =>
lui d,hi16(j)
ori d,d,lo16(j)
All of the above have been implemented in ths patch.
Contributer: Vladimir Medic
llvm-svn: 165199
2012-10-04 12:03:53 +08:00
|
|
|
# RUN: llvm-mc %s -triple=mipsel-unknown-linux -show-encoding -mcpu=mips32r2 | FileCheck %s
|
|
|
|
# Check that the assembler can handle the documented syntax
|
|
|
|
# for macro instructions
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
# Load immediate instructions
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
# CHECK: ori $5, $zero, 123 # encoding: [0x7b,0x00,0x05,0x34]
|
|
|
|
# CHECK: addiu $6, $zero, -2345 # encoding: [0xd7,0xf6,0x06,0x24]
|
|
|
|
# CHECK: lui $7, 1 # encoding: [0x01,0x00,0x07,0x3c]
|
|
|
|
# CHECK: ori $7, $7, 2 # encoding: [0x02,0x00,0xe7,0x34]
|
2014-06-18 21:55:18 +08:00
|
|
|
# CHECK: addiu $8, $zero, -8 # encoding: [0xf8,0xff,0x08,0x24]
|
|
|
|
|
Initial assembler implementation of Mips load address macro
This patch provides initial implementation of load address
macro instruction for Mips. We have implemented two kinds
of expansions with their variations depending on the size
of immediate operand:
1) load address with immediate value directly:
* la d,j => addiu d,$zero,j (for -32768 <= j <= 65535)
* la d,j => lui d,hi16(j)
ori d,d,lo16(j) (for any other 32 bit value of j)
2) load load address with register offset value
* la d,j(s) => addiu d,s,j (for -32768 <= j <= 65535)
* la d,j(s) => lui d,hi16(j) (for any other 32 bit value of j)
ori d,d,lo16(j)
addu d,d,s
This patch does not cover the case when the address is loaded
from the value of the label or function.
Contributer: Vladimir Medic
llvm-svn: 165561
2012-10-10 07:29:45 +08:00
|
|
|
# CHECK: addiu $4, $zero, 20 # encoding: [0x14,0x00,0x04,0x24]
|
|
|
|
# CHECK: lui $7, 1 # encoding: [0x01,0x00,0x07,0x3c]
|
|
|
|
# CHECK: ori $7, $7, 2 # encoding: [0x02,0x00,0xe7,0x34]
|
|
|
|
# CHECK: addiu $4, $5, 20 # encoding: [0x14,0x00,0xa4,0x24]
|
|
|
|
# CHECK: lui $7, 1 # encoding: [0x01,0x00,0x07,0x3c]
|
|
|
|
# CHECK: ori $7, $7, 2 # encoding: [0x02,0x00,0xe7,0x34]
|
|
|
|
# CHECK: addu $7, $7, $8 # encoding: [0x21,0x38,0xe8,0x00]
|
2014-08-14 18:29:17 +08:00
|
|
|
# CHECK: lui $8, %hi(symbol) # encoding: [A,A,0x08,0x3c]
|
|
|
|
# fixup A - offset: 0, value: symbol@ABS_HI, kind: fixup_Mips_HI16
|
|
|
|
# CHECK: ori $8, $8, %lo(symbol) # encoding: [A,A,0x08,0x35]
|
|
|
|
# fixup A - offset: 0, value: symbol@ABS_LO, kind: fixup_Mips_LO16
|
|
|
|
# CHECK: .set mips64
|
|
|
|
# CHECK: lui $8, %highest(symbol) # encoding: [A,A,0x08,0x3c]
|
|
|
|
# fixup A - offset: 0, value: symbol@HIGHEST, kind: fixup_Mips_HIGHEST
|
|
|
|
# CHECK: ori $8, $8, %higher(symbol) # encoding: [A,A,0x08,0x35]
|
|
|
|
# fixup A - offset: 0, value: symbol@HIGHER, kind: fixup_Mips_HIGHER
|
|
|
|
# CHECK: dsll $8, $8, 16 # encoding: [0x38,0x44,0x08,0x00]
|
|
|
|
# CHECK: ori $8, $8, %hi(symbol) # encoding: [A,A,0x08,0x35]
|
|
|
|
# fixup A - offset: 0, value: symbol@ABS_HI, kind: fixup_Mips_HI16
|
|
|
|
# CHECK: dsll $8, $8, 16 # encoding: [0x38,0x44,0x08,0x00]
|
|
|
|
# CHECK: ori $8, $8, %lo(symbol) # encoding: [A,A,0x08,0x35]
|
|
|
|
# fixup A - offset: 0, value: symbol@ABS_LO, kind: fixup_Mips_LO16
|
|
|
|
# CHECK: .set mips32r2
|
2013-03-22 08:05:30 +08:00
|
|
|
# CHECK: lui $10, %hi(symbol) # encoding: [A,A,0x0a,0x3c]
|
|
|
|
# CHECK: # fixup A - offset: 0, value: symbol@ABS_HI, kind: fixup_Mips_HI16
|
|
|
|
# CHECK: addu $10, $10, $4 # encoding: [0x21,0x50,0x44,0x01]
|
|
|
|
# CHECK: lw $10, %lo(symbol)($10) # encoding: [A,A,0x4a,0x8d]
|
|
|
|
# CHECK: # fixup A - offset: 0, value: symbol@ABS_LO, kind: fixup_Mips_LO16
|
|
|
|
# CHECK: lui $1, %hi(symbol) # encoding: [A,A,0x01,0x3c]
|
|
|
|
# CHECK: # fixup A - offset: 0, value: symbol@ABS_HI, kind: fixup_Mips_HI16
|
|
|
|
# CHECK: addu $1, $1, $9 # encoding: [0x21,0x08,0x29,0x00]
|
|
|
|
# CHECK: sw $10, %lo(symbol)($1) # encoding: [A,A,0x2a,0xac]
|
|
|
|
# CHECK: # fixup A - offset: 0, value: symbol@ABS_LO, kind: fixup_Mips_LO16
|
|
|
|
# CHECK: lui $10, 10 # encoding: [0x0a,0x00,0x0a,0x3c]
|
|
|
|
# CHECK: addu $10, $10, $4 # encoding: [0x21,0x50,0x44,0x01]
|
|
|
|
# CHECK: lw $10, 123($10) # encoding: [0x7b,0x00,0x4a,0x8d]
|
|
|
|
# CHECK: lui $1, 2 # encoding: [0x02,0x00,0x01,0x3c]
|
|
|
|
# CHECK: addu $1, $1, $9 # encoding: [0x21,0x08,0x29,0x00]
|
|
|
|
# CHECK: sw $10, 57920($1) # encoding: [0x40,0xe2,0x2a,0xac]
|
Initial assembler implementation of Mips load address macro
This patch provides initial implementation of load address
macro instruction for Mips. We have implemented two kinds
of expansions with their variations depending on the size
of immediate operand:
1) load address with immediate value directly:
* la d,j => addiu d,$zero,j (for -32768 <= j <= 65535)
* la d,j => lui d,hi16(j)
ori d,d,lo16(j) (for any other 32 bit value of j)
2) load load address with register offset value
* la d,j(s) => addiu d,s,j (for -32768 <= j <= 65535)
* la d,j(s) => lui d,hi16(j) (for any other 32 bit value of j)
ori d,d,lo16(j)
addu d,d,s
This patch does not cover the case when the address is loaded
from the value of the label or function.
Contributer: Vladimir Medic
llvm-svn: 165561
2012-10-10 07:29:45 +08:00
|
|
|
|
2015-04-08 21:52:41 +08:00
|
|
|
# CHECK: lui $8, %hi(symbol) # encoding: [A,A,0x08,0x3c]
|
|
|
|
# CHECK: # fixup A - offset: 0, value: symbol@ABS_HI, kind: fixup_Mips_HI16
|
|
|
|
# CHECK-NOT: move $8, $8 # encoding: [0x21,0x40,0x00,0x01]
|
|
|
|
# CHECK: lw $8, %lo(symbol)($8) # encoding: [A,A,0x08,0x8d]
|
|
|
|
# CHECK: # fixup A - offset: 0, value: symbol@ABS_LO, kind: fixup_Mips_LO16
|
|
|
|
# CHECK: lui $1, %hi(symbol) # encoding: [A,A,0x01,0x3c]
|
|
|
|
# CHECK: # fixup A - offset: 0, value: symbol@ABS_HI, kind: fixup_Mips_HI16
|
|
|
|
# CHECK-NOT: move $1, $1 # encoding: [0x21,0x08,0x20,0x00]
|
|
|
|
# CHECK: sw $8, %lo(symbol)($1) # encoding: [A,A,0x28,0xac]
|
|
|
|
# CHECK: # fixup A - offset: 0, value: symbol@ABS_LO, kind: fixup_Mips_LO16
|
|
|
|
|
2014-06-18 22:49:56 +08:00
|
|
|
# CHECK: lui $1, %hi(symbol)
|
|
|
|
# CHECK: ldc1 $f0, %lo(symbol)($1)
|
|
|
|
# CHECK: lui $1, %hi(symbol)
|
|
|
|
# CHECK: sdc1 $f0, %lo(symbol)($1)
|
|
|
|
|
Implement methods that enable expansion of load immediate
macro instruction (li) in the assembler.
We have identified three possible expansions depending on
the size of immediate operand:
1) for 0 ≤ j ≤ 65535.
li d,j =>
ori d,$zero,j
2) for −32768 ≤ j < 0.
li d,j =>
addiu d,$zero,j
3) for any other value of j that is representable as a 32-bit integer.
li d,j =>
lui d,hi16(j)
ori d,d,lo16(j)
All of the above have been implemented in ths patch.
Contributer: Vladimir Medic
llvm-svn: 165199
2012-10-04 12:03:53 +08:00
|
|
|
li $5,123
|
|
|
|
li $6,-2345
|
|
|
|
li $7,65538
|
2014-06-18 21:55:18 +08:00
|
|
|
li $8, ~7
|
Initial assembler implementation of Mips load address macro
This patch provides initial implementation of load address
macro instruction for Mips. We have implemented two kinds
of expansions with their variations depending on the size
of immediate operand:
1) load address with immediate value directly:
* la d,j => addiu d,$zero,j (for -32768 <= j <= 65535)
* la d,j => lui d,hi16(j)
ori d,d,lo16(j) (for any other 32 bit value of j)
2) load load address with register offset value
* la d,j(s) => addiu d,s,j (for -32768 <= j <= 65535)
* la d,j(s) => lui d,hi16(j) (for any other 32 bit value of j)
ori d,d,lo16(j)
addu d,d,s
This patch does not cover the case when the address is loaded
from the value of the label or function.
Contributer: Vladimir Medic
llvm-svn: 165561
2012-10-10 07:29:45 +08:00
|
|
|
|
|
|
|
la $a0, 20
|
|
|
|
la $7,65538
|
|
|
|
la $a0, 20($a1)
|
|
|
|
la $7,65538($8)
|
2014-08-14 18:29:17 +08:00
|
|
|
la $t0, symbol
|
|
|
|
.set mips64
|
|
|
|
la $t0, symbol
|
|
|
|
.set mips32r2
|
2013-03-22 08:05:30 +08:00
|
|
|
|
2014-06-18 22:15:42 +08:00
|
|
|
.set noat
|
2013-03-22 08:05:30 +08:00
|
|
|
lw $t2, symbol($a0)
|
2014-06-18 22:15:42 +08:00
|
|
|
.set at
|
2013-03-22 08:05:30 +08:00
|
|
|
sw $t2, symbol($t1)
|
|
|
|
|
|
|
|
lw $t2, 655483($a0)
|
|
|
|
sw $t2, 123456($t1)
|
2014-06-18 22:49:56 +08:00
|
|
|
|
2015-04-08 21:52:41 +08:00
|
|
|
lw $8, symbol
|
|
|
|
sw $8, symbol
|
|
|
|
|
2014-06-18 22:49:56 +08:00
|
|
|
ldc1 $f0, symbol
|
|
|
|
sdc1 $f0, symbol
|