* fix build without patches.

* create vital ACPI information from the linuxbios device tree.
* pass linuxbios information into dsdt.


git-svn-id: svn://svn.coreboot.org/coreboot/trunk@1911 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
This commit is contained in:
Stefan Reinauer 2005-02-08 09:35:19 +00:00
parent df08a1d196
commit e943fdb178
3 changed files with 2047 additions and 1984 deletions

View file

@ -115,7 +115,7 @@ default LB_CKS_LOC=123
##
default CONFIG_SMP=1
default CONFIG_MAX_CPUS=4
default ALLOW_HT_OVERCLOCKING=1
#default ALLOW_HT_OVERCLOCKING=1
##
## Build code to setup a generic IOAPIC

View file

@ -8,17 +8,18 @@
#include <string.h>
#include <arch/acpi.h>
#include <device/pci.h>
#include <device/pci_ids.h>
extern unsigned char AmlCode[];
extern unsigned char oem_config[];
#define IO_APIC_ADDR 0xfec00000UL
unsigned long acpi_dump_apics(unsigned long current)
{
unsigned int gsi_base=0x18;
unsigned int gsi_base=0x18, ioapic_nr=2;
device_t dev=0;
/* create all subtables for 4p */
/* CPUs are called 1234 in regular bios */
current += acpi_create_madt_lapic((acpi_madt_lapic_t *)current, 0, 16);
current += acpi_create_madt_lapic((acpi_madt_lapic_t *)current, 1, 17);
current += acpi_create_madt_lapic((acpi_madt_lapic_t *)current, 2, 18);
@ -29,21 +30,10 @@ unsigned long acpi_dump_apics(unsigned long current)
IO_APIC_ADDR, 0);
/* Write all 8131 IOAPICs */
/* (8131: bus, dev, fn) , id, version */
ACPI_WRITE_MADT_IOAPIC(0x01,1,1, 2);
ACPI_WRITE_MADT_IOAPIC(0x01,2,1, 3);
ACPI_WRITE_MADT_IOAPIC(0x05,1,1, 4);
ACPI_WRITE_MADT_IOAPIC(0x05,2,1, 5);
ACPI_WRITE_MADT_IOAPIC(0x05,3,1, 6);
ACPI_WRITE_MADT_IOAPIC(0x05,4,1, 7);
ACPI_WRITE_MADT_IOAPIC(0x0c,1,1, 8);
ACPI_WRITE_MADT_IOAPIC(0x0c,2,1, 9);
ACPI_WRITE_MADT_IOAPIC(0x0c,3,1, 10);
ACPI_WRITE_MADT_IOAPIC(0x0c,4,1, 11);
ACPI_WRITE_MADT_IOAPIC(0x11,1,1, 12);
ACPI_WRITE_MADT_IOAPIC(0x11,2,1, 13);
ACPI_WRITE_MADT_IOAPIC(0x11,3,1, 14);
ACPI_WRITE_MADT_IOAPIC(0x11,4,1, 15);
while((dev = dev_find_device(PCI_VENDOR_ID_AMD, 0x7451, dev))) {
ACPI_WRITE_MADT_IOAPIC(dev, ioapic_nr);
ioapic_nr++;
}
current += acpi_create_madt_irqoverride( (acpi_madt_irqoverride_t *)
current, 1, 0, 2, 0 );
@ -54,6 +44,68 @@ unsigned long acpi_dump_apics(unsigned long current)
return current;
}
/* The next two tables are used by our DSDT and are freely defined
* here. This construct is used because the bus numbers containing
* the 8131 bridges may vary so that we need to pass LinuxBIOS
* knowledge into the DSDT
*/
typedef struct lnxc_busses {
u8 secondary;
u8 subordinate;
} acpi_lnxb_busses_t;
typedef struct acpi_lnxb {
struct acpi_table_header header;
acpi_lnxb_busses_t busses[5];
} acpi_lnxb_t;
/* special linuxbios acpi table */
void acpi_create_lnxb(acpi_lnxb_t *lnxb)
{
device_t dev;
int busidx=0;
acpi_header_t *header=&(lnxb->header);
/* fill out header fields */
memcpy(header->signature, "LNXB", 4);
memcpy(header->oem_id, OEM_ID, 6);
memcpy(header->oem_table_id, "LNXBIOS ", 8);
memcpy(header->asl_compiler_id, ASLC, 4);
header->length = sizeof(acpi_lnxb_t);
header->revision = 1;
/*
* Write external 8131 bus ranges
*/
/* first skip the onboard 8131 */
dev=dev_find_device(PCI_VENDOR_ID_AMD, 0x7450, 0);
dev=dev_find_device(PCI_VENDOR_ID_AMD, 0x7450, dev);
/* now look at the last 8131 in each chain,
* as it contains the valid bus ranges
*/
while((dev = dev_find_device(PCI_VENDOR_ID_AMD, 0x7450, dev))
&& busidx<5 ) {
int subu, fn, slot;
acpi_lnxb_busses_t *busses;
if(PCI_SLOT(dev->path.u.pci.devfn)!=4)
continue;
busses=&(lnxb->busses[busidx]);
lnxb->busses[busidx].secondary = dev->bus->secondary;
lnxb->busses[busidx].subordinate =
pci_read_config8(dev, PCI_SUBORDINATE_BUS);
busidx++;
}
header->checksum = acpi_checksum((void *)lnxb, sizeof(acpi_lnxb_t));
}
unsigned long write_acpi_tables(unsigned long start)
{
unsigned long current;
@ -63,9 +115,9 @@ unsigned long write_acpi_tables(unsigned long start)
acpi_madt_t *madt;
acpi_fadt_t *fadt;
acpi_facs_t *facs;
acpi_lnxb_t *lnxb;
acpi_header_t *dsdt;
acpi_header_t *oemb;
/* Align ACPI tables to 16byte */
start = ( start + 0x0f ) & -0x10;
current = start;
@ -102,6 +154,11 @@ unsigned long write_acpi_tables(unsigned long start)
current+=madt->header.length;
acpi_add_table(rsdt,madt);
printk_debug("ACPI: * LNXB\n");
lnxb=(acpi_lnxb_t *)current;
current += sizeof(acpi_facs_t);
acpi_create_lnxb(lnxb);
printk_debug("ACPI: * FACS\n");
facs = (acpi_facs_t *) current;
current += sizeof(acpi_facs_t);
@ -112,12 +169,15 @@ unsigned long write_acpi_tables(unsigned long start)
memcpy((void *)dsdt,(void *)AmlCode, \
((acpi_header_t *)AmlCode)->length);
/* fix up dsdt */
((u32 *)dsdt)[11]=((u32)lnxb)+sizeof(acpi_header_t);
/* recalculate checksum */
dsdt->checksum = 0;
dsdt->checksum = acpi_checksum(dsdt,dsdt->length);
printk_debug("ACPI: * DSDT @ %08x Length %x\n",dsdt,dsdt->length);
printk_debug("ACPI: * FADT\n");
fadt = (acpi_fadt_t *) current;
current += sizeof(acpi_fadt_t);

File diff suppressed because it is too large Load diff