mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-03 01:18:47 +00:00
Disambiguate the *_UPD and * variants by specifying the writeback flag as 1.
This is for the disassembly work. There are cases where this is not possible, for example, A8.6.53 LDM Encoding T1. In such case, we'll use an adhoc approach to deduce the Opcode programmatically. llvm-svn: 98679
This commit is contained in:
parent
b51960824f
commit
54bb1efbe0
@ -1355,7 +1355,9 @@ def LDM_UPD : AXI4ld<(outs GPR:$wb), (ins addrmode4:$addr, pred:$p,
|
|||||||
reglist:$dsts, variable_ops),
|
reglist:$dsts, variable_ops),
|
||||||
IndexModeUpd, LdStMulFrm, IIC_iLoadm,
|
IndexModeUpd, LdStMulFrm, IIC_iLoadm,
|
||||||
"ldm${addr:submode}${p}\t$addr!, $dsts",
|
"ldm${addr:submode}${p}\t$addr!, $dsts",
|
||||||
"$addr.addr = $wb", []>;
|
"$addr.addr = $wb", []> {
|
||||||
|
let Inst{21} = 1; // wback
|
||||||
|
}
|
||||||
} // mayLoad, hasExtraDefRegAllocReq
|
} // mayLoad, hasExtraDefRegAllocReq
|
||||||
|
|
||||||
let mayStore = 1, hasExtraSrcRegAllocReq = 1 in {
|
let mayStore = 1, hasExtraSrcRegAllocReq = 1 in {
|
||||||
@ -1368,7 +1370,9 @@ def STM_UPD : AXI4st<(outs GPR:$wb), (ins addrmode4:$addr, pred:$p,
|
|||||||
reglist:$srcs, variable_ops),
|
reglist:$srcs, variable_ops),
|
||||||
IndexModeUpd, LdStMulFrm, IIC_iStorem,
|
IndexModeUpd, LdStMulFrm, IIC_iStorem,
|
||||||
"stm${addr:submode}${p}\t$addr!, $srcs",
|
"stm${addr:submode}${p}\t$addr!, $srcs",
|
||||||
"$addr.addr = $wb", []>;
|
"$addr.addr = $wb", []> {
|
||||||
|
let Inst{21} = 1; // wback
|
||||||
|
}
|
||||||
} // mayStore, hasExtraSrcRegAllocReq
|
} // mayStore, hasExtraSrcRegAllocReq
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
@ -96,6 +96,7 @@ def VLDMD_UPD : AXDI5<(outs GPR:$wb), (ins addrmode5:$addr, pred:$p,
|
|||||||
IndexModeUpd, IIC_fpLoadm,
|
IndexModeUpd, IIC_fpLoadm,
|
||||||
"vldm${addr:submode}${p}\t${addr:base}!, $dsts",
|
"vldm${addr:submode}${p}\t${addr:base}!, $dsts",
|
||||||
"$addr.base = $wb", []> {
|
"$addr.base = $wb", []> {
|
||||||
|
let Inst{21} = 1; // wback
|
||||||
let Inst{20} = 1;
|
let Inst{20} = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -104,6 +105,7 @@ def VLDMS_UPD : AXSI5<(outs GPR:$wb), (ins addrmode5:$addr, pred:$p,
|
|||||||
IndexModeUpd, IIC_fpLoadm,
|
IndexModeUpd, IIC_fpLoadm,
|
||||||
"vldm${addr:submode}${p}\t${addr:base}!, $dsts",
|
"vldm${addr:submode}${p}\t${addr:base}!, $dsts",
|
||||||
"$addr.base = $wb", []> {
|
"$addr.base = $wb", []> {
|
||||||
|
let Inst{21} = 1; // wback
|
||||||
let Inst{20} = 1;
|
let Inst{20} = 1;
|
||||||
}
|
}
|
||||||
} // mayLoad, hasExtraDefRegAllocReq
|
} // mayLoad, hasExtraDefRegAllocReq
|
||||||
@ -126,6 +128,7 @@ def VSTMD_UPD : AXDI5<(outs GPR:$wb), (ins addrmode5:$addr, pred:$p,
|
|||||||
IndexModeUpd, IIC_fpStorem,
|
IndexModeUpd, IIC_fpStorem,
|
||||||
"vstm${addr:submode}${p}\t${addr:base}!, $srcs",
|
"vstm${addr:submode}${p}\t${addr:base}!, $srcs",
|
||||||
"$addr.base = $wb", []> {
|
"$addr.base = $wb", []> {
|
||||||
|
let Inst{21} = 1; // wback
|
||||||
let Inst{20} = 0;
|
let Inst{20} = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -134,6 +137,7 @@ def VSTMS_UPD : AXSI5<(outs GPR:$wb), (ins addrmode5:$addr, pred:$p,
|
|||||||
IndexModeUpd, IIC_fpStorem,
|
IndexModeUpd, IIC_fpStorem,
|
||||||
"vstm${addr:submode}${p}\t${addr:base}!, $srcs",
|
"vstm${addr:submode}${p}\t${addr:base}!, $srcs",
|
||||||
"$addr.base = $wb", []> {
|
"$addr.base = $wb", []> {
|
||||||
|
let Inst{21} = 1; // wback
|
||||||
let Inst{20} = 0;
|
let Inst{20} = 0;
|
||||||
}
|
}
|
||||||
} // mayStore, hasExtraSrcRegAllocReq
|
} // mayStore, hasExtraSrcRegAllocReq
|
||||||
|
Loading…
Reference in New Issue
Block a user