aboutsummaryrefslogtreecommitdiff
path: root/main.c
diff options
context:
space:
mode:
authorPaolo Bonzini <pbonzini@redhat.com>2015-05-25 11:06:01 +0200
committerPaolo Bonzini <pbonzini@redhat.com>2015-05-25 13:27:03 +0200
commit4a020bbc0dd5e6025f92b47f829561df249e6cc6 (patch)
treefef4bd8591e88242a0f03956815276b9d6f9b6e3 /main.c
parentc4b724bd7ca65b8945ef683f33c0aa06152a381f (diff)
downloadqboot-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.c70
1 files changed, 6 insertions, 64 deletions
diff --git a/main.c b/main.c
index 756cc87..95c33ce 100644
--- a/main.c
+++ b/main.c
@@ -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();