cregit-Linux how code gets into the kernel

Release 4.11 arch/powerpc/platforms/pseries/pci_dlpar.c

/*
 * PCI Dynamic LPAR, PCI Hot Plug and PCI EEH recovery code
 * for RPA-compliant PPC64 platform.
 * Copyright (C) 2003 Linda Xie <lxie@us.ibm.com>
 * Copyright (C) 2005 International Business Machines
 *
 * Updates, 2005, John Rose <johnrose@austin.ibm.com>
 * Updates, 2005, Linas Vepstas <linas@austin.ibm.com>
 *
 * All rights reserved.
 *
 * 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, GOOD TITLE or
 * NON INFRINGEMENT.  See the GNU General Public License for more
 * details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 */

#include <linux/pci.h>
#include <linux/export.h>
#include <asm/pci-bridge.h>
#include <asm/ppc-pci.h>
#include <asm/firmware.h>
#include <asm/eeh.h>

#include "pseries.h"


struct pci_controller *init_phb_dynamic(struct device_node *dn) { struct pci_controller *phb; pr_debug("PCI: Initializing new hotplug PHB %s\n", dn->full_name); phb = pcibios_alloc_controller(dn); if (!phb) return NULL; rtas_setup_phb(phb); pci_process_bridge_OF_ranges(phb, dn, 0); phb->controller_ops = pseries_pci_controller_ops; pci_devs_phb_init_dynamic(phb); /* Create EEH devices for the PHB */ eeh_dev_phb_init_dynamic(phb); if (dn->child) eeh_add_device_tree_early(PCI_DN(dn)); pcibios_scan_phb(phb); pcibios_finish_adding_to_bus(phb->bus); return phb; }

Contributors

PersonTokensPropCommitsCommitProp
John Rose6463.37%112.50%
Benjamin Herrenschmidt1514.85%225.00%
Gavin Shan98.91%225.00%
Nathan Fontenot65.94%112.50%
Daniel Axtens65.94%112.50%
Grant C. Likely10.99%112.50%
Total101100.00%8100.00%

EXPORT_SYMBOL_GPL(init_phb_dynamic); /* RPA-specific bits for removing PHBs */
int remove_phb_dynamic(struct pci_controller *phb) { struct pci_bus *b = phb->bus; struct resource *res; int rc, i; pr_debug("PCI: Removing PHB %04x:%02x...\n", pci_domain_nr(b), b->number); /* We cannot to remove a root bus that has children */ if (!(list_empty(&b->children) && list_empty(&b->devices))) return -EBUSY; /* We -know- there aren't any child devices anymore at this stage * and thus, we can safely unmap the IO space as it's not in use */ res = &phb->io_resource; if (res->flags & IORESOURCE_IO) { rc = pcibios_unmap_io_space(b); if (rc) { printk(KERN_ERR "%s: failed to unmap IO on bus %s\n", __func__, b->name); return 1; } } /* Remove the PCI bus and unregister the bridge device from sysfs */ phb->bus = NULL; pci_remove_bus(b); device_unregister(b->bridge); /* Now release the IO resource */ if (res->flags & IORESOURCE_IO) release_resource(res); /* Release memory resources */ for (i = 0; i < 3; ++i) { res = &phb->mem_resources[i]; if (!(res->flags & IORESOURCE_MEM)) continue; release_resource(res); } /* * The pci_controller data structure is freed by * the pcibios_free_controller_deferred() callback; * see pseries_root_bridge_prepare(). */ return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Benjamin Herrenschmidt16886.15%116.67%
John Rose126.15%116.67%
Tyrel Datwyler84.10%116.67%
Linas Vepstas52.56%116.67%
Frans Pop10.51%116.67%
Mauricio Faria de Oliveira10.51%116.67%
Total195100.00%6100.00%

EXPORT_SYMBOL_GPL(remove_phb_dynamic);

Overall Contributors

PersonTokensPropCommitsCommitProp
Benjamin Herrenschmidt19258.36%318.75%
John Rose8425.53%16.25%
Linas Vepstas123.65%212.50%
Daniel Axtens92.74%16.25%
Gavin Shan92.74%212.50%
Tyrel Datwyler82.43%16.25%
Nathan Fontenot61.82%16.25%
Paul Gortmaker30.91%16.25%
Olaf Hering30.91%16.25%
Mauricio Faria de Oliveira10.30%16.25%
Grant C. Likely10.30%16.25%
Frans Pop10.30%16.25%
Total329100.00%16100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.