| 
									
										
										
										
											2015-02-13 05:46:07 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * QEMU Generic PCI Express Bridge Emulation | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (C) 2015 Alexander Graf <agraf@suse.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; either version 2 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-01-23 15:51:23 +01:00
										 |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, see <http://www.gnu.org/licenses/>
 | 
					
						
							| 
									
										
										
										
											2015-02-13 05:46:07 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef HW_GPEX_H
 | 
					
						
							|  |  |  | #define HW_GPEX_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-28 12:42:46 +02:00
										 |  |  | #include "exec/hwaddr.h"
 | 
					
						
							| 
									
										
										
										
											2015-02-13 05:46:07 +00:00
										 |  |  | #include "hw/sysbus.h"
 | 
					
						
							| 
									
										
										
										
											2022-12-22 11:03:28 +01:00
										 |  |  | #include "hw/pci/pci_device.h"
 | 
					
						
							| 
									
										
										
										
											2015-02-13 05:46:07 +00:00
										 |  |  | #include "hw/pci/pcie_host.h"
 | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | #include "qom/object.h"
 | 
					
						
							| 
									
										
										
										
											2015-02-13 05:46:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define TYPE_GPEX_HOST "gpex-pcihost"
 | 
					
						
							| 
									
										
										
										
											2020-09-16 14:25:19 -04:00
										 |  |  | OBJECT_DECLARE_SIMPLE_TYPE(GPEXHost, GPEX_HOST) | 
					
						
							| 
									
										
										
										
											2015-02-13 05:46:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define TYPE_GPEX_ROOT_DEVICE "gpex-root"
 | 
					
						
							| 
									
										
										
										
											2020-09-16 14:25:19 -04:00
										 |  |  | OBJECT_DECLARE_SIMPLE_TYPE(GPEXRootState, GPEX_ROOT_DEVICE) | 
					
						
							| 
									
										
										
										
											2015-02-13 05:46:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define GPEX_NUM_IRQS 4
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | struct GPEXRootState { | 
					
						
							| 
									
										
										
										
											2015-02-13 05:46:07 +00:00
										 |  |  |     /*< private >*/ | 
					
						
							|  |  |  |     PCIDevice parent_obj; | 
					
						
							|  |  |  |     /*< public >*/ | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2015-02-13 05:46:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | struct GPEXHost { | 
					
						
							| 
									
										
										
										
											2015-02-13 05:46:07 +00:00
										 |  |  |     /*< private >*/ | 
					
						
							|  |  |  |     PCIExpressHost parent_obj; | 
					
						
							|  |  |  |     /*< public >*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     GPEXRootState gpex_root; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     MemoryRegion io_ioport; | 
					
						
							|  |  |  |     MemoryRegion io_mmio; | 
					
						
							| 
									
										
										
										
											2021-03-25 16:33:15 +00:00
										 |  |  |     MemoryRegion io_ioport_window; | 
					
						
							|  |  |  |     MemoryRegion io_mmio_window; | 
					
						
							| 
									
										
										
										
											2015-02-13 05:46:07 +00:00
										 |  |  |     qemu_irq irq[GPEX_NUM_IRQS]; | 
					
						
							| 
									
										
										
										
											2017-09-14 18:43:18 +01:00
										 |  |  |     int irq_num[GPEX_NUM_IRQS]; | 
					
						
							| 
									
										
										
										
											2021-03-25 16:33:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     bool allow_unmapped_accesses; | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2015-02-13 05:46:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-28 12:42:46 +02:00
										 |  |  | struct GPEXConfig { | 
					
						
							|  |  |  |     MemMapEntry ecam; | 
					
						
							|  |  |  |     MemMapEntry mmio32; | 
					
						
							|  |  |  |     MemMapEntry mmio64; | 
					
						
							|  |  |  |     MemMapEntry pio; | 
					
						
							|  |  |  |     int         irq; | 
					
						
							| 
									
										
										
										
											2020-11-19 09:48:37 +08:00
										 |  |  |     PCIBus      *bus; | 
					
						
							| 
									
										
										
										
											2020-09-28 12:42:46 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-14 18:43:18 +01:00
										 |  |  | int gpex_set_irq_num(GPEXHost *s, int index, int gsi); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-28 12:42:46 +02:00
										 |  |  | void acpi_dsdt_add_gpex(Aml *scope, struct GPEXConfig *cfg); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-13 05:46:07 +00:00
										 |  |  | #endif /* HW_GPEX_H */
 |