This patch adds coreboot support for the GIGABYTE MA785GM-US2H board. This port now removes all dead code in the previous patch set, and also boots Fedora 16 on x86_64 (Phenom II X4 955 BE) On-board audio causes spurious interrupts and the kernel gets stuck in an infinite loop. AtomBIOS on RadeonHD video cards does not function and causes another infinite loop. radeon.modeset=0 must be set. acpi=off must also be set. With those kernel command line options set, Fedora 16 makes it to the login screen. USB mouse and keyboard don't work though. several USB error codes on boot-up. PS/2 should. Change-Id: I58a7083a023ebf7373b6ded2e9f0adda7ab76dea Signed-off-by: Alec Ari <neotheuser@ymail.com> Reviewed-on: http://review.coreboot.org/476 Tested-by: build bot (Jenkins) Reviewed-by: Stefan Reinauer <stefan.reinauer@coreboot.org>
162 lines
2.9 KiB
Plaintext
162 lines
2.9 KiB
Plaintext
/*
|
|
* This file is part of the coreboot project.
|
|
*
|
|
* Copyright (C) 2010 Advanced Micro Devices, Inc.
|
|
*
|
|
* 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.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
/* simple name description */
|
|
/*
|
|
DefinitionBlock ("DSDT.AML","DSDT",0x01,"XXXXXX","XXXXXXXX",0x00010001
|
|
)
|
|
{
|
|
#include "usb.asl"
|
|
}
|
|
*/
|
|
Method(UCOC, 0) {
|
|
Sleep(20)
|
|
Store(0x13,CMTI)
|
|
Store(0,GPSL)
|
|
}
|
|
|
|
/* USB Port 0 overcurrent uses Gpm 0 */
|
|
If(LLessEqual(UOM0,9)) {
|
|
Scope (\_GPE) {
|
|
Method (_L13) {
|
|
UCOC()
|
|
if(LEqual(GPB0,PLC0)) {
|
|
Not(PLC0,PLC0)
|
|
Store(PLC0, \_SB.PT0D)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/* USB Port 1 overcurrent uses Gpm 1 */
|
|
If (LLessEqual(UOM1,9)) {
|
|
Scope (\_GPE) {
|
|
Method (_L14) {
|
|
UCOC()
|
|
if (LEqual(GPB1,PLC1)) {
|
|
Not(PLC1,PLC1)
|
|
Store(PLC1, \_SB.PT1D)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/* USB Port 2 overcurrent uses Gpm 2 */
|
|
If (LLessEqual(UOM2,9)) {
|
|
Scope (\_GPE) {
|
|
Method (_L15) {
|
|
UCOC()
|
|
if (LEqual(GPB2,PLC2)) {
|
|
Not(PLC2,PLC2)
|
|
Store(PLC2, \_SB.PT2D)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/* USB Port 3 overcurrent uses Gpm 3 */
|
|
If (LLessEqual(UOM3,9)) {
|
|
Scope (\_GPE) {
|
|
Method (_L16) {
|
|
UCOC()
|
|
if (LEqual(GPB3,PLC3)) {
|
|
Not(PLC3,PLC3)
|
|
Store(PLC3, \_SB.PT3D)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/* USB Port 4 overcurrent uses Gpm 4 */
|
|
If (LLessEqual(UOM4,9)) {
|
|
Scope (\_GPE) {
|
|
Method (_L19) {
|
|
UCOC()
|
|
if (LEqual(GPB4,PLC4)) {
|
|
Not(PLC4,PLC4)
|
|
Store(PLC4, \_SB.PT4D)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/* USB Port 5 overcurrent uses Gpm 5 */
|
|
If (LLessEqual(UOM5,9)) {
|
|
Scope (\_GPE) {
|
|
Method (_L1A) {
|
|
UCOC()
|
|
if (LEqual(GPB5,PLC5)) {
|
|
Not(PLC5,PLC5)
|
|
Store(PLC5, \_SB.PT5D)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/* USB Port 6 overcurrent uses Gpm 6 */
|
|
If (LLessEqual(UOM6,9)) {
|
|
Scope (\_GPE) {
|
|
/* Method (_L1C) { */
|
|
Method (_L06) {
|
|
UCOC()
|
|
if (LEqual(GPB6,PLC6)) {
|
|
Not(PLC6,PLC6)
|
|
Store(PLC6, \_SB.PT6D)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/* USB Port 7 overcurrent uses Gpm 7 */
|
|
If (LLessEqual(UOM7,9)) {
|
|
Scope (\_GPE) {
|
|
/* Method (_L1D) { */
|
|
Method (_L07) {
|
|
UCOC()
|
|
if (LEqual(GPB7,PLC7)) {
|
|
Not(PLC7,PLC7)
|
|
Store(PLC7, \_SB.PT7D)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/* USB Port 8 overcurrent uses Gpm 8 */
|
|
If (LLessEqual(UOM8,9)) {
|
|
Scope (\_GPE) {
|
|
Method (_L17) {
|
|
if (LEqual(G8IS,PLC8)) {
|
|
Not(PLC8,PLC8)
|
|
Store(PLC8, \_SB.PT8D)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/* USB Port 9 overcurrent uses Gpm 9 */
|
|
If (LLessEqual(UOM9,9)) {
|
|
Scope (\_GPE) {
|
|
Method (_L0E) {
|
|
if (LEqual(G9IS,0)) {
|
|
Store(1,\_SB.PT9D)
|
|
}
|
|
}
|
|
}
|
|
}
|