]> www.infradead.org Git - users/dwmw2/qemu.git/commitdiff
exec-all: Translate TCI return addresses backwards too
authorPeter Crosthwaite <crosthwaitepeter@gmail.com>
Tue, 18 Aug 2015 03:28:18 +0000 (20:28 -0700)
committerStefan Weil <sw@weilnetz.de>
Wed, 26 Aug 2015 18:50:46 +0000 (20:50 +0200)
This subtraction of return addresses applies directly to TCI as well as
host-TCG. This fixes Linux boots for at least Microblaze, CRIS, ARM and
SH4 when using TCI.

[sw: Removed indentation for preprocessor statement]
[sw: The patch also fixes Linux boot for x86_64]

Reviewed-by: Richard Henderson <rth@twiddle.net>
Signed-off-by: Stefan Weil <sw@weilnetz.de>
Signed-off-by: Peter Crosthwaite <crosthwaite.peter@gmail.com>
include/exec/exec-all.h

index fbc6dcb90caea8d5158afdbd488fc6a28919e868..83b925172f31991512cac844b4ce95a7cf539ebb 100644 (file)
@@ -357,11 +357,7 @@ extern uintptr_t tci_tb_ptr;
    to indicate the compressed mode; subtracting two works around that.  It
    is also the case that there are no host isas that contain a call insn
    smaller than 4 bytes, so we don't worry about special-casing this.  */
-#if defined(CONFIG_TCG_INTERPRETER)
-# define GETPC_ADJ   0
-#else
-# define GETPC_ADJ   2
-#endif
+#define GETPC_ADJ   2
 
 #define GETPC()  (GETRA() - GETPC_ADJ)