summaryrefslogtreecommitdiff
path: root/tci.c
diff options
context:
space:
mode:
authorStefan Weil <sw@weilnetz.de>2012-03-16 23:50:54 +0100
committerBlue Swirl <blauwirbel@gmail.com>2012-03-17 13:02:03 +0000
commit69784eaec335d09619639db4da6c1e4770290526 (patch)
tree24be5b25208b7cbb780042d544a99ecb216e73ff /tci.c
parent3bf7e40ab9140e577a6e7e17d3f5711b28aed833 (diff)
downloadqemu-69784eaec335d09619639db4da6c1e4770290526.tar.gz
qemu-69784eaec335d09619639db4da6c1e4770290526.tar.bz2
qemu-69784eaec335d09619639db4da6c1e4770290526.zip
w64: Fix data type of next_tb and tcg_qemu_tb_exec
next_tb is the numeric value of a tcg target (= QEMU host) address. Using tcg_target_ulong instead of unsigned long shows this and makes the code portable for hosts with an unusual size of long (w64). The type cast '(long)(next_tb & ~3)' was not needed (casting unsigned long to long does not change the bits, and nor does casting long to pointer for most (= all non w64) hosts. It is removed here. Macro or function tcg_qemu_tb_exec is used to set next_tb. The function also returns next_tb. Therefore tcg_qemu_tb_exec must return a tcg_target_ulong. Signed-off-by: Stefan Weil <sw@weilnetz.de> Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
Diffstat (limited to 'tci.c')
-rw-r--r--tci.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/tci.c b/tci.c
index fb9ebef107..70e7bfb759 100644
--- a/tci.c
+++ b/tci.c
@@ -429,9 +429,9 @@ static bool tci_compare64(uint64_t u0, uint64_t u1, TCGCond condition)
}
/* Interpret pseudo code in tb. */
-unsigned long tcg_qemu_tb_exec(CPUArchState *cpustate, uint8_t *tb_ptr)
+tcg_target_ulong tcg_qemu_tb_exec(CPUArchState *cpustate, uint8_t *tb_ptr)
{
- unsigned long next_tb = 0;
+ tcg_target_ulong next_tb = 0;
env = cpustate;
tci_reg[TCG_AREG0] = (tcg_target_ulong)env;