diff options
author | Jim Quinlan <[email protected]> | 2022-07-25 11:12:53 -0400 |
---|---|---|
committer | Bjorn Helgaas <[email protected]> | 2022-07-27 11:53:03 -0500 |
commit | 9e6be018b26347c26a93e63fb50a37ee2c9311de (patch) | |
tree | 85f1f123ddadb8089618041315c19df0e3ca8da0 /drivers/fpga/xilinx-selectmap.c | |
parent | 0693b4207fd73c1a23edb21fbfc0020532f53fb9 (diff) |
PCI: brcmstb: Enable child bus device regulators from DT
Some platforms have power regulators for slots or devices below Root Ports.
On platforms like Raspberry Pi 4, these regulators are described in the
Root Port device tree node, since they logically belong to the Root Port,
not to the host bridge itself.
Add an .add_bus() hook (called when pci_alloc_child_bus() allocates the
secondary ("child") bus for a bridge), and look for such regulators. If we
find some, enable them before bringing up the link and enumerating devices
on the child bus.
Similarly, when pci_remove_bus() calls the ops->remove_bus() hook, disable
the regulators.
The regulators that may be described in a Root Port DT device are:
vpcie3v3
vpcie3v3aux
vpcie12v
These control power to the device downstream from the Root Port.
[bhelgaas: commit log, name hooks brcm_pcie_add_bus(), etc, since we only
support one set of subregulator info, save info in struct brcm_pcie instead
of dev->driver_data, move brcm_pcie_start_link() from probe to .add_bus()
(from subsequent patch)]
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Jim Quinlan <[email protected]>
Signed-off-by: Bjorn Helgaas <[email protected]>
Tested-by: Florian Fainelli <[email protected]>
Diffstat (limited to 'drivers/fpga/xilinx-selectmap.c')
0 files changed, 0 insertions, 0 deletions