| 
									
										
										
										
											2011-10-30 17:16:46 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * QEMU SPAPR PCI BUS definitions | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (c) 2011 Alexey Kardashevskiy <aik@au1.ibm.com> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This library is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU Lesser General Public | 
					
						
							|  |  |  |  * License as published by the Free Software Foundation; either | 
					
						
							| 
									
										
										
										
											2020-10-23 12:44:24 +00:00
										 |  |  |  * version 2.1 of the License, or (at your option) any later version. | 
					
						
							| 
									
										
										
										
											2011-10-30 17:16:46 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * 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, see <http://www.gnu.org/licenses/>.
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-29 10:12:57 +02:00
										 |  |  | #ifndef PCI_HOST_SPAPR_H
 | 
					
						
							|  |  |  | #define PCI_HOST_SPAPR_H
 | 
					
						
							| 
									
										
										
										
											2011-10-30 17:16:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-29 11:31:09 +02:00
										 |  |  | #include "hw/ppc/spapr.h"
 | 
					
						
							| 
									
										
										
										
											2012-12-12 14:24:50 +02:00
										 |  |  | #include "hw/pci/pci.h"
 | 
					
						
							|  |  |  | #include "hw/pci/pci_host.h"
 | 
					
						
							| 
									
										
										
										
											2013-02-05 17:06:20 +01:00
										 |  |  | #include "hw/ppc/xics.h"
 | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | #include "qom/object.h"
 | 
					
						
							| 
									
										
										
										
											2011-10-30 17:16:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-20 19:08:05 +02:00
										 |  |  | #define TYPE_SPAPR_PCI_HOST_BRIDGE "spapr-pci-host-bridge"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-16 14:25:19 -04:00
										 |  |  | OBJECT_DECLARE_SIMPLE_TYPE(SpaprPhbState, SPAPR_PCI_HOST_BRIDGE) | 
					
						
							| 
									
										
										
										
											2012-08-20 19:08:05 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-04 13:33:07 +10:00
										 |  |  | #define SPAPR_PCI_DMA_MAX_WINDOWS    2
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-27 15:36:31 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-28 20:20:44 +02:00
										 |  |  | typedef struct SpaprPciMsi { | 
					
						
							| 
									
										
										
										
											2014-05-30 19:34:20 +10:00
										 |  |  |     uint32_t first_irq; | 
					
						
							|  |  |  |     uint32_t num; | 
					
						
							| 
									
										
										
										
											2019-08-28 20:20:44 +02:00
										 |  |  | } SpaprPciMsi; | 
					
						
							| 
									
										
										
										
											2014-05-30 19:34:20 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-28 20:20:44 +02:00
										 |  |  | typedef struct SpaprPciMsiMig { | 
					
						
							| 
									
										
										
										
											2014-05-30 19:34:20 +10:00
										 |  |  |     uint32_t key; | 
					
						
							| 
									
										
										
										
											2019-08-28 20:20:44 +02:00
										 |  |  |     SpaprPciMsi value; | 
					
						
							|  |  |  | } SpaprPciMsiMig; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct SpaprPciLsi { | 
					
						
							|  |  |  |     uint32_t irq; | 
					
						
							|  |  |  | } SpaprPciLsi; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												spapr: Use CamelCase properly
The qemu coding standard is to use CamelCase for type and structure names,
and the pseries code follows that... sort of.  There are quite a lot of
places where we bend the rules in order to preserve the capitalization of
internal acronyms like "PHB", "TCE", "DIMM" and most commonly "sPAPR".
That was a bad idea - it frequently leads to names ending up with hard to
read clusters of capital letters, and means they don't catch the eye as
type identifiers, which is kind of the point of the CamelCase convention in
the first place.
In short, keeping type identifiers look like CamelCase is more important
than preserving standard capitalization of internal "words".  So, this
patch renames a heap of spapr internal type names to a more standard
CamelCase.
In addition to case changes, we also make some other identifier renames:
  VIOsPAPR* -> SpaprVio*
    The reverse word ordering was only ever used to mitigate the capital
    cluster, so revert to the natural ordering.
  VIOsPAPRVTYDevice -> SpaprVioVty
  VIOsPAPRVLANDevice -> SpaprVioVlan
    Brevity, since the "Device" didn't add useful information
  sPAPRDRConnector -> SpaprDrc
  sPAPRDRConnectorClass -> SpaprDrcClass
    Brevity, and makes it clearer this is the same thing as a "DRC"
    mentioned in many other places in the code
