2008-08-21 03:14:29 +00:00
|
|
|
--- bochs-2.3.7.orig/bios/rombios.h
|
|
|
|
+++ bochs-2.3.7/bios/rombios.h
|
|
|
|
@@ -19,7 +19,7 @@
|
|
|
|
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
|
|
|
|
/* define it to include QEMU specific code */
|
|
|
|
-//#define BX_QEMU
|
|
|
|
+#define BX_QEMU
|
|
|
|
|
|
|
|
#ifndef LEGACY
|
|
|
|
# define BX_ROMBIOS32 1
|
|
|
|
--- bochs-2.3.7.orig/bios/rombios.c
|
|
|
|
+++ bochs-2.3.7/bios/rombios.c
|
|
|
|
@@ -4404,22 +4404,25 @@
|
2008-04-22 20:37:21 +00:00
|
|
|
#endif // BX_USE_PS2_MOUSE
|
2008-04-27 23:46:00 +00:00
|
|
|
|
|
|
|
|
2008-04-22 20:37:21 +00:00
|
|
|
-void set_e820_range(ES, DI, start, end, type)
|
|
|
|
+void set_e820_range(ES, DI, start, end, extra_start, extra_end, type)
|
|
|
|
Bit16u ES;
|
|
|
|
Bit16u DI;
|
|
|
|
Bit32u start;
|
|
|
|
Bit32u end;
|
|
|
|
+ Bit8u extra_start;
|
|
|
|
+ Bit8u extra_end;
|
|
|
|
Bit16u type;
|
|
|
|
{
|
|
|
|
write_word(ES, DI, start);
|
|
|
|
write_word(ES, DI+2, start >> 16);
|
|
|
|
- write_word(ES, DI+4, 0x00);
|
|
|
|
+ write_word(ES, DI+4, extra_start);
|
|
|
|
write_word(ES, DI+6, 0x00);
|
2008-04-27 23:46:00 +00:00
|
|
|
|
2008-04-22 20:37:21 +00:00
|
|
|
end -= start;
|
|
|
|
+ extra_end -= extra_start;
|
|
|
|
write_word(ES, DI+8, end);
|
|
|
|
write_word(ES, DI+10, end >> 16);
|
|
|
|
- write_word(ES, DI+12, 0x0000);
|
|
|
|
+ write_word(ES, DI+12, extra_end);
|
|
|
|
write_word(ES, DI+14, 0x0000);
|
2008-04-27 23:46:00 +00:00
|
|
|
|
2008-04-22 20:37:21 +00:00
|
|
|
write_word(ES, DI+16, type);
|
2008-08-21 03:14:29 +00:00
|
|
|
@@ -4432,7 +4435,9 @@
|
2008-04-22 20:37:21 +00:00
|
|
|
Bit16u ES, DS, FLAGS;
|
|
|
|
{
|
|
|
|
Bit32u extended_memory_size=0; // 64bits long
|
|
|
|
+ Bit32u extra_lowbits_memory_size=0;
|
|
|
|
Bit16u CX,DX;
|
|
|
|
+ Bit8u extra_highbits_memory_size=0;
|
2008-04-27 23:46:00 +00:00
|
|
|
|
2008-04-22 20:37:21 +00:00
|
|
|
BX_DEBUG_INT15("int15 AX=%04x\n",regs.u.r16.ax);
|
2008-04-27 23:46:00 +00:00
|
|
|
|
2008-08-21 03:14:29 +00:00
|
|
|
@@ -4506,11 +4511,18 @@
|
2008-04-22 20:37:21 +00:00
|
|
|
extended_memory_size += (1L * 1024 * 1024);
|
|
|
|
}
|
2008-04-27 23:46:00 +00:00
|
|
|
|
2008-04-22 20:37:21 +00:00
|
|
|
+ extra_lowbits_memory_size = inb_cmos(0x5c);
|
|
|
|
+ extra_lowbits_memory_size <<= 8;
|
|
|
|
+ extra_lowbits_memory_size |= inb_cmos(0x5b);
|
|
|
|
+ extra_lowbits_memory_size *= 64;
|
|
|
|
+ extra_lowbits_memory_size *= 1024;
|
|
|
|
+ extra_highbits_memory_size = inb_cmos(0x5d);
|
|
|
|
+
|
|
|
|
switch(regs.u.r16.bx)
|
|
|
|
{
|
|
|
|
case 0:
|
|
|
|
set_e820_range(ES, regs.u.r16.di,
|
|
|
|
- 0x0000000L, 0x0009fc00L, 1);
|
|
|
|
+ 0x0000000L, 0x0009fc00L, 0, 0, 1);
|
|
|
|
regs.u.r32.ebx = 1;
|
|
|
|
regs.u.r32.eax = 0x534D4150;
|
|
|
|
regs.u.r32.ecx = 0x14;
|
2008-08-21 03:14:29 +00:00
|
|
|
@@ -4519,7 +4531,7 @@
|
2008-04-22 20:37:21 +00:00
|
|
|
break;
|
|
|
|
case 1:
|
|
|
|
set_e820_range(ES, regs.u.r16.di,
|
|
|
|
- 0x0009fc00L, 0x000a0000L, 2);
|
|
|
|
+ 0x0009fc00L, 0x000a0000L, 0, 0, 2);
|
|
|
|
regs.u.r32.ebx = 2;
|
|
|
|
regs.u.r32.eax = 0x534D4150;
|
|
|
|
regs.u.r32.ecx = 0x14;
|
2008-08-21 03:14:29 +00:00
|
|
|
@@ -4528,7 +4540,7 @@
|
2008-04-22 20:37:21 +00:00
|
|
|
break;
|
|
|
|
case 2:
|
|
|
|
set_e820_range(ES, regs.u.r16.di,
|
|
|
|
- 0x000e8000L, 0x00100000L, 2);
|
|
|
|
+ 0x000e8000L, 0x00100000L, 0, 0, 2);
|
|
|
|
regs.u.r32.ebx = 3;
|
|
|
|
regs.u.r32.eax = 0x534D4150;
|
|
|
|
regs.u.r32.ecx = 0x14;
|
2008-08-21 03:14:29 +00:00
|
|
|
@@ -4539,7 +4551,7 @@
|
2008-04-27 23:46:00 +00:00
|
|
|
#if BX_ROMBIOS32
|
2008-04-22 20:37:21 +00:00
|
|
|
set_e820_range(ES, regs.u.r16.di,
|
|
|
|
0x00100000L,
|
|
|
|
- extended_memory_size - ACPI_DATA_SIZE, 1);
|
|
|
|
+ extended_memory_size - ACPI_DATA_SIZE ,0, 0, 1);
|
|
|
|
regs.u.r32.ebx = 4;
|
2008-04-27 23:46:00 +00:00
|
|
|
#else
|
|
|
|
set_e820_range(ES, regs.u.r16.di,
|
2008-08-21 03:14:29 +00:00
|
|
|
@@ -4555,7 +4567,7 @@
|
2008-04-22 20:37:21 +00:00
|
|
|
case 4:
|
|
|
|
set_e820_range(ES, regs.u.r16.di,
|
|
|
|
extended_memory_size - ACPI_DATA_SIZE,
|
|
|
|
- extended_memory_size, 3); // ACPI RAM
|
|
|
|
+ extended_memory_size ,0, 0, 3); // ACPI RAM
|
|
|
|
regs.u.r32.ebx = 5;
|
|
|
|
regs.u.r32.eax = 0x534D4150;
|
|
|
|
regs.u.r32.ecx = 0x14;
|
2008-08-21 03:14:29 +00:00
|
|
|
@@ -4565,7 +4577,20 @@
|
2008-04-22 20:37:21 +00:00
|
|
|
case 5:
|
|
|
|
/* 256KB BIOS area at the end of 4 GB */
|
|
|
|
set_e820_range(ES, regs.u.r16.di,
|
|
|
|
- 0xfffc0000L, 0x00000000L, 2);
|
|
|
|
+ 0xfffc0000L, 0x00000000L ,0, 0, 2);
|
|
|
|
+ if (extra_highbits_memory_size || extra_lowbits_memory_size)
|
|
|
|
+ regs.u.r32.ebx = 6;
|
|
|
|
+ else
|
|
|
|
+ regs.u.r32.ebx = 0;
|
|
|
|
+ regs.u.r32.eax = 0x534D4150;
|
|
|
|
+ regs.u.r32.ecx = 0x14;
|
|
|
|
+ CLEAR_CF();
|
|
|
|
+ return;
|
|
|
|
+ case 6:
|
|
|
|
+ /* Maping of memory above 4 GB */
|
|
|
|
+ set_e820_range(ES, regs.u.r16.di, 0x00000000L,
|
|
|
|
+ extra_lowbits_memory_size, 1, extra_highbits_memory_size
|
|
|
|
+ + 1, 1);
|
|
|
|
regs.u.r32.ebx = 0;
|
|
|
|
regs.u.r32.eax = 0x534D4150;
|
|
|
|
regs.u.r32.ecx = 0x14;
|
2008-08-21 03:14:29 +00:00
|
|
|
--- bochs-2.3.7.orig/bios/rombios32.c
|
|
|
|
+++ bochs-2.3.7/bios/rombios32.c
|
|
|
|
@@ -479,7 +479,12 @@
|
2008-03-28 22:28:30 +00:00
|
|
|
sipi_vector = AP_BOOT_ADDR >> 12;
|
|
|
|
writel(APIC_BASE + APIC_ICR_LOW, 0x000C4600 | sipi_vector);
|
2006-10-01 16:08:15 +00:00
|
|
|
|
2008-03-28 22:28:30 +00:00
|
|
|
+#ifndef BX_QEMU
|
|
|
|
delay_ms(10);
|
|
|
|
+#else
|
|
|
|
+ while (cmos_readb(0x5f) + 1 != readw((void *)CPU_COUNT_ADDR))
|
|
|
|
+ ;
|
2006-10-02 18:35:39 +00:00
|
|
|
+#endif
|
2008-03-28 22:28:30 +00:00
|
|
|
|
|
|
|
smp_cpus = readw((void *)CPU_COUNT_ADDR);
|
|
|
|
}
|