diff options
| -rw-r--r-- | meta/recipes-devtools/qemu/files/target-i386-Fix-aflag-logic-for-CODE64-and-the-0x67-.patch | 79 | ||||
| -rw-r--r-- | meta/recipes-devtools/qemu/qemu_1.5.0.bb | 3 |
2 files changed, 81 insertions, 1 deletions
diff --git a/meta/recipes-devtools/qemu/files/target-i386-Fix-aflag-logic-for-CODE64-and-the-0x67-.patch b/meta/recipes-devtools/qemu/files/target-i386-Fix-aflag-logic-for-CODE64-and-the-0x67-.patch new file mode 100644 index 0000000000..852efd1cc9 --- /dev/null +++ b/meta/recipes-devtools/qemu/files/target-i386-Fix-aflag-logic-for-CODE64-and-the-0x67-.patch | |||
| @@ -0,0 +1,79 @@ | |||
| 1 | Upstream-Status: Backported | ||
| 2 | |||
| 3 | From dec3fc9657e0682637de4d5a29d947284d01985c Mon Sep 17 00:00:00 2001 | ||
| 4 | From: Richard Henderson <rth@twiddle.net> | ||
| 5 | Date: Wed, 29 May 2013 12:30:51 -0700 | ||
| 6 | Subject: [PATCH] target-i386: Fix aflag logic for CODE64 and the 0x67 prefix | ||
| 7 | |||
| 8 | The code reorganization in commit 4a6fd938 broke handling of PREFIX_ADR. | ||
| 9 | While fixing this, tidy and comment the code so that it's more obvious | ||
| 10 | what's going on in setting both aflag and dflag. | ||
| 11 | |||
| 12 | The TARGET_X86_64 ifdef can be eliminated because CODE64 expands to the | ||
| 13 | constant zero when TARGET_X86_64 is undefined. | ||
| 14 | |||
| 15 | Cc: Paolo Bonzini <pbonzini@redhat.com> | ||
| 16 | Reported-by: Laszlo Ersek <lersek@redhat.com> | ||
| 17 | Signed-off-by: Richard Henderson <rth@twiddle.net> | ||
| 18 | Reviewed-by: Paolo Bonzini <pbonzini@redhat.com> | ||
| 19 | Message-id: 1369855851-21400-1-git-send-email-rth@twiddle.net | ||
| 20 | Signed-off-by: Anthony Liguori <aliguori@us.ibm.com> | ||
| 21 | --- | ||
| 22 | target-i386/translate.c | 30 +++++++++++++++--------------- | ||
| 23 | 1 file changed, 15 insertions(+), 15 deletions(-) | ||
| 24 | |||
| 25 | diff --git a/target-i386/translate.c b/target-i386/translate.c | ||
| 26 | index 0aeccdb..14b0298 100644 | ||
| 27 | --- a/target-i386/translate.c | ||
| 28 | +++ b/target-i386/translate.c | ||
| 29 | @@ -4677,8 +4677,6 @@ static target_ulong disas_insn(CPUX86State *env, DisasContext *s, | ||
| 30 | } | ||
| 31 | s->pc = pc_start; | ||
| 32 | prefixes = 0; | ||
| 33 | - aflag = s->code32; | ||
| 34 | - dflag = s->code32; | ||
| 35 | s->override = -1; | ||
| 36 | rex_w = -1; | ||
| 37 | rex_r = 0; | ||
| 38 | @@ -4801,23 +4799,25 @@ static target_ulong disas_insn(CPUX86State *env, DisasContext *s, | ||
| 39 | } | ||
| 40 | |||
| 41 | /* Post-process prefixes. */ | ||
| 42 | - if (prefixes & PREFIX_DATA) { | ||
| 43 | - dflag ^= 1; | ||
| 44 | - } | ||
| 45 | - if (prefixes & PREFIX_ADR) { | ||
| 46 | - aflag ^= 1; | ||
| 47 | - } | ||
| 48 | -#ifdef TARGET_X86_64 | ||
| 49 | if (CODE64(s)) { | ||
| 50 | - if (rex_w == 1) { | ||
| 51 | - /* 0x66 is ignored if rex.w is set */ | ||
| 52 | - dflag = 2; | ||
| 53 | + /* In 64-bit mode, the default data size is 32-bit. Select 64-bit | ||
| 54 | + data with rex_w, and 16-bit data with 0x66; rex_w takes precedence | ||
| 55 | + over 0x66 if both are present. */ | ||
| 56 | + dflag = (rex_w > 0 ? 2 : prefixes & PREFIX_DATA ? 0 : 1); | ||
| 57 | + /* In 64-bit mode, 0x67 selects 32-bit addressing. */ | ||
| 58 | + aflag = (prefixes & PREFIX_ADR ? 1 : 2); | ||
| 59 | + } else { | ||
| 60 | + /* In 16/32-bit mode, 0x66 selects the opposite data size. */ | ||
| 61 | + dflag = s->code32; | ||
| 62 | + if (prefixes & PREFIX_DATA) { | ||
| 63 | + dflag ^= 1; | ||
| 64 | } | ||
| 65 | - if (!(prefixes & PREFIX_ADR)) { | ||
| 66 | - aflag = 2; | ||
| 67 | + /* In 16/32-bit mode, 0x67 selects the opposite addressing. */ | ||
| 68 | + aflag = s->code32; | ||
| 69 | + if (prefixes & PREFIX_ADR) { | ||
| 70 | + aflag ^= 1; | ||
| 71 | } | ||
| 72 | } | ||
| 73 | -#endif | ||
| 74 | |||
| 75 | s->prefix = prefixes; | ||
| 76 | s->aflag = aflag; | ||
| 77 | -- | ||
| 78 | 1.7.9.5 | ||
| 79 | |||
diff --git a/meta/recipes-devtools/qemu/qemu_1.5.0.bb b/meta/recipes-devtools/qemu/qemu_1.5.0.bb index 2ea4f12031..9b9d0d7e5d 100644 --- a/meta/recipes-devtools/qemu/qemu_1.5.0.bb +++ b/meta/recipes-devtools/qemu/qemu_1.5.0.bb | |||
| @@ -3,7 +3,8 @@ require qemu.inc | |||
| 3 | LIC_FILES_CHKSUM = "file://COPYING;md5=441c28d2cf86e15a37fa47e15a72fbac \ | 3 | LIC_FILES_CHKSUM = "file://COPYING;md5=441c28d2cf86e15a37fa47e15a72fbac \ |
| 4 | file://COPYING.LIB;endline=24;md5=c04def7ae38850e7d3ef548588159913" | 4 | file://COPYING.LIB;endline=24;md5=c04def7ae38850e7d3ef548588159913" |
| 5 | 5 | ||
| 6 | SRC_URI += "file://fdt_header.patch" | 6 | SRC_URI += "file://fdt_header.patch \ |
| 7 | file://target-i386-Fix-aflag-logic-for-CODE64-and-the-0x67-.patch" | ||
| 7 | 8 | ||
| 8 | SRC_URI_prepend = "http://wiki.qemu.org/download/qemu-${PV}.tar.bz2" | 9 | SRC_URI_prepend = "http://wiki.qemu.org/download/qemu-${PV}.tar.bz2" |
| 9 | SRC_URI[md5sum] = "b6f3265b8ed39d77e8f354f35cc26e16" | 10 | SRC_URI[md5sum] = "b6f3265b8ed39d77e8f354f35cc26e16" |
