aboutsummaryrefslogtreecommitdiffstats
path: root/tools/firmware
diff options
context:
space:
mode:
authorKeir Fraser <keir@xen.org>2011-08-09 11:33:40 +0100
committerKeir Fraser <keir@xen.org>2011-08-09 11:33:40 +0100
commitab6e985fae87d9d84cc8bd072043b8674d8e3a70 (patch)
tree3495674fa9f55b3345fad89e120b9773b127a58c /tools/firmware
parent2346303a425b8adcea86397e49739c8ab206903d (diff)
downloadxen-ab6e985fae87d9d84cc8bd072043b8674d8e3a70.tar.gz
xen-ab6e985fae87d9d84cc8bd072043b8674d8e3a70.tar.bz2
xen-ab6e985fae87d9d84cc8bd072043b8674d8e3a70.zip
hvmloader: Move init_vm86_tss() back into common code.
It is not BIOS specific. Signed-off-by: Keir Fraser <keir@xen.org>
Diffstat (limited to 'tools/firmware')
-rw-r--r--tools/firmware/hvmloader/config.h1
-rw-r--r--tools/firmware/hvmloader/hvmloader.c22
-rw-r--r--tools/firmware/hvmloader/rombios.c20
-rw-r--r--tools/firmware/hvmloader/seabios.c1
4 files changed, 20 insertions, 24 deletions
diff --git a/tools/firmware/hvmloader/config.h b/tools/firmware/hvmloader/config.h
index eb91611e30..079416613e 100644
--- a/tools/firmware/hvmloader/config.h
+++ b/tools/firmware/hvmloader/config.h
@@ -25,7 +25,6 @@ struct bios_config {
void (*bios_info_setup)(void);
void (*bios_info_finish)(void);
- void (*vm86_setup)(void);
void (*e820_setup)(void);
void (*acpi_build_tables)(void);
diff --git a/tools/firmware/hvmloader/hvmloader.c b/tools/firmware/hvmloader/hvmloader.c
index 4129670fc7..f5817b31ff 100644
--- a/tools/firmware/hvmloader/hvmloader.c
+++ b/tools/firmware/hvmloader/hvmloader.c
@@ -336,6 +336,25 @@ static void cmos_write_memory_size(void)
cmos_outb(0x35, (uint8_t)( alt_mem >> 8));
}
+/*
+ * Set up an empty TSS area for virtual 8086 mode to use.
+ * The only important thing is that it musn't have any bits set
+ * in the interrupt redirection bitmap, so all zeros will do.
+ */
+static void init_vm86_tss(void)
+{
+ void *tss;
+ struct xen_hvm_param p;
+
+ tss = mem_alloc(128, 128);
+ memset(tss, 0, 128);
+ p.domid = DOMID_SELF;
+ p.index = HVM_PARAM_VM86_TSS;
+ p.value = virt_to_phys(tss);
+ hypercall_hvm_op(HVMOP_set_param, &p);
+ printf("vm86 TSS at %08lx\n", virt_to_phys(tss));
+}
+
static void apic_setup(void)
{
/* Set the IOAPIC ID to the static value used in the MP/ACPI tables. */
@@ -506,8 +525,7 @@ int main(void)
hypercall_hvm_op(HVMOP_set_param, &p);
}
- if ( bios->vm86_setup )
- bios->vm86_setup();
+ init_vm86_tss();
cmos_write_memory_size();
diff --git a/tools/firmware/hvmloader/rombios.c b/tools/firmware/hvmloader/rombios.c
index ba2718f2da..017bd4cacf 100644
--- a/tools/firmware/hvmloader/rombios.c
+++ b/tools/firmware/hvmloader/rombios.c
@@ -40,25 +40,6 @@
#define ROMBIOS_MAXOFFSET 0x0000FFFF
#define ROMBIOS_END (ROMBIOS_BEGIN + ROMBIOS_SIZE)
-/*
- * Set up an empty TSS area for virtual 8086 mode to use.
- * The only important thing is that it musn't have any bits set
- * in the interrupt redirection bitmap, so all zeros will do.
- */
-static void rombios_init_vm86_tss(void)
-{
- void *tss;
- struct xen_hvm_param p;
-
- tss = mem_alloc(128, 128);
- memset(tss, 0, 128);
- p.domid = DOMID_SELF;
- p.index = HVM_PARAM_VM86_TSS;
- p.value = virt_to_phys(tss);
- hypercall_hvm_op(HVMOP_set_param, &p);
- printf("vm86 TSS at %08lx\n", virt_to_phys(tss));
-}
-
static void rombios_setup_e820(void)
{
/*
@@ -178,7 +159,6 @@ struct bios_config rombios_config = {
.bios_info_setup = rombios_setup_bios_info,
.bios_info_finish = NULL,
- .vm86_setup = rombios_init_vm86_tss,
.e820_setup = rombios_setup_e820,
.acpi_build_tables = rombios_acpi_build_tables,
diff --git a/tools/firmware/hvmloader/seabios.c b/tools/firmware/hvmloader/seabios.c
index c633875415..8f4c0a4a42 100644
--- a/tools/firmware/hvmloader/seabios.c
+++ b/tools/firmware/hvmloader/seabios.c
@@ -143,7 +143,6 @@ struct bios_config seabios_config = {
.bios_info_setup = seabios_setup_bios_info,
.bios_info_finish = seabios_finish_bios_info,
- .vm86_setup = NULL,
.e820_setup = seabios_setup_e820,
.acpi_build_tables = seabios_acpi_build_tables,