| 
									
										
										
										
											2019-02-02 20:57:47 +01:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * QEMU i440FX North Bridge Emulation | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (c) 2006 Fabrice Bellard | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This work is licensed under the terms of the GNU GPL, version 2 or later. | 
					
						
							|  |  |  |  * See the COPYING file in the top-level directory. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef HW_PCI_I440FX_H
 | 
					
						
							|  |  |  | #define HW_PCI_I440FX_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "hw/hw.h"
 | 
					
						
							|  |  |  | #include "hw/pci/pci_bus.h"
 | 
					
						
							| 
									
										
										
										
											2019-12-09 10:49:58 +01:00
										 |  |  | #include "hw/pci-host/pam.h"
 | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | #include "qom/object.h"
 | 
					
						
							| 
									
										
										
										
											2019-02-02 20:57:47 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define TYPE_I440FX_PCI_HOST_BRIDGE "i440FX-pcihost"
 | 
					
						
							|  |  |  | #define TYPE_I440FX_PCI_DEVICE "i440FX"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-16 14:25:19 -04:00
										 |  |  | OBJECT_DECLARE_SIMPLE_TYPE(PCII440FXState, I440FX_PCI_DEVICE) | 
					
						
							| 
									
										
										
										
											2019-12-09 10:49:58 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | struct PCII440FXState { | 
					
						
							| 
									
										
										
										
											2019-12-09 10:49:58 +01:00
										 |  |  |     /*< private >*/ | 
					
						
							|  |  |  |     PCIDevice parent_obj; | 
					
						
							|  |  |  |     /*< public >*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     MemoryRegion *system_memory; | 
					
						
							|  |  |  |     MemoryRegion *pci_address_space; | 
					
						
							|  |  |  |     MemoryRegion *ram_memory; | 
					
						
							|  |  |  |     PAMMemoryRegion pam_regions[13]; | 
					
						
							|  |  |  |     MemoryRegion smram_region; | 
					
						
							|  |  |  |     MemoryRegion smram, low_smram; | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2019-12-09 10:49:58 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-02 20:57:47 +01:00
										 |  |  | #define TYPE_IGD_PASSTHROUGH_I440FX_PCI_DEVICE "igd-passthrough-i440FX"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PCIBus *i440fx_init(const char *host_type, const char *pci_type, | 
					
						
							| 
									
										
										
										
											2019-10-15 07:00:41 +02:00
										 |  |  |                     PCII440FXState **pi440fx_state, | 
					
						
							| 
									
										
										
										
											2019-02-02 20:57:47 +01:00
										 |  |  |                     MemoryRegion *address_space_mem, | 
					
						
							|  |  |  |                     MemoryRegion *address_space_io, | 
					
						
							|  |  |  |                     ram_addr_t ram_size, | 
					
						
							|  |  |  |                     ram_addr_t below_4g_mem_size, | 
					
						
							|  |  |  |                     ram_addr_t above_4g_mem_size, | 
					
						
							|  |  |  |                     MemoryRegion *pci_memory, | 
					
						
							|  |  |  |                     MemoryRegion *ram_memory); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PCIBus *find_i440fx(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 |