diff options
author | Paolo Bonzini <pbonzini@redhat.com> | 2015-05-25 11:06:01 +0200 |
---|---|---|
committer | Paolo Bonzini <pbonzini@redhat.com> | 2015-05-25 13:27:03 +0200 |
commit | 4a020bbc0dd5e6025f92b47f829561df249e6cc6 (patch) | |
tree | fef4bd8591e88242a0f03956815276b9d6f9b6e3 /main.c | |
parent | c4b724bd7ca65b8945ef683f33c0aa06152a381f (diff) | |
download | qboot-4a020bbc0dd5e6025f92b47f829561df249e6cc6.zip qboot-4a020bbc0dd5e6025f92b47f829561df249e6cc6.tar.gz qboot-4a020bbc0dd5e6025f92b47f829561df249e6cc6.tar.bz2 |
initialize the southbridge
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'main.c')
-rw-r--r-- | main.c | 70 |
1 files changed, 6 insertions, 64 deletions
@@ -2,54 +2,11 @@ #include "bios.h" #include "stdio.h" #include "e820.h" -#include "pci.h" #include "string.h" #include "segment.h" #include "fw_cfg.h" #include "pflash.h" -#define PCI_VENDOR_ID_INTEL 0x8086 -#define PCI_DEVICE_ID_INTEL_82441 0x1237 -#define PCI_DEVICE_ID_INTEL_Q35_MCH 0x29c0 - -#define I440FX_PAM0 0x59 -#define Q35_HOST_BRIDGE_PAM0 0x90 - -static void make_bios_writable(void) -{ - // NOTE: this runs from ROM at 0xFFFF0000, so it is not possible to use any - // static data. - - const int bdf = 0; - const uint8_t *bios_start = (uint8_t *)0xffff0000; - uint8_t *low_start = (uint8_t *)0xf0000; - int pambase; - - uint32_t id = pci_config_readl(bdf, 0); - if (id == (PCI_VENDOR_ID_INTEL | (PCI_DEVICE_ID_INTEL_82441 << 16))) - pambase = I440FX_PAM0; - else if (id == (PCI_VENDOR_ID_INTEL | (PCI_DEVICE_ID_INTEL_Q35_MCH << 16))) - pambase = Q35_HOST_BRIDGE_PAM0; - else - panic(); - - // Make ram from 0xc0000-0xf0000 read-write - int i; - for (i=0; i<6; i++) { - int pam = pambase + 1 + i; - pci_config_writeb(bdf, pam, 0x33); - } - - // Make ram from 0xf0000-0x100000 read-write and shadow BIOS - // We're still running from 0xffff0000 - pci_config_writeb(bdf, pambase, 0x30); - memcpy(low_start, bios_start, 0x10000); - - // Now go to the F-segment: we need to move away from flash area - // in order to probe CBFS! - asm("ljmp $0x8, $1f; 1:"); -} - static void set_realmode_int(int vec, void *p) { uint16_t *realmode_idt = (uint16_t *) 0; @@ -57,25 +14,6 @@ static void set_realmode_int(int vec, void *p) realmode_idt[vec * 2 + 1] = flat_to_seg16((uintptr_t) p); } -static void setup_pic(void) -{ - /* Send ICW1 (select OCW1 + will send ICW4) */ - outb(0x20, 0x11); - outb(0xa0, 0x11); - /* Send ICW2 (base irqs: 0x08-0x0f for irq0-7, 0x70-0x77 for irq8-15) */ - outb(0x21, 8); - outb(0xa1, 0x70); - /* Send ICW3 (cascaded pic ids) */ - outb(0x21, 0x04); - outb(0xa1, 0x02); - /* Send ICW4 (enable 8086 mode) */ - outb(0x21, 0x01); - outb(0xa1, 0x01); - /* Mask all irqs (except cascaded PIC2 irq) */ - outb(0x21, ~(1 << 2)); - outb(0xa1, ~0); -} - static void setup_idt(void) { int i; @@ -142,8 +80,12 @@ static bool detect_cbfs_and_boot(void) int main(void) { - make_bios_writable(); - setup_pic(); + setup_hw(); + + // Now go to the F-segment: we need to move away from flash area + // in order to probe CBFS! + asm("ljmp $0x8, $1f; 1:"); + setup_idt(); fw_cfg_setup(); extract_acpi(); |