2018-01-26 12:50:27 -06:00
// SPDX-License-Identifier: GPL-2.0
2016-03-11 15:35:55 -06:00
/*
2016-08-22 17:59:48 -04:00
* Generic PCI host driver common code
*
2016-03-11 15:35:55 -06:00
* Copyright ( C ) 2014 ARM Limited
*
* Author : Will Deacon < will . deacon @ arm . com >
*/
# include <linux/kernel.h>
2020-04-09 17:49:22 -06:00
# include <linux/module.h>
2016-03-11 15:35:55 -06:00
# include <linux/of_address.h>
2020-04-09 17:49:23 -06:00
# include <linux/of_device.h>
2016-03-11 15:35:55 -06:00
# include <linux/of_pci.h>
2016-06-10 21:55:09 +02:00
# include <linux/pci-ecam.h>
2016-03-11 15:35:55 -06:00
# include <linux/platform_device.h>
2016-05-11 17:34:46 -05:00
static void gen_pci_unmap_cfg ( void * ptr )
{
pci_ecam_free ( ( struct pci_config_window * ) ptr ) ;
}
static struct pci_config_window * gen_pci_init ( struct device * dev ,
2020-05-22 17:48:20 -06:00
struct pci_host_bridge * bridge , const struct pci_ecam_ops * ops )
2016-03-11 15:35:55 -06:00
{
int err ;
2016-05-11 17:34:46 -05:00
struct resource cfgres ;
2020-07-21 20:25:13 -06:00
struct resource_entry * bus ;
2016-05-11 17:34:46 -05:00
struct pci_config_window * cfg ;
2016-03-11 15:35:55 -06:00
2016-05-11 17:34:46 -05:00
err = of_address_to_resource ( dev - > of_node , 0 , & cfgres ) ;
2016-03-11 15:35:55 -06:00
if ( err ) {
dev_err ( dev , " missing \" reg \" property \n " ) ;
2020-05-22 17:48:20 -06:00
return ERR_PTR ( err ) ;
2016-03-11 15:35:55 -06:00
}
2020-07-21 20:25:13 -06:00
bus = resource_list_first_type ( & bridge - > windows , IORESOURCE_BUS ) ;
if ( ! bus )
return ERR_PTR ( - ENODEV ) ;
cfg = pci_ecam_create ( dev , & cfgres , bus - > res , ops ) ;
2020-05-22 17:48:20 -06:00
if ( IS_ERR ( cfg ) )
return cfg ;
2016-03-11 15:35:55 -06:00
2019-07-08 20:33:54 +08:00
err = devm_add_action_or_reset ( dev , gen_pci_unmap_cfg , cfg ) ;
2020-05-22 17:48:20 -06:00
if ( err )
return ERR_PTR ( err ) ;
2016-05-11 17:34:46 -05:00
2020-05-22 17:48:20 -06:00
return cfg ;
2016-03-11 15:35:55 -06:00
}
2020-04-09 17:49:23 -06:00
int pci_host_common_probe ( struct platform_device * pdev )
2016-03-11 15:35:55 -06:00
{
struct device * dev = & pdev - > dev ;
2017-06-28 15:14:00 -05:00
struct pci_host_bridge * bridge ;
2016-05-11 17:34:46 -05:00
struct pci_config_window * cfg ;
2020-04-09 17:49:23 -06:00
const struct pci_ecam_ops * ops ;
2017-06-28 15:14:00 -05:00
2020-04-09 17:49:23 -06:00
ops = of_device_get_match_data ( & pdev - > dev ) ;
if ( ! ops )
return - ENODEV ;
2017-06-28 15:14:00 -05:00
bridge = devm_pci_alloc_host_bridge ( dev , 0 ) ;
if ( ! bridge )
return - ENOMEM ;
2016-03-11 15:35:55 -06:00
2021-01-25 16:29:31 +00:00
platform_set_drvdata ( pdev , bridge ) ;
2016-03-11 15:35:55 -06:00
of_pci_check_probe_only ( ) ;
/* Parse and map our Configuration Space windows */
2020-05-22 17:48:20 -06:00
cfg = gen_pci_init ( dev , bridge , ops ) ;
2016-05-11 17:34:46 -05:00
if ( IS_ERR ( cfg ) )
return PTR_ERR ( cfg ) ;
2016-03-11 15:35:55 -06:00
/* Do not reassign resources if probe only */
if ( ! pci_has_flag ( PCI_PROBE_ONLY ) )
PCI: Remove PCI_REASSIGN_ALL_RSRC use on arm and arm64
On arm, PCI_REASSIGN_ALL_RSRC is used only in pcibios_assign_all_busses(),
which helps decide whether to reconfigure bridge bus numbers. It has
nothing to do with BAR assignments. On arm64 and powerpc,
pcibios_assign_all_busses() tests PCI_REASSIGN_ALL_BUS, which makes more
sense.
Align arm with arm64 and powerpc, so they all use PCI_REASSIGN_ALL_BUS for
pcibios_assign_all_busses().
Remove PCI_REASSIGN_ALL_RSRC from the generic, Tegra, Versatile, and
R-Car drivers. These drivers are used only on arm or arm64, where
PCI_REASSIGN_ALL_RSRC is not used after this change, so removing it
should have no effect.
No functional change intended.
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Reviewed-by: Manikanta Maddireddy <mmaddireddy@nvidia.com>
Reviewed-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
2017-11-30 11:21:57 -06:00
pci_add_flags ( PCI_REASSIGN_ALL_BUS ) ;
2016-03-11 15:35:55 -06:00
2017-06-28 15:14:00 -05:00
bridge - > sysdata = cfg ;
2020-04-09 17:49:21 -06:00
bridge - > ops = ( struct pci_ops * ) & ops - > pci_ops ;
2021-03-30 16:11:42 +01:00
bridge - > msi_domain = true ;
2017-06-28 15:14:00 -05:00
2020-05-22 17:48:20 -06:00
return pci_host_probe ( bridge ) ;
2018-05-15 11:07:06 +02:00
}
2020-04-09 17:49:22 -06:00
EXPORT_SYMBOL_GPL ( pci_host_common_probe ) ;
2018-05-15 11:07:06 +02:00
int pci_host_common_remove ( struct platform_device * pdev )
{
2020-05-22 17:48:20 -06:00
struct pci_host_bridge * bridge = platform_get_drvdata ( pdev ) ;
2018-05-15 11:07:06 +02:00
pci_lock_rescan_remove ( ) ;
2020-05-22 17:48:20 -06:00
pci_stop_root_bus ( bridge - > bus ) ;
pci_remove_root_bus ( bridge - > bus ) ;
2018-05-15 11:07:06 +02:00
pci_unlock_rescan_remove ( ) ;
2016-03-11 15:35:55 -06:00
return 0 ;
}
2020-04-09 17:49:22 -06:00
EXPORT_SYMBOL_GPL ( pci_host_common_remove ) ;
MODULE_LICENSE ( " GPL v2 " ) ;