queued tcg patches
-----BEGIN PGP SIGNATURE----- Version: GnuPG v1 iQEcBAABAgAGBQJV52upAAoJEK0ScMxN0CebDaQIAJ5SzydWuImw1aun5JC+EAcZ GNdc3F2C5kSafgkq8Xxyo5igN7cKFSqPkChvc9hEEMlplsWv7FeA7cV7P7pxnw7a OnxOmbcU3I2GhZ06vbYU7c9dkaToaXQcCiZfkYO99+l1rc8u1K8EVtG43FbxybWj OZ0cC1qwOx/EAjGAM6LCIOxIBIsHkyC52Z62rd6XHdr8J2/IAha8mcz8n+HKbnaN xGnc1/8juQnLfiBuCY+2V2kqdq85oFkGMg9UROIjOt4qsB8aIh+ppmotLq/mxR1Z iAwSuPe8X9qqfEgYoqUG3eUwEdYoICCw7dCBzwWgLKAdcWvF4UqgoRUe7vDntcs= =gL4M -----END PGP SIGNATURE----- Merge remote-tracking branch 'remotes/rth/tags/pull-tcg-20150902' into staging queued tcg patches # gpg: Signature made Wed 02 Sep 2015 22:35:37 BST using RSA key ID 4DD0279B # gpg: Good signature from "Richard Henderson <rth7680@gmail.com>" # gpg: aka "Richard Henderson <rth@redhat.com>" # gpg: aka "Richard Henderson <rth@twiddle.net>" * remotes/rth/tags/pull-tcg-20150902: tcg/i386: omit a few REXW prefixes in softmmu code tcg/aarch64: Fix tcg_out_qemu_{ld, st} for guest_base == 0 Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
561578c2a8
@ -56,6 +56,11 @@ static const int tcg_target_call_oarg_regs[1] = {
|
|||||||
#define TCG_REG_TMP TCG_REG_X30
|
#define TCG_REG_TMP TCG_REG_X30
|
||||||
|
|
||||||
#ifndef CONFIG_SOFTMMU
|
#ifndef CONFIG_SOFTMMU
|
||||||
|
/* Note that XZR cannot be encoded in the address base register slot,
|
||||||
|
as that actaully encodes SP. So if we need to zero-extend the guest
|
||||||
|
address, via the address index register slot, we need to load even
|
||||||
|
a zero guest base into a register. */
|
||||||
|
#define USE_GUEST_BASE (guest_base != 0 || TARGET_LONG_BITS == 32)
|
||||||
#define TCG_REG_GUEST_BASE TCG_REG_X28
|
#define TCG_REG_GUEST_BASE TCG_REG_X28
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1224,9 +1229,13 @@ static void tcg_out_qemu_ld(TCGContext *s, TCGReg data_reg, TCGReg addr_reg,
|
|||||||
add_qemu_ldst_label(s, true, oi, ext, data_reg, addr_reg,
|
add_qemu_ldst_label(s, true, oi, ext, data_reg, addr_reg,
|
||||||
s->code_ptr, label_ptr);
|
s->code_ptr, label_ptr);
|
||||||
#else /* !CONFIG_SOFTMMU */
|
#else /* !CONFIG_SOFTMMU */
|
||||||
tcg_out_qemu_ld_direct(s, memop, ext, data_reg,
|
if (USE_GUEST_BASE) {
|
||||||
guest_base ? TCG_REG_GUEST_BASE : TCG_REG_XZR,
|
tcg_out_qemu_ld_direct(s, memop, ext, data_reg,
|
||||||
otype, addr_reg);
|
TCG_REG_GUEST_BASE, otype, addr_reg);
|
||||||
|
} else {
|
||||||
|
tcg_out_qemu_ld_direct(s, memop, ext, data_reg,
|
||||||
|
addr_reg, TCG_TYPE_I64, TCG_REG_XZR);
|
||||||
|
}
|
||||||
#endif /* CONFIG_SOFTMMU */
|
#endif /* CONFIG_SOFTMMU */
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1245,9 +1254,13 @@ static void tcg_out_qemu_st(TCGContext *s, TCGReg data_reg, TCGReg addr_reg,
|
|||||||
add_qemu_ldst_label(s, false, oi, (memop & MO_SIZE)== MO_64,
|
add_qemu_ldst_label(s, false, oi, (memop & MO_SIZE)== MO_64,
|
||||||
data_reg, addr_reg, s->code_ptr, label_ptr);
|
data_reg, addr_reg, s->code_ptr, label_ptr);
|
||||||
#else /* !CONFIG_SOFTMMU */
|
#else /* !CONFIG_SOFTMMU */
|
||||||
tcg_out_qemu_st_direct(s, memop, data_reg,
|
if (USE_GUEST_BASE) {
|
||||||
guest_base ? TCG_REG_GUEST_BASE : TCG_REG_XZR,
|
tcg_out_qemu_st_direct(s, memop, data_reg,
|
||||||
otype, addr_reg);
|
TCG_REG_GUEST_BASE, otype, addr_reg);
|
||||||
|
} else {
|
||||||
|
tcg_out_qemu_st_direct(s, memop, data_reg,
|
||||||
|
addr_reg, TCG_TYPE_I64, TCG_REG_XZR);
|
||||||
|
}
|
||||||
#endif /* CONFIG_SOFTMMU */
|
#endif /* CONFIG_SOFTMMU */
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1806,7 +1819,7 @@ static void tcg_target_qemu_prologue(TCGContext *s)
|
|||||||
CPU_TEMP_BUF_NLONGS * sizeof(long));
|
CPU_TEMP_BUF_NLONGS * sizeof(long));
|
||||||
|
|
||||||
#if !defined(CONFIG_SOFTMMU)
|
#if !defined(CONFIG_SOFTMMU)
|
||||||
if (guest_base) {
|
if (USE_GUEST_BASE) {
|
||||||
tcg_out_movi(s, TCG_TYPE_PTR, TCG_REG_GUEST_BASE, guest_base);
|
tcg_out_movi(s, TCG_TYPE_PTR, TCG_REG_GUEST_BASE, guest_base);
|
||||||
tcg_regset_set_reg(s->reserved_regs, TCG_REG_GUEST_BASE);
|
tcg_regset_set_reg(s->reserved_regs, TCG_REG_GUEST_BASE);
|
||||||
}
|
}
|
||||||
|
@ -1178,8 +1178,8 @@ static inline void tcg_out_tlb_load(TCGContext *s, TCGReg addrlo, TCGReg addrhi,
|
|||||||
const TCGReg r0 = TCG_REG_L0;
|
const TCGReg r0 = TCG_REG_L0;
|
||||||
const TCGReg r1 = TCG_REG_L1;
|
const TCGReg r1 = TCG_REG_L1;
|
||||||
TCGType ttype = TCG_TYPE_I32;
|
TCGType ttype = TCG_TYPE_I32;
|
||||||
TCGType htype = TCG_TYPE_I32;
|
TCGType tlbtype = TCG_TYPE_I32;
|
||||||
int trexw = 0, hrexw = 0;
|
int trexw = 0, hrexw = 0, tlbrexw = 0;
|
||||||
int s_mask = (1 << (opc & MO_SIZE)) - 1;
|
int s_mask = (1 << (opc & MO_SIZE)) - 1;
|
||||||
bool aligned = (opc & MO_AMASK) == MO_ALIGN || s_mask == 0;
|
bool aligned = (opc & MO_AMASK) == MO_ALIGN || s_mask == 0;
|
||||||
|
|
||||||
@ -1189,12 +1189,15 @@ static inline void tcg_out_tlb_load(TCGContext *s, TCGReg addrlo, TCGReg addrhi,
|
|||||||
trexw = P_REXW;
|
trexw = P_REXW;
|
||||||
}
|
}
|
||||||
if (TCG_TYPE_PTR == TCG_TYPE_I64) {
|
if (TCG_TYPE_PTR == TCG_TYPE_I64) {
|
||||||
htype = TCG_TYPE_I64;
|
|
||||||
hrexw = P_REXW;
|
hrexw = P_REXW;
|
||||||
|
if (TARGET_PAGE_BITS + CPU_TLB_BITS > 32) {
|
||||||
|
tlbtype = TCG_TYPE_I64;
|
||||||
|
tlbrexw = P_REXW;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tcg_out_mov(s, htype, r0, addrlo);
|
tcg_out_mov(s, tlbtype, r0, addrlo);
|
||||||
if (aligned) {
|
if (aligned) {
|
||||||
tcg_out_mov(s, ttype, r1, addrlo);
|
tcg_out_mov(s, ttype, r1, addrlo);
|
||||||
} else {
|
} else {
|
||||||
@ -1203,12 +1206,12 @@ static inline void tcg_out_tlb_load(TCGContext *s, TCGReg addrlo, TCGReg addrhi,
|
|||||||
tcg_out_modrm_offset(s, OPC_LEA + trexw, r1, addrlo, s_mask);
|
tcg_out_modrm_offset(s, OPC_LEA + trexw, r1, addrlo, s_mask);
|
||||||
}
|
}
|
||||||
|
|
||||||
tcg_out_shifti(s, SHIFT_SHR + hrexw, r0,
|
tcg_out_shifti(s, SHIFT_SHR + tlbrexw, r0,
|
||||||
TARGET_PAGE_BITS - CPU_TLB_ENTRY_BITS);
|
TARGET_PAGE_BITS - CPU_TLB_ENTRY_BITS);
|
||||||
|
|
||||||
tgen_arithi(s, ARITH_AND + trexw, r1,
|
tgen_arithi(s, ARITH_AND + trexw, r1,
|
||||||
TARGET_PAGE_MASK | (aligned ? s_mask : 0), 0);
|
TARGET_PAGE_MASK | (aligned ? s_mask : 0), 0);
|
||||||
tgen_arithi(s, ARITH_AND + hrexw, r0,
|
tgen_arithi(s, ARITH_AND + tlbrexw, r0,
|
||||||
(CPU_TLB_SIZE - 1) << CPU_TLB_ENTRY_BITS, 0);
|
(CPU_TLB_SIZE - 1) << CPU_TLB_ENTRY_BITS, 0);
|
||||||
|
|
||||||
tcg_out_modrm_sib_offset(s, OPC_LEA + hrexw, r0, TCG_AREG0, r0, 0,
|
tcg_out_modrm_sib_offset(s, OPC_LEA + hrexw, r0, TCG_AREG0, r0, 0,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user