mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-02 07:32:52 +00:00
Added the definitions for one-bit left shifts to
the Intel instruction tables. The patterns will stay blank because ADD reg, reg is faster, but having the encoding available is useful for the disassembler. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@81994 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b6c3385a2d
commit
13cf8e9b82
@ -752,8 +752,10 @@ let isConvertibleToThreeAddress = 1 in // Can transform into LEA.
|
|||||||
def SHL64ri : RIi8<0xC1, MRM4r, (outs GR64:$dst), (ins GR64:$src1, i8imm:$src2),
|
def SHL64ri : RIi8<0xC1, MRM4r, (outs GR64:$dst), (ins GR64:$src1, i8imm:$src2),
|
||||||
"shl{q}\t{$src2, $dst|$dst, $src2}",
|
"shl{q}\t{$src2, $dst|$dst, $src2}",
|
||||||
[(set GR64:$dst, (shl GR64:$src1, (i8 imm:$src2)))]>;
|
[(set GR64:$dst, (shl GR64:$src1, (i8 imm:$src2)))]>;
|
||||||
// NOTE: We don't use shifts of a register by one, because 'add reg,reg' is
|
// NOTE: We don't include patterns for shifts of a register by one, because
|
||||||
// cheaper.
|
// 'add reg,reg' is cheaper.
|
||||||
|
def SHL64r1 : RI<0xD1, MRM4r, (outs GR64:$dst), (ins GR64:$src1),
|
||||||
|
"shr{q}\t$dst", []>;
|
||||||
} // isTwoAddress
|
} // isTwoAddress
|
||||||
|
|
||||||
let Uses = [CL] in
|
let Uses = [CL] in
|
||||||
|
@ -1974,8 +1974,17 @@ def SHL16ri : Ii8<0xC1, MRM4r, (outs GR16:$dst), (ins GR16:$src1, i8imm:$src2),
|
|||||||
def SHL32ri : Ii8<0xC1, MRM4r, (outs GR32:$dst), (ins GR32:$src1, i8imm:$src2),
|
def SHL32ri : Ii8<0xC1, MRM4r, (outs GR32:$dst), (ins GR32:$src1, i8imm:$src2),
|
||||||
"shl{l}\t{$src2, $dst|$dst, $src2}",
|
"shl{l}\t{$src2, $dst|$dst, $src2}",
|
||||||
[(set GR32:$dst, (shl GR32:$src1, (i8 imm:$src2)))]>;
|
[(set GR32:$dst, (shl GR32:$src1, (i8 imm:$src2)))]>;
|
||||||
// NOTE: We don't use shifts of a register by one, because 'add reg,reg' is
|
|
||||||
// cheaper.
|
// NOTE: We don't include patterns for shifts of a register by one, because
|
||||||
|
// 'add reg,reg' is cheaper.
|
||||||
|
|
||||||
|
def SHL8r1 : I<0xD0, MRM4r, (outs GR8:$dst), (ins GR8:$src1),
|
||||||
|
"shl{b}\t$dst", []>;
|
||||||
|
def SHL16r1 : I<0xD1, MRM4r, (outs GR16:$dst), (ins GR16:$src1),
|
||||||
|
"shl{w}\t$dst", []>, OpSize;
|
||||||
|
def SHL32r1 : I<0xD1, MRM4r, (outs GR32:$dst), (ins GR32:$src1),
|
||||||
|
"shl{l}\t$dst", []>;
|
||||||
|
|
||||||
} // isConvertibleToThreeAddress = 1
|
} // isConvertibleToThreeAddress = 1
|
||||||
|
|
||||||
let isTwoAddress = 0 in {
|
let isTwoAddress = 0 in {
|
||||||
|
Loading…
Reference in New Issue
Block a user