OSDN Git Service

ARM host: fix generated blocks linking
authorLaurent Desnogues <laurent.desnogues@gmail.com>
Mon, 21 Sep 2009 12:27:59 +0000 (14:27 +0200)
committerAurelien Jarno <aurelien@aurel32.net>
Fri, 25 Sep 2009 15:25:37 +0000 (17:25 +0200)
This patch fixes the linking of generated blocks on an ARM host.
No need to say this brings a very nice speedup :-)

Signed-off-by: Laurent Desnogues <laurent.desnogues@gmail.com>
Signed-off-by: Aurelien Jarno <aurelien@aurel32.net>
exec-all.h

index 93e0b5d..dd134a9 100644 (file)
@@ -208,7 +208,9 @@ static inline void tb_set_jmp_target1(unsigned long jmp_addr, unsigned long addr
 #endif
 
     /* we could use a ldr pc, [pc, #-4] kind of branch and avoid the flush */
-    *(uint32_t *)jmp_addr |= ((addr - (jmp_addr + 8)) >> 2) & 0xffffff;
+    *(uint32_t *)jmp_addr =
+        (*(uint32_t *)jmp_addr & ~0xffffff)
+        | (((addr - (jmp_addr + 8)) >> 2) & 0xffffff);
 
 #if QEMU_GNUC_PREREQ(4, 1)
     __clear_cache((char *) jmp_addr, (char *) jmp_addr + 4);