Commit 1aa36616 authored by Avi Kivity's avatar Avi Kivity

KVM: x86 emulator: consolidate segment accessors

Instead of separate accessors for the segment selector and cached descriptor,
use one accessor for both.  This simplifies the code somewhat.
Signed-off-by: default avatarAvi Kivity <avi@redhat.com>
parent 0a434bb2
...@@ -164,15 +164,10 @@ struct x86_emulate_ops { ...@@ -164,15 +164,10 @@ struct x86_emulate_ops {
int size, unsigned short port, const void *val, int size, unsigned short port, const void *val,
unsigned int count); unsigned int count);
bool (*get_cached_descriptor)(struct x86_emulate_ctxt *ctxt, bool (*get_segment)(struct x86_emulate_ctxt *ctxt, u16 *selector,
struct desc_struct *desc, u32 *base3, struct desc_struct *desc, u32 *base3, int seg);
int seg); void (*set_segment)(struct x86_emulate_ctxt *ctxt, u16 selector,
void (*set_cached_descriptor)(struct x86_emulate_ctxt *ctxt, struct desc_struct *desc, u32 base3, int seg);
struct desc_struct *desc, u32 base3,
int seg);
u16 (*get_segment_selector)(struct x86_emulate_ctxt *ctxt, int seg);
void (*set_segment_selector)(struct x86_emulate_ctxt *ctxt,
u16 sel, int seg);
unsigned long (*get_cached_segment_base)(struct x86_emulate_ctxt *ctxt, unsigned long (*get_cached_segment_base)(struct x86_emulate_ctxt *ctxt,
int seg); int seg);
void (*get_gdt)(struct x86_emulate_ctxt *ctxt, struct desc_ptr *dt); void (*get_gdt)(struct x86_emulate_ctxt *ctxt, struct desc_ptr *dt);
......
This diff is collapsed.
...@@ -4304,13 +4304,14 @@ static unsigned long emulator_get_cached_segment_base( ...@@ -4304,13 +4304,14 @@ static unsigned long emulator_get_cached_segment_base(
return get_segment_base(emul_to_vcpu(ctxt), seg); return get_segment_base(emul_to_vcpu(ctxt), seg);
} }
static bool emulator_get_cached_descriptor(struct x86_emulate_ctxt *ctxt, static bool emulator_get_segment(struct x86_emulate_ctxt *ctxt, u16 *selector,
struct desc_struct *desc, u32 *base3, struct desc_struct *desc, u32 *base3,
int seg) int seg)
{ {
struct kvm_segment var; struct kvm_segment var;
kvm_get_segment(emul_to_vcpu(ctxt), &var, seg); kvm_get_segment(emul_to_vcpu(ctxt), &var, seg);
*selector = var.selector;
if (var.unusable) if (var.unusable)
return false; return false;
...@@ -4335,16 +4336,14 @@ static bool emulator_get_cached_descriptor(struct x86_emulate_ctxt *ctxt, ...@@ -4335,16 +4336,14 @@ static bool emulator_get_cached_descriptor(struct x86_emulate_ctxt *ctxt,
return true; return true;
} }
static void emulator_set_cached_descriptor(struct x86_emulate_ctxt *ctxt, static void emulator_set_segment(struct x86_emulate_ctxt *ctxt, u16 selector,
struct desc_struct *desc, u32 base3, struct desc_struct *desc, u32 base3,
int seg) int seg)
{ {
struct kvm_vcpu *vcpu = emul_to_vcpu(ctxt); struct kvm_vcpu *vcpu = emul_to_vcpu(ctxt);
struct kvm_segment var; struct kvm_segment var;
/* needed to preserve selector */ var.selector = selector;
kvm_get_segment(vcpu, &var, seg);
var.base = get_desc_base(desc); var.base = get_desc_base(desc);
#ifdef CONFIG_X86_64 #ifdef CONFIG_X86_64
var.base |= ((u64)base3) << 32; var.base |= ((u64)base3) << 32;
...@@ -4368,24 +4367,6 @@ static void emulator_set_cached_descriptor(struct x86_emulate_ctxt *ctxt, ...@@ -4368,24 +4367,6 @@ static void emulator_set_cached_descriptor(struct x86_emulate_ctxt *ctxt,
return; return;
} }
static u16 emulator_get_segment_selector(struct x86_emulate_ctxt *ctxt, int seg)
{
struct kvm_segment kvm_seg;
kvm_get_segment(emul_to_vcpu(ctxt), &kvm_seg, seg);
return kvm_seg.selector;
}
static void emulator_set_segment_selector(struct x86_emulate_ctxt *ctxt,
u16 sel, int seg)
{
struct kvm_segment kvm_seg;
kvm_get_segment(emul_to_vcpu(ctxt), &kvm_seg, seg);
kvm_seg.selector = sel;
kvm_set_segment(emul_to_vcpu(ctxt), &kvm_seg, seg);
}
static int emulator_get_msr(struct x86_emulate_ctxt *ctxt, static int emulator_get_msr(struct x86_emulate_ctxt *ctxt,
u32 msr_index, u64 *pdata) u32 msr_index, u64 *pdata)
{ {
...@@ -4436,10 +4417,8 @@ static struct x86_emulate_ops emulate_ops = { ...@@ -4436,10 +4417,8 @@ static struct x86_emulate_ops emulate_ops = {
.invlpg = emulator_invlpg, .invlpg = emulator_invlpg,
.pio_in_emulated = emulator_pio_in_emulated, .pio_in_emulated = emulator_pio_in_emulated,
.pio_out_emulated = emulator_pio_out_emulated, .pio_out_emulated = emulator_pio_out_emulated,
.get_cached_descriptor = emulator_get_cached_descriptor, .get_segment = emulator_get_segment,
.set_cached_descriptor = emulator_set_cached_descriptor, .set_segment = emulator_set_segment,
.get_segment_selector = emulator_get_segment_selector,
.set_segment_selector = emulator_set_segment_selector,
.get_cached_segment_base = emulator_get_cached_segment_base, .get_cached_segment_base = emulator_get_cached_segment_base,
.get_gdt = emulator_get_gdt, .get_gdt = emulator_get_gdt,
.get_idt = emulator_get_idt, .get_idt = emulator_get_idt,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment