aboutsummaryrefslogtreecommitdiff
path: root/target-i386/helper.c
diff options
context:
space:
mode:
authorbellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162>2008-05-21 16:25:27 +0000
committerbellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162>2008-05-21 16:25:27 +0000
commitcec6843e87fe29d8419fd5a9ed9912729c068656 (patch)
tree18655d7ea74f7eae9e230c6a8f0bdcbf4fe302d3 /target-i386/helper.c
parente5097dc8e3beb5cc94d132681db7a2433bdce5a7 (diff)
downloadqemu-cec6843e87fe29d8419fd5a9ed9912729c068656.zip
qemu-cec6843e87fe29d8419fd5a9ed9912729c068656.tar.gz
qemu-cec6843e87fe29d8419fd5a9ed9912729c068656.tar.bz2
converted LSL/LAR/VERW/VERR to TCG - force 16 bit memory access for LSL/LAR
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@4513 c046a42c-6fe2-441c-8c8c-71466251a162
Diffstat (limited to 'target-i386/helper.c')
-rw-r--r--target-i386/helper.c24
1 files changed, 12 insertions, 12 deletions
diff --git a/target-i386/helper.c b/target-i386/helper.c
index 0891ec9..731d7a3 100644
--- a/target-i386/helper.c
+++ b/target-i386/helper.c
@@ -3138,13 +3138,13 @@ void helper_rdmsr(void)
}
#endif
-uint32_t helper_lsl(uint32_t selector)
+target_ulong helper_lsl(target_ulong selector1)
{
unsigned int limit;
- uint32_t e1, e2, eflags;
+ uint32_t e1, e2, eflags, selector;
int rpl, dpl, cpl, type;
- selector &= 0xffff;
+ selector = selector1 & 0xffff;
eflags = cc_table[CC_OP].compute_all();
if (load_segment(&e1, &e2, selector) != 0)
goto fail;
@@ -3181,12 +3181,12 @@ uint32_t helper_lsl(uint32_t selector)
return limit;
}
-uint32_t helper_lar(uint32_t selector)
+target_ulong helper_lar(target_ulong selector1)
{
- uint32_t e1, e2, eflags;
+ uint32_t e1, e2, eflags, selector;
int rpl, dpl, cpl, type;
- selector &= 0xffff;
+ selector = selector1 & 0xffff;
eflags = cc_table[CC_OP].compute_all();
if ((selector & 0xfffc) == 0)
goto fail;
@@ -3227,12 +3227,12 @@ uint32_t helper_lar(uint32_t selector)
return e2 & 0x00f0ff00;
}
-void helper_verr(uint32_t selector)
+void helper_verr(target_ulong selector1)
{
- uint32_t e1, e2, eflags;
+ uint32_t e1, e2, eflags, selector;
int rpl, dpl, cpl;
- selector &= 0xffff;
+ selector = selector1 & 0xffff;
eflags = cc_table[CC_OP].compute_all();
if ((selector & 0xfffc) == 0)
goto fail;
@@ -3260,12 +3260,12 @@ void helper_verr(uint32_t selector)
CC_SRC = eflags | CC_Z;
}
-void helper_verw(uint32_t selector)
+void helper_verw(target_ulong selector1)
{
- uint32_t e1, e2, eflags;
+ uint32_t e1, e2, eflags, selector;
int rpl, dpl, cpl;
- selector &= 0xffff;
+ selector = selector1 & 0xffff;
eflags = cc_table[CC_OP].compute_all();
if ((selector & 0xfffc) == 0)
goto fail;