This target is dead.
[coreboot.git] / src / mainboard / asus / m2v-mx_se / dsdt.asl
1 /*
2  * This file is part of the coreboot project.
3  *
4  * (C) Copyright 2004 Nick Barker <Nick.Barker9@btinternet.com>
5  * (C) Copyright 2007, 2008 Rudolf Marek <r.marek@assembler.cz>
6  *
7  * ISA portions taken from QEMU acpi-dsdt.dsl.
8  *
9  * This program is free software; you can redistribute it and/or modify
10  * it under the terms of the GNU General Public License v2 as published by
11  * the Free Software Foundation.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, write to the Free Software
20  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA
21  */
22
23 DefinitionBlock ("DSDT.aml", "DSDT", 1, "LXBIOS", "LXB-DSDT", 1)
24 {
25          Include ("amdk8_util.asl")
26
27
28         /* Define the main processor.*/
29         Scope (\_PR)
30         {
31                 Processor (\_PR.CPU0, 0x00, 0x000000, 0x00) {}
32                 Processor (\_PR.CPU1, 0x01, 0x000000, 0x00) {}
33         }
34
35         /* For now only define 2 power states:
36          *  - S0 which is fully on
37          *  - S5 which is soft off
38          * Any others would involve declaring the wake up methods.
39          */
40         Name (\_S0, Package () { 0x00, 0x00, 0x00, 0x00 })
41         Name (\_S5, Package () { 0x02, 0x02, 0x00, 0x00 })
42
43         /* Root of the bus hierarchy */
44         Scope (\_SB)
45         {
46                 /* Top PCI device */
47                 Device (PCI0)
48                 {
49                         Name (_HID, EisaId ("PNP0A03"))
50                         Name (_ADR, 0x00)
51                         Name (_UID, 0x00)
52                         Name (_BBN, 0x00)
53                         
54                     External (BUSN)
55                     External (MMIO)
56                     External (PCIO)
57                     External (SBLK)
58                     External (TOM1)
59                     External (HCLK)
60                     External (SBDN)
61                     External (HCDN)
62
63                     Method (_CRS, 0, NotSerialized)
64                         {
65                             Name (BUF0, ResourceTemplate ()
66                             {
67                                 IO (Decode16,
68                                 0x0CF8,             // Address Range Minimum
69                                 0x0CF8,             // Address Range Maximum
70                                 0x01,               // Address Alignment
71                                 0x08,               // Address Length
72                                 )
73                                 WordIO (ResourceProducer, MinFixed, MaxFixed, PosDecode, EntireRange,
74                                 0x0000,             // Address Space Granularity
75                                 0x0000,             // Address Range Minimum
76                                 0x0CF7,             // Address Range Maximum
77                                 0x0000,             // Address Translation Offset
78                                 0x0CF8,             // Address Length
79                                 ,, , TypeStatic)
80                             })
81                                 /* Methods bellow use SSDT to get actual MMIO regs
82                                    The IO ports are from 0xd00, optionally an VGA,
83                                    otherwise the info from MMIO is used.
84                                  */
85                                 Concatenate (\_SB.GMEM (0x00, \_SB.PCI0.SBLK), BUF0, Local1)
86                                 Concatenate (\_SB.GIOR (0x00, \_SB.PCI0.SBLK), Local1, Local2)
87                                 Concatenate (\_SB.GWBN (0x00, \_SB.PCI0.SBLK), Local2, Local3)
88                                 Return (Local3) 
89                         }
90
91                         /* PCI Routing Table */
92                         Name (_PRT, Package () {
93                                 Package (0x04) { 0x000FFFFF, 0x01, 0x00, 0x15 }, /* 0xf SATA IRQ 21 */
94                                 Package (0x04) { 0x000FFFFF, 0x00, 0x00, 0x14 }, /* 0xf Native IDE IRQ 20 */
95                                 Package (0x04) { 0x0010FFFF, 0x00, 0x00, 0x15 }, /* USB routing */
96                                 Package (0x04) { 0x0010FFFF, 0x01, 0x00, 0x15 },
97                                 Package (0x04) { 0x0010FFFF, 0x02, 0x00, 0x15 },
98                                 Package (0x04) { 0x0010FFFF, 0x03, 0x00, 0x15 },
99                                 Package (0x04) { 0x0012FFFF, 0x00, 0x00, 0x17 }, /* LAN */
100                                 Package (0x04) { 0x0013FFFF, 0x00, 0x00, 0x14 }, /* PCIe bridge SB */
101                                 Package (0x04) { 0x0013FFFF, 0x02, 0x00, 0x16 }, /* PCIe bridge SB */
102                                 Package (0x04) { 0x0001FFFF, 0x00, 0x00, 0x10 }, /* AGP pridge */
103                                 Package (0x04) { 0x0001FFFF, 0x01, 0x00, 0x11 }, /* FIXME FIXME */
104                                 Package (0x04) { 0x0002FFFF, 0x00, 0x00, 0x1B }, /* PCIE16 bridge IRQ27 */
105                                 Package (0x04) { 0x0002FFFF, 0x01, 0x00, 0x1B },
106                                 Package (0x04) { 0x0002FFFF, 0x02, 0x00, 0x1B },
107                                 Package (0x04) { 0x0002FFFF, 0x03, 0x00, 0x1B },
108                                 Package (0x04) { 0x0003FFFF, 0x00, 0x00, 0x1F }, /* PCIE bridge IRQ31 */
109                                 Package (0x04) { 0x0003FFFF, 0x01, 0x00, 0x23 }, /* IRQ36 */
110                                 Package (0x04) { 0x0003FFFF, 0x02, 0x00, 0x27 }, /* IRQ39 */
111                                 Package (0x04) { 0x0003FFFF, 0x03, 0x00, 0x2B }  /* IRQ43 */
112                         })
113
114                         Device (PEGG)
115                         {
116                                 Name (_ADR, 0x00020000)
117                                 Name (_UID, 0x00)
118                                 Name (_BBN, 0x02)
119                                 Name (_PRT, Package () {
120                                         Package (0x04) { 0x0000FFFF, 0x00, 0x00, 0x18 }, /* PCIE IRQ24-IRQ27 */
121                                         Package (0x04) { 0x0000FFFF, 0x01, 0x00, 0x19 },
122                                         Package (0x04) { 0x0000FFFF, 0x02, 0x00, 0x1A },
123                                         Package (0x04) { 0x0000FFFF, 0x03, 0x00, 0x1B },
124                                 })
125                         }
126
127                         Device (PEX0)
128                         {
129                                 Name (_ADR, 0x00030000)
130                                 Name (_UID, 0x00)
131                                 Name (_BBN, 0x03)
132                                 Name (_PRT, Package () {
133                                         Package (0x04) { 0x0000FFFF, 0x00, 0x00, 0x1C }, /* PCIE IRQ28-IRQ31 */
134                                         Package (0x04) { 0x0000FFFF, 0x01, 0x00, 0x1D },
135                                         Package (0x04) { 0x0000FFFF, 0x02, 0x00, 0x1E },
136                                         Package (0x04) { 0x0000FFFF, 0x03, 0x00, 0x1F },
137                                 })
138                         }
139
140                         Device (PEX1)
141                         {
142                                 Name (_ADR, 0x00130000)
143                                 Name (_UID, 0x00)
144                                 Name (_BBN, 0x4)
145                                 Name (_PRT, Package () {
146                                         Package (0x04) { 0x0001FFFF, 0x00, 0x00, 0x11 }, /* PCIE audio */
147                                         Package (0x04) { 0x0001FFFF, 0x01, 0x00, 0x11 },
148                                         Package (0x04) { 0x0001FFFF, 0x02, 0x00, 0x11 },
149                                         Package (0x04) { 0x0001FFFF, 0x03, 0x00, 0x11 },
150                                 })
151                         }
152
153                         Device (TBRG)
154                         {
155                                 Name (_ADR, 0x00130001)
156                                 Name (_UID, 0x00)
157                                 Name (_BBN, 0x5)
158                                 Name (_PRT, Package () {
159                                         Package (0x04) { 0x0006FFFF, 0x00, 0x00, 0x10 }, /* PCI slot */
160                                         Package (0x04) { 0x0006FFFF, 0x01, 0x00, 0x11 },
161                                         Package (0x04) { 0x0006FFFF, 0x02, 0x00, 0x12 },
162                                         Package (0x04) { 0x0006FFFF, 0x03, 0x00, 0x13 },
163                                         Package (0x04) { 0x0007FFFF, 0x00, 0x00, 0x11 }, /* PCI slot */
164                                         Package (0x04) { 0x0007FFFF, 0x01, 0x00, 0x12 },
165                                         Package (0x04) { 0x0007FFFF, 0x02, 0x00, 0x13 },
166                                         Package (0x04) { 0x0007FFFF, 0x03, 0x00, 0x10 },
167                                 })
168                         }
169                         Device (ISA) {
170                                 Name (_ADR, 0x00110000)
171
172                                 /* PS/2 keyboard (seems to be important for WinXP install) */
173                                 Device (KBD)
174                                 {
175                                         Name (_HID, EisaId ("PNP0303"))
176                                         Method (_STA, 0, NotSerialized)
177                                         {
178                                                 Return (0x0f)
179                                         }
180                                         Method (_CRS, 0, NotSerialized)
181                                         {
182                                                 Name (TMP, ResourceTemplate () {
183                                                         IO (Decode16, 0x0060, 0x0060, 0x01, 0x01)
184                                                         IO (Decode16, 0x0064, 0x0064, 0x01, 0x01)
185                                                         IRQNoFlags () {1}
186                                                 })
187                                                 Return (TMP)
188                                         }
189                                 }
190
191                                 /* PS/2 mouse */
192                                 Device (MOU)
193                                 {
194                                         Name (_HID, EisaId ("PNP0F13"))
195                                         Method (_STA, 0, NotSerialized)
196                                         {
197                                                 Return (0x0f)
198                                         }
199                                         Method (_CRS, 0, NotSerialized)
200                                         {
201                                                 Name (TMP, ResourceTemplate () {
202                                                      IRQNoFlags () {12}
203                                                 })
204                                                 Return (TMP)
205                                         }
206                                 }
207
208                                 /* PS/2 floppy controller */
209                                 Device (FDC0)
210                                 {
211                                         Name (_HID, EisaId ("PNP0700"))
212                                         Method (_STA, 0, NotSerialized)
213                                         {
214                                                 Return (0x0f)
215                                         }
216                                         Method (_CRS, 0, NotSerialized)
217                                         {
218                                                 Name (BUF0, ResourceTemplate () {
219                                                         IO (Decode16, 0x03F2, 0x03F2, 0x00, 0x04)
220                                                         IO (Decode16, 0x03F7, 0x03F7, 0x00, 0x01)
221                                                         IRQNoFlags () {6}
222                                                         DMA (Compatibility, NotBusMaster, Transfer8) {2}
223                                                 })
224                                                 Return (BUF0)
225                                         }
226                                 }
227                         }
228                 }
229         }
230 }