2013-07-24 19:56:02 +04:00
|
|
|
/*
|
|
|
|
* Bochs/QEMU ACPI DSDT ASL definition
|
|
|
|
*
|
|
|
|
* Copyright (c) 2006 Fabrice Bellard
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License version 2 as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This library 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
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
ACPI_EXTRACT_ALL_CODE AcpiDsdtAmlCode
|
|
|
|
|
|
|
|
DefinitionBlock (
|
|
|
|
"acpi-dsdt.aml", // Output Filename
|
|
|
|
"DSDT", // Signature
|
|
|
|
0x01, // DSDT Compliance Revision
|
|
|
|
"BXPC", // OEMID
|
|
|
|
"BXDSDT", // TABLE ID
|
|
|
|
0x1 // OEM Revision
|
|
|
|
)
|
|
|
|
{
|
|
|
|
|
|
|
|
Scope(\_SB) {
|
|
|
|
Device(PCI0) {
|
|
|
|
Name(_HID, EisaId("PNP0A03"))
|
|
|
|
Name(_ADR, 0x00)
|
|
|
|
Name(_UID, 1)
|
acpi-build: append description for non-hotplug
As reported in
http://article.gmane.org/gmane.comp.emulators.qemu/253987
Mac OSX actually requires describing all occupied slots
in ACPI - even if hotplug isn't enabled.
I didn't expect this so I dropped description of all
non hotpluggable slots from ACPI.
As a result: before
commit 99fd437dee468609de8218f0eb3b16621fb6a9c9 (enable
hotplug for pci bridges), PCI cards show up in the "device tree" of OS X
(System Information). E.g., on MountainLion users have:
Hardware -> PCI Cards:
Card Type Driver Installed Slot
*ethernet Ethernet Controller Yes PCI Slot 2
pci8086,2934 USB UHC Yes PCI Slot 29
ethernet:
Type: Ethernet Controller
Driver Installed: Yes
MSI: No
Bus: PCI
Slot PCI Slot 2
Vendor ID: 0x8086
Device ID: 0x100e
Subsystem Vendor ID: 0x1af4
Subsystem ID: 0x1100
Revision ID: 0x0003
Hardware -> Ethernet Cards
ethernet:
Type: Ethernet Controller
Bus: PCI
Slot PCI Slot 2
Vendor ID: 0x8086
Device ID: 0x100e
Subsystem Vendor ID: 0x1af4
Subsystem ID: 0x1100
Revision ID: 0x0003
BSD name: en0
Kext name: AppleIntel8254XEthernet.kext
Location: /System/Library/Extensions/...
Version: 3.1.1b1
After commit 99fd437dee468609de8218f0eb3b16621fb6a9c9, users get:
Hardware -> PCI Cards:
This computer doesn't contain any PCI cards. If you installed PCI
cards, make sure they're properly installed.
Hardware -> Ethernet Cards
ethernet:
Type: Ethernet Controller
Bus: PCI
Vendor ID: 0x8086
Device ID: 0x100e
Subsystem Vendor ID: 0x1af4
Subsystem ID: 0x1100
Revision ID: 0x0003
BSD name: en0
Kext name: AppleIntel8254XEthernet.kext
Location: /System/Library/Extensions/...
Version: 3.1.1b1
Ethernet still works, but it's not showing up on the PCI bus, and it
no longer thinks it's plugged in to slot #2, as it used to before the
change.
To fix, append description for all occupied non hotpluggable PCI slots.
One need to be careful when doing this: VGA devices
are now described in SSDT, so we need to drop description from DSDT.
And ISA devices are used in DSDT so drop them from SSDT.
Reported-by: Gabriel L. Somlo <gsomlo@gmail.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
Also update generated dsdt and pcihp hex dump files.
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2014-02-04 19:43:47 +04:00
|
|
|
//#define PX13 S0B_
|
|
|
|
// External(PX13, DeviceObj)
|
2013-07-24 19:56:02 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
* PCI hotplug
|
|
|
|
****************************************************************/
|
|
|
|
|
|
|
|
Scope(\_SB.PCI0) {
|
|
|
|
OperationRegion(PCST, SystemIO, 0xae00, 0x08)
|
|
|
|
Field(PCST, DWordAcc, NoLock, WriteAsZeros) {
|
|
|
|
PCIU, 32,
|
|
|
|
PCID, 32,
|
|
|
|
}
|
|
|
|
|
|
|
|
OperationRegion(SEJ, SystemIO, 0xae08, 0x04)
|
|
|
|
Field(SEJ, DWordAcc, NoLock, WriteAsZeros) {
|
|
|
|
B0EJ, 32,
|
|
|
|
}
|
|
|
|
|
2013-10-14 19:01:29 +04:00
|
|
|
OperationRegion(BNMR, SystemIO, 0xae10, 0x04)
|
|
|
|
Field(BNMR, DWordAcc, NoLock, WriteAsZeros) {
|
|
|
|
BNUM, 32,
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Lock to protect access to fields above. */
|
|
|
|
Mutex(BLCK, 0)
|
|
|
|
|
2013-07-24 19:56:02 +04:00
|
|
|
/* Methods called by bulk generated PCI devices below */
|
|
|
|
|
|
|
|
/* Methods called by hotplug devices */
|
2013-10-14 19:01:29 +04:00
|
|
|
Method(PCEJ, 2, NotSerialized) {
|
2013-07-24 19:56:02 +04:00
|
|
|
// _EJ0 method - eject callback
|
2013-10-14 19:01:29 +04:00
|
|
|
Acquire(BLCK, 0xFFFF)
|
|
|
|
Store(Arg0, BNUM)
|
|
|
|
Store(ShiftLeft(1, Arg1), B0EJ)
|
|
|
|
Release(BLCK)
|
2013-07-24 19:56:02 +04:00
|
|
|
Return (0x0)
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Hotplug notification method supplied by SSDT */
|
|
|
|
External(\_SB.PCI0.PCNT, MethodObj)
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
* PCI IRQs
|
|
|
|
****************************************************************/
|
|
|
|
|
|
|
|
Scope(\_SB) {
|
|
|
|
Scope(PCI0) {
|
2014-07-28 19:34:14 +04:00
|
|
|
Method (_PRT, 0) {
|
|
|
|
Store(Package(128) {}, Local0)
|
|
|
|
Store(Zero, Local1)
|
|
|
|
While(LLess(Local1, 128)) {
|
|
|
|
// slot = pin >> 2
|
|
|
|
Store(ShiftRight(Local1, 2), Local2)
|
|
|
|
|
|
|
|
// lnk = (slot + pin) & 3
|
|
|
|
Store(And(Add(Local1, Local2), 3), Local3)
|
|
|
|
If (LEqual(Local3, 0)) {
|
|
|
|
Store(Package(4) { Zero, Zero, LNKD, Zero }, Local4)
|
|
|
|
}
|
|
|
|
If (LEqual(Local3, 1)) {
|
|
|
|
// device 1 is the power-management device, needs SCI
|
|
|
|
If (LEqual(Local1, 4)) {
|
|
|
|
Store(Package(4) { Zero, Zero, LNKS, Zero }, Local4)
|
|
|
|
} Else {
|
|
|
|
Store(Package(4) { Zero, Zero, LNKA, Zero }, Local4)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
If (LEqual(Local3, 2)) {
|
|
|
|
Store(Package(4) { Zero, Zero, LNKB, Zero }, Local4)
|
|
|
|
}
|
|
|
|
If (LEqual(Local3, 3)) {
|
|
|
|
Store(Package(4) { Zero, Zero, LNKC, Zero }, Local4)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Complete the interrupt routing entry:
|
|
|
|
// Package(4) { 0x[slot]FFFF, [pin], [link], 0) }
|
|
|
|
|
|
|
|
Store(Or(ShiftLeft(Local2, 16), 0xFFFF), Index(Local4, 0))
|
|
|
|
Store(And(Local1, 3), Index(Local4, 1))
|
|
|
|
Store(Local4, Index(Local0, Local1))
|
|
|
|
|
|
|
|
Increment(Local1)
|
|
|
|
}
|
|
|
|
|
|
|
|
Return(Local0)
|
|
|
|
}
|
2013-07-24 19:56:02 +04:00
|
|
|
}
|
|
|
|
|
2015-12-28 20:02:37 +03:00
|
|
|
|
|
|
|
External(PRQ0, FieldUnitObj)
|
|
|
|
External(PRQ1, FieldUnitObj)
|
|
|
|
External(PRQ2, FieldUnitObj)
|
|
|
|
External(PRQ3, FieldUnitObj)
|
2013-07-24 19:56:02 +04:00
|
|
|
|
|
|
|
Method(IQST, 1, NotSerialized) {
|
|
|
|
// _STA method - get status
|
|
|
|
If (And(0x80, Arg0)) {
|
|
|
|
Return (0x09)
|
|
|
|
}
|
|
|
|
Return (0x0B)
|
|
|
|
}
|
|
|
|
|
2015-12-28 20:02:39 +03:00
|
|
|
External(LNKA, DeviceObj)
|
|
|
|
External(LNKB, DeviceObj)
|
|
|
|
External(LNKC, DeviceObj)
|
|
|
|
External(LNKD, DeviceObj)
|
|
|
|
External(LNKS, DeviceObj)
|
2013-07-24 19:56:02 +04:00
|
|
|
}
|
|
|
|
}
|