| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * QEMU Ultrasparc APB PCI host | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (c) 2006 Fabrice Bellard | 
					
						
							| 
									
										
										
										
											2007-09-16 21:08:06 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  |  * Permission is hereby granted, free of charge, to any person obtaining a copy | 
					
						
							|  |  |  |  * of this software and associated documentation files (the "Software"), to deal | 
					
						
							|  |  |  |  * in the Software without restriction, including without limitation the rights | 
					
						
							|  |  |  |  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | 
					
						
							|  |  |  |  * copies of the Software, and to permit persons to whom the Software is | 
					
						
							|  |  |  |  * furnished to do so, subject to the following conditions: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The above copyright notice and this permission notice shall be included in | 
					
						
							|  |  |  |  * all copies or substantial portions of the Software. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | 
					
						
							|  |  |  |  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | 
					
						
							|  |  |  |  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL | 
					
						
							|  |  |  |  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | 
					
						
							|  |  |  |  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | 
					
						
							|  |  |  |  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | 
					
						
							|  |  |  |  * THE SOFTWARE. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2006-09-24 17:01:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-09 20:53:30 +00:00
										 |  |  | /* XXX This file and most of its contents are somewhat misnamed.  The
 | 
					
						
							| 
									
										
										
										
											2006-09-24 17:01:44 +00:00
										 |  |  |    Ultrasparc PCI host is called the PCI Bus Module (PBM).  The APB is | 
					
						
							|  |  |  |    the secondary PCI bridge.  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  | #include "sysbus.h"
 | 
					
						
							| 
									
										
										
										
											2007-11-17 17:14:51 +00:00
										 |  |  | #include "pci.h"
 | 
					
						
							| 
									
										
										
										
											2009-10-30 21:21:06 +09:00
										 |  |  | #include "pci_host.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-11 14:59:56 +02:00
										 |  |  | #include "apb_pci.h"
 | 
					
						
							| 
									
										
										
										
											2009-01-09 20:53:30 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* debug APB */ | 
					
						
							|  |  |  | //#define DEBUG_APB
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef DEBUG_APB
 | 
					
						
							| 
									
										
										
										
											2009-05-13 17:53:17 +00:00
										 |  |  | #define APB_DPRINTF(fmt, ...) \
 | 
					
						
							|  |  |  | do { printf("APB: " fmt , ## __VA_ARGS__); } while (0) | 
					
						
							| 
									
										
										
										
											2009-01-09 20:53:30 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2009-05-13 17:53:17 +00:00
										 |  |  | #define APB_DPRINTF(fmt, ...)
 | 
					
						
							| 
									
										
										
										
											2009-01-09 20:53:30 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-13 18:56:27 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Chipset docs: | 
					
						
							|  |  |  |  * PBM: "UltraSPARC IIi User's Manual", | 
					
						
							|  |  |  |  * http://www.sun.com/processors/manuals/805-0087.pdf
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * APB: "Advanced PCI Bridge (APB) User's Manual", | 
					
						
							|  |  |  |  * http://www.sun.com/processors/manuals/805-1251.pdf
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  | typedef struct APBState { | 
					
						
							|  |  |  |     SysBusDevice busdev; | 
					
						
							|  |  |  |     PCIHostState host_state; | 
					
						
							|  |  |  | } APBState; | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-01 16:12:16 -05:00
										 |  |  | static void apb_config_writel (void *opaque, target_phys_addr_t addr, | 
					
						
							| 
									
										
										
										
											2007-10-06 11:28:21 +00:00
										 |  |  |                                uint32_t val) | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     //PCIBus *s = opaque;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     switch (addr & 0x3f) { | 
					
						
							|  |  |  |     case 0x00: // Control/Status
 | 
					
						
							|  |  |  |     case 0x10: // AFSR
 | 
					
						
							|  |  |  |     case 0x18: // AFAR
 | 
					
						
							|  |  |  |     case 0x20: // Diagnostic
 | 
					
						
							|  |  |  |     case 0x28: // Target address space
 | 
					
						
							| 
									
										
										
										
											2007-10-06 11:28:21 +00:00
										 |  |  |         // XXX
 | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  |     default: | 
					
						
							| 
									
										
										
										
											2007-10-06 11:28:21 +00:00
										 |  |  |         break; | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static uint32_t apb_config_readl (void *opaque, | 
					
						
							| 
									
										
										
										
											2009-10-01 16:12:16 -05:00
										 |  |  |                                   target_phys_addr_t addr) | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     //PCIBus *s = opaque;
 | 
					
						
							|  |  |  |     uint32_t val; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     switch (addr & 0x3f) { | 
					
						
							|  |  |  |     case 0x00: // Control/Status
 | 
					
						
							|  |  |  |     case 0x10: // AFSR
 | 
					
						
							|  |  |  |     case 0x18: // AFAR
 | 
					
						
							|  |  |  |     case 0x20: // Diagnostic
 | 
					
						
							|  |  |  |     case 0x28: // Target address space
 | 
					
						
							| 
									
										
										
										
											2007-10-06 11:28:21 +00:00
										 |  |  |         // XXX
 | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  |     default: | 
					
						
							| 
									
										
										
										
											2007-10-06 11:28:21 +00:00
										 |  |  |         val = 0; | 
					
						
							|  |  |  |         break; | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     return val; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-25 18:29:31 +00:00
										 |  |  | static CPUWriteMemoryFunc * const apb_config_write[] = { | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  |     &apb_config_writel, | 
					
						
							|  |  |  |     &apb_config_writel, | 
					
						
							|  |  |  |     &apb_config_writel, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-25 18:29:31 +00:00
										 |  |  | static CPUReadMemoryFunc * const apb_config_read[] = { | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  |     &apb_config_readl, | 
					
						
							|  |  |  |     &apb_config_readl, | 
					
						
							|  |  |  |     &apb_config_readl, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-01 16:12:16 -05:00
										 |  |  | static void pci_apb_iowriteb (void *opaque, target_phys_addr_t addr, | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  |                                   uint32_t val) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-09-20 16:05:47 +00:00
										 |  |  |     cpu_outb(addr & IOPORTS_MASK, val); | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-01 16:12:16 -05:00
										 |  |  | static void pci_apb_iowritew (void *opaque, target_phys_addr_t addr, | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  |                                   uint32_t val) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-09-20 16:05:47 +00:00
										 |  |  |     cpu_outw(addr & IOPORTS_MASK, val); | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-01 16:12:16 -05:00
										 |  |  | static void pci_apb_iowritel (void *opaque, target_phys_addr_t addr, | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  |                                 uint32_t val) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-09-20 16:05:47 +00:00
										 |  |  |     cpu_outl(addr & IOPORTS_MASK, val); | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-01 16:12:16 -05:00
										 |  |  | static uint32_t pci_apb_ioreadb (void *opaque, target_phys_addr_t addr) | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     uint32_t val; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-20 16:05:47 +00:00
										 |  |  |     val = cpu_inb(addr & IOPORTS_MASK); | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  |     return val; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-01 16:12:16 -05:00
										 |  |  | static uint32_t pci_apb_ioreadw (void *opaque, target_phys_addr_t addr) | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     uint32_t val; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-20 16:05:47 +00:00
										 |  |  |     val = cpu_inw(addr & IOPORTS_MASK); | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  |     return val; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-01 16:12:16 -05:00
										 |  |  | static uint32_t pci_apb_ioreadl (void *opaque, target_phys_addr_t addr) | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     uint32_t val; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-20 16:05:47 +00:00
										 |  |  |     val = cpu_inl(addr & IOPORTS_MASK); | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  |     return val; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-25 18:29:31 +00:00
										 |  |  | static CPUWriteMemoryFunc * const pci_apb_iowrite[] = { | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  |     &pci_apb_iowriteb, | 
					
						
							|  |  |  |     &pci_apb_iowritew, | 
					
						
							|  |  |  |     &pci_apb_iowritel, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-25 18:29:31 +00:00
										 |  |  | static CPUReadMemoryFunc * const pci_apb_ioread[] = { | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  |     &pci_apb_ioreadb, | 
					
						
							|  |  |  |     &pci_apb_ioreadw, | 
					
						
							|  |  |  |     &pci_apb_ioreadl, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-09-24 17:01:44 +00:00
										 |  |  | /* The APB host has an IRQ line for each IRQ line of each slot.  */ | 
					
						
							| 
									
										
										
										
											2006-09-24 00:16:34 +00:00
										 |  |  | static int pci_apb_map_irq(PCIDevice *pci_dev, int irq_num) | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2006-09-24 17:01:44 +00:00
										 |  |  |     return ((pci_dev->devfn & 0x18) >> 1) + irq_num; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int pci_pbm_map_irq(PCIDevice *pci_dev, int irq_num) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     int bus_offset; | 
					
						
							|  |  |  |     if (pci_dev->devfn & 1) | 
					
						
							|  |  |  |         bus_offset = 16; | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |         bus_offset = 0; | 
					
						
							|  |  |  |     return bus_offset + irq_num; | 
					
						
							| 
									
										
										
										
											2006-09-24 00:16:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 15:28:17 +02:00
										 |  |  | static void pci_apb_set_irq(void *opaque, int irq_num, int level) | 
					
						
							| 
									
										
										
										
											2006-09-24 00:16:34 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-08-28 15:28:17 +02:00
										 |  |  |     qemu_irq *pic = opaque; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-09-24 17:01:44 +00:00
										 |  |  |     /* PCI IRQ map onto the first 32 INO.  */ | 
					
						
							| 
									
										
										
										
											2007-04-07 18:14:41 +00:00
										 |  |  |     qemu_set_irq(pic[irq_num], level); | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-01 16:12:16 -05:00
										 |  |  | PCIBus *pci_apb_init(target_phys_addr_t special_base, | 
					
						
							|  |  |  |                      target_phys_addr_t mem_base, | 
					
						
							| 
									
										
										
										
											2009-01-10 11:33:32 +00:00
										 |  |  |                      qemu_irq *pic, PCIBus **bus2, PCIBus **bus3) | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  |     DeviceState *dev; | 
					
						
							|  |  |  |     SysBusDevice *s; | 
					
						
							|  |  |  |     APBState *d; | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-09-24 17:01:44 +00:00
										 |  |  |     /* Ultrasparc PBM main bus */ | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  |     dev = qdev_create(NULL, "pbm"); | 
					
						
							| 
									
										
										
										
											2009-10-07 01:15:58 +02:00
										 |  |  |     qdev_init_nofail(dev); | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  |     s = sysbus_from_qdev(dev); | 
					
						
							|  |  |  |     /* apb_config */ | 
					
						
							|  |  |  |     sysbus_mmio_map(s, 0, special_base + 0x2000ULL); | 
					
						
							|  |  |  |     /* pci_ioport */ | 
					
						
							|  |  |  |     sysbus_mmio_map(s, 1, special_base + 0x2000000ULL); | 
					
						
							|  |  |  |     /* mem_config: XXX size should be 4G-prom */ | 
					
						
							|  |  |  |     sysbus_mmio_map(s, 2, special_base + 0x1000000ULL); | 
					
						
							|  |  |  |     /* mem_data */ | 
					
						
							|  |  |  |     sysbus_mmio_map(s, 3, mem_base); | 
					
						
							|  |  |  |     d = FROM_SYSBUS(APBState, s); | 
					
						
							| 
									
										
										
										
											2009-09-13 08:32:40 +00:00
										 |  |  |     d->host_state.bus = pci_register_bus(&d->busdev.qdev, "pci", | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  |                                          pci_apb_set_irq, pci_pbm_map_irq, pic, | 
					
						
							|  |  |  |                                          0, 32); | 
					
						
							|  |  |  |     pci_create_simple(d->host_state.bus, 0, "pbm"); | 
					
						
							|  |  |  |     /* APB secondary busses */ | 
					
						
							| 
									
										
										
										
											2009-10-30 21:20:57 +09:00
										 |  |  |     *bus2 = pci_bridge_init(d->host_state.bus, PCI_DEVFN(1, 0), | 
					
						
							|  |  |  |                             PCI_VENDOR_ID_SUN, PCI_DEVICE_ID_SUN_SIMBA, | 
					
						
							|  |  |  |                             pci_apb_map_irq, | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  |                             "Advanced PCI Bus secondary bridge 1"); | 
					
						
							| 
									
										
										
										
											2009-10-30 21:20:57 +09:00
										 |  |  |     *bus3 = pci_bridge_init(d->host_state.bus, PCI_DEVFN(1, 1), | 
					
						
							|  |  |  |                             PCI_VENDOR_ID_SUN, PCI_DEVICE_ID_SUN_SIMBA, | 
					
						
							|  |  |  |                             pci_apb_map_irq, | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  |                             "Advanced PCI Bus secondary bridge 2"); | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  |     return d->host_state.bus; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-14 10:36:05 +02:00
										 |  |  | static int pci_pbm_init_device(SysBusDevice *dev) | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     APBState *s; | 
					
						
							|  |  |  |     int pci_mem_config, pci_mem_data, apb_config, pci_ioport; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     s = FROM_SYSBUS(APBState, dev); | 
					
						
							|  |  |  |     /* apb_config */ | 
					
						
							| 
									
										
										
										
											2009-06-14 11:38:51 +03:00
										 |  |  |     apb_config = cpu_register_io_memory(apb_config_read, | 
					
						
							| 
									
										
										
										
											2007-10-06 11:28:21 +00:00
										 |  |  |                                         apb_config_write, s); | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  |     sysbus_init_mmio(dev, 0x40ULL, apb_config); | 
					
						
							|  |  |  |     /* pci_ioport */ | 
					
						
							| 
									
										
										
										
											2009-06-14 11:38:51 +03:00
										 |  |  |     pci_ioport = cpu_register_io_memory(pci_apb_ioread, | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  |                                           pci_apb_iowrite, s); | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  |     sysbus_init_mmio(dev, 0x10000ULL, pci_ioport); | 
					
						
							|  |  |  |     /* mem_config  */ | 
					
						
							| 
									
										
										
										
											2009-11-12 14:58:34 +09:00
										 |  |  |     pci_mem_config = pci_host_conf_register_mmio(&s->host_state); | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  |     sysbus_init_mmio(dev, 0x10ULL, pci_mem_config); | 
					
						
							|  |  |  |     /* mem_data */ | 
					
						
							| 
									
										
										
										
											2009-11-12 14:58:34 +09:00
										 |  |  |     pci_mem_data = pci_host_data_register_mmio(&s->host_state); | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  |     sysbus_init_mmio(dev, 0x10000000ULL, pci_mem_data); | 
					
						
							| 
									
										
										
										
											2009-08-14 10:36:05 +02:00
										 |  |  |     return 0; | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-14 10:36:05 +02:00
										 |  |  | static int pbm_pci_host_init(PCIDevice *d) | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-01-26 15:37:35 +00:00
										 |  |  |     pci_config_set_vendor_id(d->config, PCI_VENDOR_ID_SUN); | 
					
						
							|  |  |  |     pci_config_set_device_id(d->config, PCI_DEVICE_ID_SUN_SABRE); | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  |     d->config[0x04] = 0x06; // command = bus master, pci mem
 | 
					
						
							|  |  |  |     d->config[0x05] = 0x00; | 
					
						
							|  |  |  |     d->config[0x06] = 0xa0; // status = fast back-to-back, 66MHz, no error
 | 
					
						
							|  |  |  |     d->config[0x07] = 0x03; // status = medium devsel
 | 
					
						
							|  |  |  |     d->config[0x08] = 0x00; // revision
 | 
					
						
							|  |  |  |     d->config[0x09] = 0x00; // programming i/f
 | 
					
						
							| 
									
										
										
										
											2009-02-01 19:26:20 +00:00
										 |  |  |     pci_config_set_class(d->config, PCI_CLASS_BRIDGE_HOST); | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  |     d->config[0x0D] = 0x10; // latency_timer
 | 
					
						
							| 
									
										
										
										
											2009-07-11 08:38:39 +00:00
										 |  |  |     d->config[PCI_HEADER_TYPE] = PCI_HEADER_TYPE_NORMAL; // header_type
 | 
					
						
							| 
									
										
										
										
											2009-08-14 10:36:05 +02:00
										 |  |  |     return 0; | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2006-09-24 17:01:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  | static PCIDeviceInfo pbm_pci_host_info = { | 
					
						
							|  |  |  |     .qdev.name = "pbm", | 
					
						
							|  |  |  |     .qdev.size = sizeof(PCIDevice), | 
					
						
							|  |  |  |     .init      = pbm_pci_host_init, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void pbm_register_devices(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     sysbus_register_dev("pbm", sizeof(APBState), pci_pbm_init_device); | 
					
						
							|  |  |  |     pci_qdev_register(&pbm_pci_host_info); | 
					
						
							| 
									
										
										
										
											2006-05-13 16:11:23 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-07-21 08:36:37 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | device_init(pbm_register_devices) |