This is 100% a mechanical search-and-replace patch.  It will, however,
conflict with essentially any and all outstanding patches touching the
spapr code.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
											
										 
											2019-03-06 15:35:37 +11:00
										 |  |  | struct SpaprPhbState { | 
					
						
							| 
									
										
										
										
											2012-08-20 19:08:09 +02:00
										 |  |  |     PCIHostState parent_obj; | 
					
						
							| 
									
										
										
										
											2011-10-30 17:16:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-14 13:33:39 +11:00
										 |  |  |     uint32_t index; | 
					
						
							| 
									
										
										
										
											2011-10-30 17:16:46 +00:00
										 |  |  |     uint64_t buid; | 
					
						
							| 
									
										
										
										
											2012-03-12 17:50:24 +00:00
										 |  |  |     char *dtbusname; | 
					
						
							| 
									
										
										
										
											2015-05-07 15:33:52 +10:00
										 |  |  |     bool dr_enabled; | 
					
						
							| 
									
										
										
										
											2011-10-30 17:16:46 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     MemoryRegion memspace, iospace; | 
					
						
							| 
									
										
											  
											
												spapr_pci: Add a 64-bit MMIO window
On real hardware, and under pHyp, the PCI host bridges on Power machines
typically advertise two outbound MMIO windows from the guest's physical
memory space to PCI memory space:
  - A 32-bit window which maps onto 2GiB..4GiB in the PCI address space
  - A 64-bit window which maps onto a large region somewhere high in PCI
    address space (traditionally this used an identity mapping from guest
    physical address to PCI address, but that's not always the case)
The qemu implementation in spapr-pci-host-bridge, however, only supports a
single outbound MMIO window, however.  At least some Linux versions expect
the two windows however, so we arranged this window to map onto the PCI
memory space from 2 GiB..~64 GiB, then advertised it as two contiguous
windows, the "32-bit" window from 2G..4G and the "64-bit" window from
4G..~64G.
This approach means, however, that the 64G window is not naturally aligned.
In turn this limits the size of the largest BAR we can map (which does have
to be naturally aligned) to roughly half of the total window.  With some
large nVidia GPGPU cards which have huge memory BARs, this is starting to
be a problem.
This patch adds true support for separate 32-bit and 64-bit outbound MMIO
windows to the spapr-pci-host-bridge implementation, each of which can
be independently configured.  The 32-bit window always maps to 2G.. in PCI
space, but the PCI address of the 64-bit window can be configured (it
defaults to the same as the guest physical address).
So as not to break possible existing configurations, as long as a 64-bit
window is not specified, a large single window can be specified.  This
will appear the same way to the guest as the old approach, although it's
now implemented by two contiguous memory regions rather than a single one.
For now, this only adds the possibility of 64-bit windows.  The default
configuration still uses the legacy mode.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Reviewed-by: Laurent Vivier <lvivier@redhat.com>
											
										 
											2016-10-11 14:23:33 +11:00
										 |  |  |     hwaddr mem_win_addr, mem_win_size, mem64_win_addr, mem64_win_size; | 
					
						
							|  |  |  |     uint64_t mem64_win_pciaddr; | 
					
						
							|  |  |  |     hwaddr io_win_addr, io_win_size; | 
					
						
							|  |  |  |     MemoryRegion mem32window, mem64window, iowindow, msiwindow; | 
					
						
							| 
									
										
										
										
											2012-08-07 16:10:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-04 13:33:07 +10:00
										 |  |  |     uint32_t dma_liobn[SPAPR_PCI_DMA_MAX_WINDOWS]; | 
					
						
							| 
									
										
										
										
											2015-09-24 09:56:44 +10:00
										 |  |  |     hwaddr dma_win_addr, dma_win_size; | 
					
						
							| 
									
										
										
										
											2012-10-30 13:47:48 +02:00
										 |  |  |     AddressSpace iommu_as; | 
					
						
							| 
									
										
										
										
											2014-05-27 15:36:32 +10:00
										 |  |  |     MemoryRegion iommu_root; | 
					
						
							| 
									
										
										
										
											2011-10-30 17:16:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-28 20:20:44 +02:00
										 |  |  |     SpaprPciLsi lsi_table[PCI_NUM_PINS]; | 
					
						
							| 
									
										
										
										
											2011-10-30 17:16:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-30 19:34:20 +10:00
										 |  |  |     GHashTable *msi; | 
					
						
							|  |  |  |     /* Temporary cache for migration purposes */ | 
					
						
							|  |  |  |     int32_t msi_devs_num; | 
					
						
							| 
									
										
										
										
											2019-08-28 20:20:44 +02:00
										 |  |  |     SpaprPciMsiMig *msi_devs; | 
					
						
							| 
									
										
										
										
											2012-08-07 16:10:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												spapr: Use CamelCase properly
The qemu coding standard is to use CamelCase for type and structure names,
and the pseries code follows that... sort of.  There are quite a lot of
places where we bend the rules in order to preserve the capitalization of
internal acronyms like "PHB", "TCE", "DIMM" and most commonly "sPAPR".
That was a bad idea - it frequently leads to names ending up with hard to
read clusters of capital letters, and means they don't catch the eye as
type identifiers, which is kind of the point of the CamelCase convention in
the first place.
In short, keeping type identifiers look like CamelCase is more important
than preserving standard capitalization of internal "words".  So, this
patch renames a heap of spapr internal type names to a more standard
CamelCase.
In addition to case changes, we also make some other identifier renames:
  VIOsPAPR* -> SpaprVio*
    The reverse word ordering was only ever used to mitigate the capital
    cluster, so revert to the natural ordering.
  VIOsPAPRVTYDevice -> SpaprVioVty
  VIOsPAPRVLANDevice -> SpaprVioVlan
    Brevity, since the "Device" didn't add useful information
  sPAPRDRConnector -> SpaprDrc
  sPAPRDRConnectorClass -> SpaprDrcClass
    Brevity, and makes it clearer this is the same thing as a "DRC"
    mentioned in many other places in the code
This is 100% a mechanical search-and-replace patch.  It will, however,
conflict with essentially any and all outstanding patches touching the
spapr code.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
											
										 
											2019-03-06 15:35:37 +11:00
										 |  |  |     QLIST_ENTRY(SpaprPhbState) list; | 
					
						
							| 
									
										
										
										
											2016-07-04 13:33:07 +10:00
										 |  |  | 
 | 
					
						
							|  |  |  |     bool ddw_enabled; | 
					
						
							|  |  |  |     uint64_t page_size_mask; | 
					
						
							|  |  |  |     uint64_t dma64_win_addr; | 
					
						
							| 
									
										
										
										
											2016-07-27 18:03:38 +10:00
										 |  |  | 
 | 
					
						
							|  |  |  |     uint32_t numa_node; | 
					
						
							| 
									
										
										
										
											2016-11-23 10:26:38 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-14 11:54:17 +11:00
										 |  |  |     bool pcie_ecs; /* Allow access to PCIe extended config space? */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-23 10:26:38 +11:00
										 |  |  |     /* Fields for migration compatibility hacks */ | 
					
						
							|  |  |  |     bool pre_2_8_migration; | 
					
						
							|  |  |  |     uint32_t mig_liobn; | 
					
						
							|  |  |  |     hwaddr mig_mem_win_addr, mig_mem_win_size; | 
					
						
							|  |  |  |     hwaddr mig_io_win_addr, mig_io_win_size; | 
					
						
							| 
									
										
										
										
											2020-07-16 17:56:55 -05:00
										 |  |  |     bool pre_5_1_assoc; | 
					
						
							| 
									
										
										
										
											2014-05-27 15:36:31 +10:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2011-10-30 17:16:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-30 12:53:19 +11:00
										 |  |  | #define SPAPR_PCI_MEM_WIN_BUS_OFFSET 0x80000000ULL
 | 
					
						
							| 
									
										
											  
											
												spapr_pci: Add a 64-bit MMIO window
On real hardware, and under pHyp, the PCI host bridges on Power machines
typically advertise two outbound MMIO windows from the guest's physical
memory space to PCI memory space:
  - A 32-bit window which maps onto 2GiB..4GiB in the PCI address space
  - A 64-bit window which maps onto a large region somewhere high in PCI
    address space (traditionally this used an identity mapping from guest
    physical address to PCI address, but that's not always the case)
The qemu implementation in spapr-pci-host-bridge, however, only supports a
single outbound MMIO window, however.  At least some Linux versions expect
the two windows however, so we arranged this window to map onto the PCI
memory space from 2 GiB..~64 GiB, then advertised it as two contiguous
windows, the "32-bit" window from 2G..4G and the "64-bit" window from
4G..~64G.
This approach means, however, that the 64G window is not naturally aligned.
In turn this limits the size of the largest BAR we can map (which does have
to be naturally aligned) to roughly half of the total window.  With some
large nVidia GPGPU cards which have huge memory BARs, this is starting to
be a problem.
This patch adds true support for separate 32-bit and 64-bit outbound MMIO
windows to the spapr-pci-host-bridge implementation, each of which can
be independently configured.  The 32-bit window always maps to 2G.. in PCI
space, but the PCI address of the 64-bit window can be configured (it
defaults to the same as the guest physical address).
So as not to break possible existing configurations, as long as a 64-bit
window is not specified, a large single window can be specified.  This
will appear the same way to the guest as the old approach, although it's
now implemented by two contiguous memory regions rather than a single one.
For now, this only adds the possibility of 64-bit windows.  The default
configuration still uses the legacy mode.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Reviewed-by: Laurent Vivier <lvivier@redhat.com>
											
										 
											2016-10-11 14:23:33 +11:00
										 |  |  | #define SPAPR_PCI_MEM32_WIN_SIZE     \
 | 
					
						
							|  |  |  |     ((1ULL << 32) - SPAPR_PCI_MEM_WIN_BUS_OFFSET) | 
					
						
							| 
									
										
										
										
											2016-10-16 12:04:15 +11:00
										 |  |  | #define SPAPR_PCI_MEM64_WIN_SIZE     0x10000000000ULL /* 1 TiB */
 | 
					
						
							| 
									
										
										
										
											2015-01-30 12:53:19 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-21 01:36:53 +01:00
										 |  |  | /* All PCI outbound windows will be within this range */ | 
					
						
							| 
									
										
										
										
											2016-10-16 12:04:15 +11:00
										 |  |  | #define SPAPR_PCI_BASE               (1ULL << 45) /* 32 TiB */
 | 
					
						
							|  |  |  | #define SPAPR_PCI_LIMIT              (1ULL << 46) /* 64 TiB */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-21 01:36:53 +01:00
										 |  |  | #define SPAPR_MAX_PHBS ((SPAPR_PCI_LIMIT - SPAPR_PCI_BASE) / \
 | 
					
						
							|  |  |  |                         SPAPR_PCI_MEM64_WIN_SIZE - 1) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-23 17:20:39 +00:00
										 |  |  | #define SPAPR_PCI_IO_WIN_SIZE        0x10000
 | 
					
						
							| 
									
										
										
										
											2013-07-12 17:38:24 +10:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define SPAPR_PCI_MSI_WINDOW         0x40000000000ULL
 | 
					
						
							| 
									
										
										
										
											2013-01-23 17:20:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-27 13:44:58 +10:00
										 |  |  | int spapr_dt_phb(SpaprMachineState *spapr, SpaprPhbState *phb, | 
					
						
							|  |  |  |                  uint32_t intc_phandle, void *fdt, int *node_offset); | 
					
						
							| 
									
										
										
										
											2011-10-30 17:16:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-07 16:10:33 +00:00
										 |  |  | void spapr_pci_rtas_init(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												spapr: Use CamelCase properly
The qemu coding standard is to use CamelCase for type and structure names,
and the pseries code follows that... sort of.  There are quite a lot of
places where we bend the rules in order to preserve the capitalization of
internal acronyms like "PHB", "TCE", "DIMM" and most commonly "sPAPR".
That was a bad idea - it frequently leads to names ending up with hard to
read clusters of capital letters, and means they don't catch the eye as
type identifiers, which is kind of the point of the CamelCase convention in
the first place.
In short, keeping type identifiers look like CamelCase is more important
than preserving standard capitalization of internal "words".  So, this
patch renames a heap of spapr internal type names to a more standard
CamelCase.
In addition to case changes, we also make some other identifier renames:
  VIOsPAPR* -> SpaprVio*
    The reverse word ordering was only ever used to mitigate the capital
    cluster, so revert to the natural ordering.
  VIOsPAPRVTYDevice -> SpaprVioVty
  VIOsPAPRVLANDevice -> SpaprVioVlan
    Brevity, since the "Device" didn't add useful information
  sPAPRDRConnector -> SpaprDrc
  sPAPRDRConnectorClass -> SpaprDrcClass
    Brevity, and makes it clearer this is the same thing as a "DRC"
    mentioned in many other places in the code
This is 100% a mechanical search-and-replace patch.  It will, however,
conflict with essentially any and all outstanding patches touching the
spapr code.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
											
										 
											2019-03-06 15:35:37 +11:00
										 |  |  | SpaprPhbState *spapr_pci_find_phb(SpaprMachineState *spapr, uint64_t buid); | 
					
						
							|  |  |  | PCIDevice *spapr_pci_find_dev(SpaprMachineState *spapr, uint64_t buid, | 
					
						
							| 
									
										
										
										
											2015-05-07 15:33:34 +10:00
										 |  |  |                               uint32_t config_addr); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-19 18:17:53 +01:00
										 |  |  | /* DRC callbacks */ | 
					
						
							| 
									
										
										
										
											2017-05-22 16:35:48 -03:00
										 |  |  | void spapr_phb_remove_pci_device_cb(DeviceState *dev); | 
					
						
							| 
									
										
											  
											
												spapr: Use CamelCase properly
The qemu coding standard is to use CamelCase for type and structure names,
and the pseries code follows that... sort of.  There are quite a lot of
places where we bend the rules in order to preserve the capitalization of
internal acronyms like "PHB", "TCE", "DIMM" and most commonly "sPAPR".
That was a bad idea - it frequently leads to names ending up with hard to
read clusters of capital letters, and means they don't catch the eye as
type identifiers, which is kind of the point of the CamelCase convention in
the first place.
In short, keeping type identifiers look like CamelCase is more important
than preserving standard capitalization of internal "words".  So, this
patch renames a heap of spapr internal type names to a more standard
CamelCase.
In addition to case changes, we also make some other identifier renames:
  VIOsPAPR* -> SpaprVio*
    The reverse word ordering was only ever used to mitigate the capital
    cluster, so revert to the natural ordering.
  VIOsPAPRVTYDevice -> SpaprVioVty
  VIOsPAPRVLANDevice -> SpaprVioVlan
    Brevity, since the "Device" didn't add useful information
  sPAPRDRConnector -> SpaprDrc
  sPAPRDRConnectorClass -> SpaprDrcClass
    Brevity, and makes it clearer this is the same thing as a "DRC"
    mentioned in many other places in the code
This is 100% a mechanical search-and-replace patch.  It will, however,
conflict with essentially any and all outstanding patches touching the
spapr code.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
											
										 
											2019-03-06 15:35:37 +11:00
										 |  |  | int spapr_pci_dt_populate(SpaprDrc *drc, SpaprMachineState *spapr, | 
					
						
							| 
									
										
										
										
											2019-02-19 18:17:53 +01:00
										 |  |  |                           void *fdt, int *fdt_start_offset, Error **errp); | 
					
						
							| 
									
										
										
										
											2017-05-22 16:35:48 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 17:45:05 +11:00
										 |  |  | /* VFIO EEH hooks */ | 
					
						
							|  |  |  | #ifdef CONFIG_LINUX
 | 
					
						
							| 
									
										
											  
											
												spapr: Use CamelCase properly
The qemu coding standard is to use CamelCase for type and structure names,
and the pseries code follows that... sort of.  There are quite a lot of
places where we bend the rules in order to preserve the capitalization of
internal acronyms like "PHB", "TCE", "DIMM" and most commonly "sPAPR".
That was a bad idea - it frequently leads to names ending up with hard to
read clusters of capital letters, and means they don't catch the eye as
type identifiers, which is kind of the point of the CamelCase convention in
the first place.
In short, keeping type identifiers look like CamelCase is more important
than preserving standard capitalization of internal "words".  So, this
patch renames a heap of spapr internal type names to a more standard
CamelCase.
In addition to case changes, we also make some other identifier renames:
  VIOsPAPR* -> SpaprVio*
    The reverse word ordering was only ever used to mitigate the capital
    cluster, so revert to the natural ordering.
  VIOsPAPRVTYDevice -> SpaprVioVty
  VIOsPAPRVLANDevice -> SpaprVioVlan
    Brevity, since the "Device" didn't add useful information
  sPAPRDRConnector -> SpaprDrc
  sPAPRDRConnectorClass -> SpaprDrcClass
    Brevity, and makes it clearer this is the same thing as a "DRC"
    mentioned in many other places in the code
This is 100% a mechanical search-and-replace patch.  It will, however,
conflict with essentially any and all outstanding patches touching the
spapr code.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
											
										 
											2019-03-06 15:35:37 +11:00
										 |  |  | bool spapr_phb_eeh_available(SpaprPhbState *sphb); | 
					
						
							|  |  |  | int spapr_phb_vfio_eeh_set_option(SpaprPhbState *sphb, | 
					
						
							| 
									
										
										
										
											2016-02-29 17:45:05 +11:00
										 |  |  |                                   unsigned int addr, int option); | 
					
						
							| 
									
										
											  
											
												spapr: Use CamelCase properly
The qemu coding standard is to use CamelCase for type and structure names,
and the pseries code follows that... sort of.  There are quite a lot of
places where we bend the rules in order to preserve the capitalization of
internal acronyms like "PHB", "TCE", "DIMM" and most commonly "sPAPR".
That was a bad idea - it frequently leads to names ending up with hard to
read clusters of capital letters, and means they don't catch the eye as
type identifiers, which is kind of the point of the CamelCase convention in
the first place.
In short, keeping type identifiers look like CamelCase is more important
than preserving standard capitalization of internal "words".  So, this
patch renames a heap of spapr internal type names to a more standard
CamelCase.
In addition to case changes, we also make some other identifier renames:
  VIOsPAPR* -> SpaprVio*
    The reverse word ordering was only ever used to mitigate the capital
    cluster, so revert to the natural ordering.
  VIOsPAPRVTYDevice -> SpaprVioVty
  VIOsPAPRVLANDevice -> SpaprVioVlan
    Brevity, since the "Device" didn't add useful information
  sPAPRDRConnector -> SpaprDrc
  sPAPRDRConnectorClass -> SpaprDrcClass
    Brevity, and makes it clearer this is the same thing as a "DRC"
    mentioned in many other places in the code
This is 100% a mechanical search-and-replace patch.  It will, however,
conflict with essentially any and all outstanding patches touching the
spapr code.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
											
										 
											2019-03-06 15:35:37 +11:00
										 |  |  | int spapr_phb_vfio_eeh_get_state(SpaprPhbState *sphb, int *state); | 
					
						
							|  |  |  | int spapr_phb_vfio_eeh_reset(SpaprPhbState *sphb, int option); | 
					
						
							|  |  |  | int spapr_phb_vfio_eeh_configure(SpaprPhbState *sphb); | 
					
						
							| 
									
										
										
										
											2016-02-29 17:45:05 +11:00
										 |  |  | void spapr_phb_vfio_reset(DeviceState *qdev); | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
											  
											
												spapr: Use CamelCase properly
The qemu coding standard is to use CamelCase for type and structure names,
and the pseries code follows that... sort of.  There are quite a lot of
places where we bend the rules in order to preserve the capitalization of
internal acronyms like "PHB", "TCE", "DIMM" and most commonly "sPAPR".
That was a bad idea - it frequently leads to names ending up with hard to
read clusters of capital letters, and means they don't catch the eye as
type identifiers, which is kind of the point of the CamelCase convention in
the first place.
In short, keeping type identifiers look like CamelCase is more important
than preserving standard capitalization of internal "words".  So, this
patch renames a heap of spapr internal type names to a more standard
CamelCase.
In addition to case changes, we also make some other identifier renames:
  VIOsPAPR* -> SpaprVio*
    The reverse word ordering was only ever used to mitigate the capital
    cluster, so revert to the natural ordering.
  VIOsPAPRVTYDevice -> SpaprVioVty
  VIOsPAPRVLANDevice -> SpaprVioVlan
    Brevity, since the "Device" didn't add useful information
  sPAPRDRConnector -> SpaprDrc
  sPAPRDRConnectorClass -> SpaprDrcClass
    Brevity, and makes it clearer this is the same thing as a "DRC"
    mentioned in many other places in the code
This is 100% a mechanical search-and-replace patch.  It will, however,
conflict with essentially any and all outstanding patches touching the
spapr code.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
											
										 
											2019-03-06 15:35:37 +11:00
										 |  |  | static inline bool spapr_phb_eeh_available(SpaprPhbState *sphb) | 
					
						
							| 
									
										
										
										
											2016-02-29 17:19:42 +11:00
										 |  |  | { | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
											  
											
												spapr: Use CamelCase properly
The qemu coding standard is to use CamelCase for type and structure names,
and the pseries code follows that... sort of.  There are quite a lot of
places where we bend the rules in order to preserve the capitalization of
internal acronyms like "PHB", "TCE", "DIMM" and most commonly "sPAPR".
That was a bad idea - it frequently leads to names ending up with hard to
read clusters of capital letters, and means they don't catch the eye as
type identifiers, which is kind of the point of the CamelCase convention in
the first place.
In short, keeping type identifiers look like CamelCase is more important
than preserving standard capitalization of internal "words".  So, this
patch renames a heap of spapr internal type names to a more standard
CamelCase.
In addition to case changes, we also make some other identifier renames:
  VIOsPAPR* -> SpaprVio*
    The reverse word ordering was only ever used to mitigate the capital
    cluster, so revert to the natural ordering.
  VIOsPAPRVTYDevice -> SpaprVioVty
  VIOsPAPRVLANDevice -> SpaprVioVlan
    Brevity, since the "Device" didn't add useful information
  sPAPRDRConnector -> SpaprDrc
  sPAPRDRConnectorClass -> SpaprDrcClass
    Brevity, and makes it clearer this is the same thing as a "DRC"
    mentioned in many other places in the code
This is 100% a mechanical search-and-replace patch.  It will, however,
conflict with essentially any and all outstanding patches touching the
spapr code.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
											
										 
											2019-03-06 15:35:37 +11:00
										 |  |  | static inline int spapr_phb_vfio_eeh_set_option(SpaprPhbState *sphb, | 
					
						
							| 
									
										
										
										
											2016-02-29 17:45:05 +11:00
										 |  |  |                                                 unsigned int addr, int option) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return RTAS_OUT_HW_ERROR; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
											  
											
												spapr: Use CamelCase properly
The qemu coding standard is to use CamelCase for type and structure names,
and the pseries code follows that... sort of.  There are quite a lot of
places where we bend the rules in order to preserve the capitalization of
internal acronyms like "PHB", "TCE", "DIMM" and most commonly "sPAPR".
That was a bad idea - it frequently leads to names ending up with hard to
read clusters of capital letters, and means they don't catch the eye as
type identifiers, which is kind of the point of the CamelCase convention in
the first place.
In short, keeping type identifiers look like CamelCase is more important
than preserving standard capitalization of internal "words".  So, this
patch renames a heap of spapr internal type names to a more standard
CamelCase.
In addition to case changes, we also make some other identifier renames:
  VIOsPAPR* -> SpaprVio*
    The reverse word ordering was only ever used to mitigate the capital
    cluster, so revert to the natural ordering.
  VIOsPAPRVTYDevice -> SpaprVioVty
  VIOsPAPRVLANDevice -> SpaprVioVlan
    Brevity, since the "Device" didn't add useful information
  sPAPRDRConnector -> SpaprDrc
  sPAPRDRConnectorClass -> SpaprDrcClass
    Brevity, and makes it clearer this is the same thing as a "DRC"
    mentioned in many other places in the code
This is 100% a mechanical search-and-replace patch.  It will, however,
conflict with essentially any and all outstanding patches touching the
spapr code.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
											
										 
											2019-03-06 15:35:37 +11:00
										 |  |  | static inline int spapr_phb_vfio_eeh_get_state(SpaprPhbState *sphb, | 
					
						
							| 
									
										
										
										
											2016-02-29 17:45:05 +11:00
										 |  |  |                                                int *state) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return RTAS_OUT_HW_ERROR; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
											  
											
												spapr: Use CamelCase properly
The qemu coding standard is to use CamelCase for type and structure names,
and the pseries code follows that... sort of.  There are quite a lot of
places where we bend the rules in order to preserve the capitalization of
internal acronyms like "PHB", "TCE", "DIMM" and most commonly "sPAPR".
That was a bad idea - it frequently leads to names ending up with hard to
read clusters of capital letters, and means they don't catch the eye as
type identifiers, which is kind of the point of the CamelCase convention in
the first place.
In short, keeping type identifiers look like CamelCase is more important
than preserving standard capitalization of internal "words".  So, this
patch renames a heap of spapr internal type names to a more standard
CamelCase.
In addition to case changes, we also make some other identifier renames:
  VIOsPAPR* -> SpaprVio*
    The reverse word ordering was only ever used to mitigate the capital
    cluster, so revert to the natural ordering.
  VIOsPAPRVTYDevice -> SpaprVioVty
  VIOsPAPRVLANDevice -> SpaprVioVlan
    Brevity, since the "Device" didn't add useful information
  sPAPRDRConnector -> SpaprDrc
  sPAPRDRConnectorClass -> SpaprDrcClass
    Brevity, and makes it clearer this is the same thing as a "DRC"
    mentioned in many other places in the code
This is 100% a mechanical search-and-replace patch.  It will, however,
conflict with essentially any and all outstanding patches touching the
spapr code.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
											
										 
											2019-03-06 15:35:37 +11:00
										 |  |  | static inline int spapr_phb_vfio_eeh_reset(SpaprPhbState *sphb, int option) | 
					
						
							| 
									
										
										
										
											2016-02-29 17:45:05 +11:00
										 |  |  | { | 
					
						
							|  |  |  |     return RTAS_OUT_HW_ERROR; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
											  
											
												spapr: Use CamelCase properly
The qemu coding standard is to use CamelCase for type and structure names,
and the pseries code follows that... sort of.  There are quite a lot of
places where we bend the rules in order to preserve the capitalization of
internal acronyms like "PHB", "TCE", "DIMM" and most commonly "sPAPR".
That was a bad idea - it frequently leads to names ending up with hard to
read clusters of capital letters, and means they don't catch the eye as
type identifiers, which is kind of the point of the CamelCase convention in
the first place.
In short, keeping type identifiers look like CamelCase is more important
than preserving standard capitalization of internal "words".  So, this
patch renames a heap of spapr internal type names to a more standard
CamelCase.
In addition to case changes, we also make some other identifier renames:
  VIOsPAPR* -> SpaprVio*
    The reverse word ordering was only ever used to mitigate the capital
    cluster, so revert to the natural ordering.
  VIOsPAPRVTYDevice -> SpaprVioVty
  VIOsPAPRVLANDevice -> SpaprVioVlan
    Brevity, since the "Device" didn't add useful information
  sPAPRDRConnector -> SpaprDrc
  sPAPRDRConnectorClass -> SpaprDrcClass
    Brevity, and makes it clearer this is the same thing as a "DRC"
    mentioned in many other places in the code
This is 100% a mechanical search-and-replace patch.  It will, however,
conflict with essentially any and all outstanding patches touching the
spapr code.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
											
										 
											2019-03-06 15:35:37 +11:00
										 |  |  | static inline int spapr_phb_vfio_eeh_configure(SpaprPhbState *sphb) | 
					
						
							| 
									
										
										
										
											2016-02-29 17:45:05 +11:00
										 |  |  | { | 
					
						
							|  |  |  |     return RTAS_OUT_HW_ERROR; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | static inline void spapr_phb_vfio_reset(DeviceState *qdev) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												spapr: Use CamelCase properly
The qemu coding standard is to use CamelCase for type and structure names,
and the pseries code follows that... sort of.  There are quite a lot of
places where we bend the rules in order to preserve the capitalization of
internal acronyms like "PHB", "TCE", "DIMM" and most commonly "sPAPR".
That was a bad idea - it frequently leads to names ending up with hard to
read clusters of capital letters, and means they don't catch the eye as
type identifiers, which is kind of the point of the CamelCase convention in
the first place.
In short, keeping type identifiers look like CamelCase is more important
than preserving standard capitalization of internal "words".  So, this
patch renames a heap of spapr internal type names to a more standard
CamelCase.
In addition to case changes, we also make some other identifier renames:
  VIOsPAPR* -> SpaprVio*
    The reverse word ordering was only ever used to mitigate the capital
    cluster, so revert to the natural ordering.
  VIOsPAPRVTYDevice -> SpaprVioVty
  VIOsPAPRVLANDevice -> SpaprVioVlan
    Brevity, since the "Device" didn't add useful information
  sPAPRDRConnector -> SpaprDrc
  sPAPRDRConnectorClass -> SpaprDrcClass
    Brevity, and makes it clearer this is the same thing as a "DRC"
    mentioned in many other places in the code
This is 100% a mechanical search-and-replace patch.  It will, however,
conflict with essentially any and all outstanding patches touching the
spapr code.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
											
										 
											2019-03-06 15:35:37 +11:00
										 |  |  | void spapr_phb_dma_reset(SpaprPhbState *sphb); | 
					
						
							| 
									
										
										
										
											2016-06-01 18:57:39 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												spapr: Use CamelCase properly
The qemu coding standard is to use CamelCase for type and structure names,
and the pseries code follows that... sort of.  There are quite a lot of
places where we bend the rules in order to preserve the capitalization of
internal acronyms like "PHB", "TCE", "DIMM" and most commonly "sPAPR".
That was a bad idea - it frequently leads to names ending up with hard to
read clusters of capital letters, and means they don't catch the eye as
type identifiers, which is kind of the point of the CamelCase convention in
the first place.
In short, keeping type identifiers look like CamelCase is more important
than preserving standard capitalization of internal "words".  So, this
patch renames a heap of spapr internal type names to a more standard
CamelCase.
In addition to case changes, we also make some other identifier renames:
  VIOsPAPR* -> SpaprVio*
    The reverse word ordering was only ever used to mitigate the capital
    cluster, so revert to the natural ordering.
  VIOsPAPRVTYDevice -> SpaprVioVty
  VIOsPAPRVLANDevice -> SpaprVioVlan
    Brevity, since the "Device" didn't add useful information
  sPAPRDRConnector -> SpaprDrc
  sPAPRDRConnectorClass -> SpaprDrcClass
    Brevity, and makes it clearer this is the same thing as a "DRC"
    mentioned in many other places in the code
This is 100% a mechanical search-and-replace patch.  It will, however,
conflict with essentially any and all outstanding patches touching the
spapr code.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
											
										 
											2019-03-06 15:35:37 +11:00
										 |  |  | static inline unsigned spapr_phb_windows_supported(SpaprPhbState *sphb) | 
					
						
							| 
									
										
										
										
											2019-02-19 18:18:18 +01:00
										 |  |  | { | 
					
						
							|  |  |  |     return sphb->ddw_enabled ? SPAPR_PCI_DMA_MAX_WINDOWS : 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												spapr: Adjust firmware path of PCI devices
It is currently not possible to perform a strict boot from USB storage:
$ qemu-system-ppc64 -accel kvm -nodefaults -nographic -serial stdio \
	-boot strict=on \
	-device qemu-xhci \
	-device usb-storage,drive=disk,bootindex=0 \
	-blockdev driver=file,node-name=disk,filename=fedora-ppc64le.qcow2
SLOF **********************************************************************
QEMU Starting
 Build Date = Jul 17 2020 11:15:24
 FW Version = git-e18ddad8516ff2cf
 Press "s" to enter Open Firmware.
Populating /vdevice methods
Populating /vdevice/vty@71000000
Populating /vdevice/nvram@71000001
Populating /pci@800000020000000
                     00 0000 (D) : 1b36 000d    serial bus [ usb-xhci ]
No NVRAM common partition, re-initializing...
Scanning USB
  XHCI: Initializing
    USB Storage
       SCSI: Looking for devices
          101000000000000 DISK     : "QEMU     QEMU HARDDISK    2.5+"
Using default console: /vdevice/vty@71000000
  Welcome to Open Firmware
  Copyright (c) 2004, 2017 IBM Corporation All rights reserved.
  This program and the accompanying materials are made available
  under the terms of the BSD License available at
  http://www.opensource.org/licenses/bsd-license.php
Trying to load:  from: /pci@800000020000000/usb@0/storage@1/disk@101000000000000 ...
E3405: No such device
E3407: Load failed
  Type 'boot' and press return to continue booting the system.
  Type 'reset-all' and press return to reboot the system.
Ready!
0 >
The device tree handed over by QEMU to SLOF indeed contains:
qemu,boot-list =
	"/pci@800000020000000/usb@0/storage@1/disk@101000000000000 HALT";
but the device node is named usb-xhci@0, not usb@0.
This happens because the firmware names of PCI devices returned
by get_boot_devices_list() come from pcibus_get_fw_dev_path(),
while the sPAPR PHB code uses a different naming scheme for
device nodes. This inconsistency has always been there but it was
hidden for a long time because SLOF used to rename USB device
nodes, until this commit, merged in QEMU 4.2.0 :
commit 85164ad4ed9960cac842fa4cc067c6b6699b0994
Author: Alexey Kardashevskiy <aik@ozlabs.ru>
Date:   Wed Sep 11 16:24:32 2019 +1000
    pseries: Update SLOF firmware image
    This fixes USB host bus adapter name in the device tree to match QEMU's
    one.
    Signed-off-by: Alexey Kardashevskiy <aik@ozlabs.ru>
    Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Fortunately, sPAPR implements the firmware path provider interface.
This provides a way to override the default firmware paths.
Just factor out the sPAPR PHB naming logic from spapr_dt_pci_device()
to a helper, and use it in the sPAPR firmware path provider hook.
Fixes: 85164ad4ed99 ("pseries: Update SLOF firmware image")
Signed-off-by: Greg Kurz <groug@kaod.org>
Message-Id: <20210122170157.246374-1-groug@kaod.org>
Reviewed-by: Daniel Henrique Barboza <danielhb413@gmail.com>
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
											
										 
											2021-01-22 18:01:57 +01:00
										 |  |  | char *spapr_pci_fw_dev_name(PCIDevice *dev); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-29 10:12:57 +02:00
										 |  |  | #endif /* PCI_HOST_SPAPR_H */
 |