tcg/riscv: Remove TARGET_LONG_BITS, TCG_TYPE_TL
All uses replaced with TCGContext.addr_type. Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
parent
79ee1b4d44
commit
8aefe1fb8a
@ -1195,6 +1195,7 @@ static TCGLabelQemuLdst *prepare_host_addr(TCGContext *s, TCGReg *pbase,
|
|||||||
TCGReg addr_reg, MemOpIdx oi,
|
TCGReg addr_reg, MemOpIdx oi,
|
||||||
bool is_ld)
|
bool is_ld)
|
||||||
{
|
{
|
||||||
|
TCGType addr_type = s->addr_type;
|
||||||
TCGLabelQemuLdst *ldst = NULL;
|
TCGLabelQemuLdst *ldst = NULL;
|
||||||
MemOp opc = get_memop(oi);
|
MemOp opc = get_memop(oi);
|
||||||
TCGAtomAlign aa;
|
TCGAtomAlign aa;
|
||||||
@ -1236,19 +1237,19 @@ static TCGLabelQemuLdst *prepare_host_addr(TCGContext *s, TCGReg *pbase,
|
|||||||
addr_adj = addr_reg;
|
addr_adj = addr_reg;
|
||||||
if (a_mask < s_mask) {
|
if (a_mask < s_mask) {
|
||||||
addr_adj = TCG_REG_TMP0;
|
addr_adj = TCG_REG_TMP0;
|
||||||
tcg_out_opc_imm(s, TARGET_LONG_BITS == 32 ? OPC_ADDIW : OPC_ADDI,
|
tcg_out_opc_imm(s, addr_type == TCG_TYPE_I32 ? OPC_ADDIW : OPC_ADDI,
|
||||||
addr_adj, addr_reg, s_mask - a_mask);
|
addr_adj, addr_reg, s_mask - a_mask);
|
||||||
}
|
}
|
||||||
compare_mask = s->page_mask | a_mask;
|
compare_mask = s->page_mask | a_mask;
|
||||||
if (compare_mask == sextreg(compare_mask, 0, 12)) {
|
if (compare_mask == sextreg(compare_mask, 0, 12)) {
|
||||||
tcg_out_opc_imm(s, OPC_ANDI, TCG_REG_TMP1, addr_adj, compare_mask);
|
tcg_out_opc_imm(s, OPC_ANDI, TCG_REG_TMP1, addr_adj, compare_mask);
|
||||||
} else {
|
} else {
|
||||||
tcg_out_movi(s, TCG_TYPE_TL, TCG_REG_TMP1, compare_mask);
|
tcg_out_movi(s, addr_type, TCG_REG_TMP1, compare_mask);
|
||||||
tcg_out_opc_reg(s, OPC_AND, TCG_REG_TMP1, TCG_REG_TMP1, addr_adj);
|
tcg_out_opc_reg(s, OPC_AND, TCG_REG_TMP1, TCG_REG_TMP1, addr_adj);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Load the tlb comparator and the addend. */
|
/* Load the tlb comparator and the addend. */
|
||||||
tcg_out_ld(s, TCG_TYPE_TL, TCG_REG_TMP0, TCG_REG_TMP2,
|
tcg_out_ld(s, addr_type, TCG_REG_TMP0, TCG_REG_TMP2,
|
||||||
is_ld ? offsetof(CPUTLBEntry, addr_read)
|
is_ld ? offsetof(CPUTLBEntry, addr_read)
|
||||||
: offsetof(CPUTLBEntry, addr_write));
|
: offsetof(CPUTLBEntry, addr_write));
|
||||||
tcg_out_ld(s, TCG_TYPE_PTR, TCG_REG_TMP2, TCG_REG_TMP2,
|
tcg_out_ld(s, TCG_TYPE_PTR, TCG_REG_TMP2, TCG_REG_TMP2,
|
||||||
@ -1259,7 +1260,7 @@ static TCGLabelQemuLdst *prepare_host_addr(TCGContext *s, TCGReg *pbase,
|
|||||||
tcg_out_opc_branch(s, OPC_BNE, TCG_REG_TMP0, TCG_REG_TMP1, 0);
|
tcg_out_opc_branch(s, OPC_BNE, TCG_REG_TMP0, TCG_REG_TMP1, 0);
|
||||||
|
|
||||||
/* TLB Hit - translate address using addend. */
|
/* TLB Hit - translate address using addend. */
|
||||||
if (TARGET_LONG_BITS == 64) {
|
if (addr_type != TCG_TYPE_I32) {
|
||||||
tcg_out_opc_reg(s, OPC_ADD, TCG_REG_TMP0, addr_reg, TCG_REG_TMP2);
|
tcg_out_opc_reg(s, OPC_ADD, TCG_REG_TMP0, addr_reg, TCG_REG_TMP2);
|
||||||
} else if (have_zba) {
|
} else if (have_zba) {
|
||||||
tcg_out_opc_reg(s, OPC_ADD_UW, TCG_REG_TMP0, addr_reg, TCG_REG_TMP2);
|
tcg_out_opc_reg(s, OPC_ADD_UW, TCG_REG_TMP0, addr_reg, TCG_REG_TMP2);
|
||||||
@ -1287,7 +1288,7 @@ static TCGLabelQemuLdst *prepare_host_addr(TCGContext *s, TCGReg *pbase,
|
|||||||
|
|
||||||
if (guest_base != 0) {
|
if (guest_base != 0) {
|
||||||
base = TCG_REG_TMP0;
|
base = TCG_REG_TMP0;
|
||||||
if (TARGET_LONG_BITS == 64) {
|
if (addr_type != TCG_TYPE_I32) {
|
||||||
tcg_out_opc_reg(s, OPC_ADD, base, addr_reg, TCG_GUEST_BASE_REG);
|
tcg_out_opc_reg(s, OPC_ADD, base, addr_reg, TCG_GUEST_BASE_REG);
|
||||||
} else if (have_zba) {
|
} else if (have_zba) {
|
||||||
tcg_out_opc_reg(s, OPC_ADD_UW, base, addr_reg, TCG_GUEST_BASE_REG);
|
tcg_out_opc_reg(s, OPC_ADD_UW, base, addr_reg, TCG_GUEST_BASE_REG);
|
||||||
@ -1295,7 +1296,7 @@ static TCGLabelQemuLdst *prepare_host_addr(TCGContext *s, TCGReg *pbase,
|
|||||||
tcg_out_ext32u(s, base, addr_reg);
|
tcg_out_ext32u(s, base, addr_reg);
|
||||||
tcg_out_opc_reg(s, OPC_ADD, base, base, TCG_GUEST_BASE_REG);
|
tcg_out_opc_reg(s, OPC_ADD, base, base, TCG_GUEST_BASE_REG);
|
||||||
}
|
}
|
||||||
} else if (TARGET_LONG_BITS == 64) {
|
} else if (addr_type != TCG_TYPE_I32) {
|
||||||
base = addr_reg;
|
base = addr_reg;
|
||||||
} else {
|
} else {
|
||||||
base = TCG_REG_TMP0;
|
base = TCG_REG_TMP0;
|
||||||
|
Loading…
Reference in New Issue
Block a user