sb/intel/i82371eb: Rework ACPI tables
Rework ACPI tables based on a mix of previous work on asus/p2b, other boards in tree with better ACPI support, and OEM BIOS. To be pulled in by DSDTs of mainboards using this southbridge. Disable on-the-fly generation of mainboard _CRS node. It is not working as it should and causes runtime errors when booting Linux. This node to be included in mainboard DSDTs in followup patches. Change-Id: Idda424de7859a36e4cac168d5469f9365a6ad421 Signed-off-by: Keith Hui <buurin@gmail.com> Reviewed-on: https://review.coreboot.org/21671 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Stefan Reinauer <stefan.reinauer@coreboot.org>
This commit is contained in:
parent
9d0aa99c5e
commit
97041de909
2 changed files with 155 additions and 0 deletions
95
src/southbridge/intel/i82371eb/acpi/i82371eb.asl
Normal file
95
src/southbridge/intel/i82371eb/acpi/i82371eb.asl
Normal file
|
@ -0,0 +1,95 @@
|
|||
/*
|
||||
* This file is part of the coreboot project.
|
||||
*
|
||||
* Copyright (C) 2004 Nick Barker <Nick.Barker9@btinternet.com>
|
||||
* Copyright (C) 2007 Rudolf Marek <r.marek@assembler.cz>
|
||||
* Copyright (C) 2017 Keith Hui <buurin@gmail.com>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; version 2 of the License.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*/
|
||||
|
||||
/*
|
||||
* Declares assorted devices that falls under this southbridge.
|
||||
*/
|
||||
#include "southbridge/intel/i82371eb/i82371eb.h"
|
||||
|
||||
OperationRegion (S1XX, PCI_Config, 0xB2, 0x01)
|
||||
Field (S1XX, ByteAcc, NoLock, Preserve)
|
||||
{
|
||||
FXS1, 8
|
||||
}
|
||||
|
||||
/* 8259-compatible Programmable Interrupt Controller */
|
||||
Device (PIC)
|
||||
{
|
||||
Name (_HID, EisaId ("PNP0000") )
|
||||
Name (_CRS, ResourceTemplate ()
|
||||
{
|
||||
IO (Decode16, 0x0020, 0x0020, 0x01, 0x02, )
|
||||
IO (Decode16, 0x00A0, 0x00A0, 0x01, 0x02, )
|
||||
IRQNoFlags () {2}
|
||||
})
|
||||
}
|
||||
|
||||
/* PC-class DMA Controller */
|
||||
Device (DMA1)
|
||||
{
|
||||
Name (_HID, EisaId ("PNP0200") )
|
||||
Name (_CRS, ResourceTemplate ()
|
||||
{
|
||||
DMA (Compatibility, BusMaster, Transfer8, ) {4}
|
||||
IO (Decode16, 0x0000, 0x0000, 0x01, 0x10,)
|
||||
IO (Decode16, 0x0080, 0x0080, 0x01, 0x11,)
|
||||
IO (Decode16, 0x0094, 0x0094, 0x01, 0x0C,)
|
||||
IO (Decode16, 0x00C0, 0x00C0, 0x01, 0x20,)
|
||||
})
|
||||
}
|
||||
|
||||
/* PC-class System Timer */
|
||||
Device (TMR)
|
||||
{
|
||||
Name (_HID, EisaId ("PNP0100"))
|
||||
Name (_CRS, ResourceTemplate ()
|
||||
{
|
||||
IO (Decode16,0x0040,0x0040,0x01,0x04,)
|
||||
IRQNoFlags () {0}
|
||||
})
|
||||
}
|
||||
|
||||
/* AT Real-Time Clock */
|
||||
Device (RTC)
|
||||
{
|
||||
Name (_HID, EisaId ("PNP0B00") )
|
||||
Name (_CRS, ResourceTemplate ()
|
||||
{
|
||||
IO (Decode16,0x0070,0x0070,0x01,0x04,)
|
||||
IRQNoFlags () {8}
|
||||
})
|
||||
}
|
||||
|
||||
Device (SPKR)
|
||||
{
|
||||
Name (_HID, EisaId ("PNP0800"))
|
||||
Name (_CRS, ResourceTemplate ()
|
||||
{
|
||||
IO (Decode16,0x0061,0x0061,0x01,0x01,)
|
||||
})
|
||||
}
|
||||
|
||||
/* x87-compatible Floating Point Processing Unit */
|
||||
Device (COPR)
|
||||
{
|
||||
Name (_HID, EisaId ("PNP0C04") )
|
||||
Name (_CRS, ResourceTemplate ()
|
||||
{
|
||||
IO (Decode16,0x00F0,0x00F0,0x01,0x10,)
|
||||
IRQNoFlags () {13}
|
||||
})
|
||||
}
|
60
src/southbridge/intel/i82371eb/acpi/intx.asl
Normal file
60
src/southbridge/intel/i82371eb/acpi/intx.asl
Normal file
|
@ -0,0 +1,60 @@
|
|||
/*
|
||||
* This file is part of the coreboot project.
|
||||
*
|
||||
* Copyright (C) 2010 Tobias Diedrich <ranma+coreboot@tdiedrich.de>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; version 2 of the License.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*/
|
||||
Name(IRQB, ResourceTemplate(){
|
||||
IRQ(Level,ActiveLow,Shared){}
|
||||
})
|
||||
|
||||
Name(IRQP, ResourceTemplate(){
|
||||
IRQ(Level,ActiveLow,Shared){3, 4, 5, 6, 7, 10, 11, 12, 14, 15}
|
||||
})
|
||||
|
||||
/* adapted from ma78gm/dsdt.asl */
|
||||
#define PCI_INTX_DEV(intx, pinx, uid) \
|
||||
Device(intx) { \
|
||||
Name(_HID, EISAID("PNP0C0F")) \
|
||||
Name(_UID, uid) \
|
||||
\
|
||||
Method(_STA, 0) { \
|
||||
If (And(pinx, 0x80)) { \
|
||||
Return(0x09) \
|
||||
} \
|
||||
Return(0x0B) \
|
||||
} \
|
||||
\
|
||||
Method(_DIS ,0) { \
|
||||
Store(0x80, pinx) \
|
||||
} \
|
||||
\
|
||||
Method(_PRS ,0) { \
|
||||
Return(IRQP) \
|
||||
} \
|
||||
\
|
||||
Method(_CRS ,0) { \
|
||||
CreateWordField(IRQB, 1, IRQN) \
|
||||
ShiftLeft(1, And(pinx, 0x0f), IRQN) \
|
||||
Return(IRQB) \
|
||||
} \
|
||||
\
|
||||
Method(_SRS, 1) { \
|
||||
CreateWordField(ARG0, 1, IRQM) \
|
||||
\
|
||||
/* Use lowest available IRQ */ \
|
||||
FindSetRightBit(IRQM, Local0) \
|
||||
if (Local0) { \
|
||||
Decrement(Local0) \
|
||||
} \
|
||||
Store(Local0, pinx) \
|
||||
} \
|
||||
} \
|
Loading…
Reference in a new issue