Re: [PATCH 5/7] ntb_hw_switchtec: Expand PFF CSR registers
From: Jon Mason
Date: Tue Dec 05 2017 - 14:12:38 EST
On Wed, Nov 29, 2017 at 12:55 PM, Logan Gunthorpe <logang@xxxxxxxxxxxx> wrote:
> The PFF CSR registers actual mirrors the PCI configuration space
> for all the ports in the switch. Previously, this was not needed by
> the driver but will be used by the crosslink code to enumerate the
> bus in an host-less centre partition.
>
> Signed-off-by: Logan Gunthorpe <logang@xxxxxxxxxxxx>
> ---
> include/linux/switchtec.h | 15 ++++++++++++++-
> 1 file changed, 14 insertions(+), 1 deletion(-)
>
> diff --git a/include/linux/switchtec.h b/include/linux/switchtec.h
> index d4a7c18b42cf..6d325a7a0c19 100644
> --- a/include/linux/switchtec.h
> +++ b/include/linux/switchtec.h
> @@ -292,7 +292,20 @@ enum {
> struct pff_csr_regs {
> u16 vendor_id;
> u16 device_id;
> - u32 pci_cfg_header[15];
> + u16 pcicmd;
> + u16 pcists;
> + u32 pci_class;
> + u32 pci_opts;
> + union {
> + u32 pci_bar[6];
> + u64 pci_bar64[3];
> + };
> + u32 pci_cardbus;
> + u32 pci_subsystem_id;
> + u32 pci_expansion_rom;
> + u32 pci_cap_ptr;
> + u32 reserved1;
> + u32 pci_irq;
It sucks that we don't already have a struct for PCI config space we
can reuse here. If you find the time, it would be good to add in the
future to reduce duplicate code here and in the PCI core. However,
this patch is fine without it.
Thanks,
Jon
> u32 pci_cap_region[48];
> u32 pcie_cap_region[448];
> u32 indirect_gas_window[128];
> --
> 2.11.0
>