mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 11:18:45 +07:00
1b6115fbe3
-----BEGIN PGP SIGNATURE----- Version: GnuPG v1 iQIcBAABAgAGBQJaDFIdAAoJEFmIoMA60/r8Jg4P/3IrmMNVnpqmYEZ7lRSW7UQ3 8jtupbzIkbPsIAEhbJ7xqO7zKx85j6Og+ZSOv4a8u/tS6cd1aVZu2PpWsTkacez0 7nLGVCSL3HZi5qcrtOvb2Pmke18SUKSPxVYSgS2ajQavB1oKaY03FbHDWyWidCZx qxkeGZOiUDw5kSGkQWyks1WgB0dd76rVbPcrKKEJueGgrdSm+EdgdDv8eT6bZInZ uMrCmSjNYTQP0KASCJJvgYOtJbdwvP6NuQTxzOlU2G+H2SqsLRjsz4UUR8FF06T5 cndpgpG3QSAZLx7wCeWTvRorTEYORzKMoyw/AUjhiGbRep9Zw0aKNvCC99E6xjyD FECrk6kCrqZs7l+LVXK4SwpBXCVjNgRoFAHBEKF2X3/SWUkUhHXZHCVvMQB8LQiS 2p8VRoYWw2aCLkHCGynuzToUrD2P2Pjxe5n/13aYVJkyBNfQqqZ3l2YHiZdpDO3j rgG6RW0WCrpZxfb/0WAbPnQ2qpZAwDPO6hOW7dIfTZabFVXRIkBvNq53by/0MxvP jyOcMTsq2l8y46f3VgNPUAHj0f52HwfZA3PQRPh+MQDz5385BJklDRWtfVM7cQx9 IoeGkq1zLLvpOh63he/jnnRELxDvNVcxND8lOkenJlObj9kK63hUEcXg/zEMS4w3 oetLw9TqE32Jb7GfpVSw =j4L3 -----END PGP SIGNATURE----- Merge tag 'pci-v4.15-changes' of git://git.kernel.org/pub/scm/linux/kernel/git/helgaas/pci Pull PCI updates from Bjorn Helgaas: - detach driver before tearing down procfs/sysfs (Alex Williamson) - disable PCIe services during shutdown (Sinan Kaya) - fix ASPM oops on systems with no Root Ports (Ard Biesheuvel) - fix ASPM LTR_L1.2_THRESHOLD programming (Bjorn Helgaas) - fix ASPM Common_Mode_Restore_Time computation (Bjorn Helgaas) - fix portdrv MSI/MSI-X vector allocation (Dongdong Liu, Bjorn Helgaas) - report non-fatal AER errors only to the affected endpoint (Gabriele Paoloni) - distribute bus numbers, MMIO, and I/O space among hotplug bridges to allow more devices to be hot-added (Mika Westerberg) - fix pciehp races during initialization and surprise link down (Mika Westerberg) - handle surprise-removed devices in PME handling (Qiang) - support resizable BARs for large graphics devices (Christian König) - expose SR-IOV offset, stride, and VF device ID via sysfs (Filippo Sironi) - create SR-IOV virtfn/physfn sysfs links before attaching driver (Stuart Hayes) - fix SR-IOV "ARI Capable Hierarchy" restore issue (Tony Nguyen) - enforce Kconfig IOV/REALLOC dependency (Sascha El-Sharkawy) - avoid slot reset if bridge itself is broken (Jan Glauber) - clean up pci_reset_function() path (Jan H. Schönherr) - make pci_map_rom() fail if the option ROM is invalid (Changbin Du) - convert timers to timer_setup() (Kees Cook) - move PCI_QUIRKS to PCI bus Kconfig menu (Randy Dunlap) - constify pci_dev_type and intel_mid_pci_ops (Bhumika Goyal) - remove unnecessary pci_dev, pci_bus, resource, pcibios_set_master() declarations (Bjorn Helgaas) - fix endpoint framework overflows and BUG()s (Dan Carpenter) - fix endpoint framework issues (Kishon Vijay Abraham I) - avoid broken Cavium CN8xxx bus reset behavior (David Daney) - extend Cavium ACS capability quirks (Vadim Lomovtsev) - support Synopsys DesignWare RC in ECAM mode (Ard Biesheuvel) - turn off dra7xx clocks cleanly on shutdown (Keerthy) - fix Faraday probe error path (Wei Yongjun) - support HiSilicon STB SoC PCIe host controller (Jianguo Sun) - fix Hyper-V interrupt affinity issue (Dexuan Cui) - remove useless ACPI warning for Hyper-V pass-through devices (Vitaly Kuznetsov) - support multiple MSI on iProc (Sandor Bodo-Merle) - support Layerscape LS1012a and LS1046a PCIe host controllers (Hou Zhiqiang) - fix Layerscape default error response (Minghuan Lian) - support MSI on Tango host controller (Marc Gonzalez) - support Tegra186 PCIe host controller (Manikanta Maddireddy) - use generic accessors on Tegra when possible (Thierry Reding) - support V3 Semiconductor PCI host controller (Linus Walleij) * tag 'pci-v4.15-changes' of git://git.kernel.org/pub/scm/linux/kernel/git/helgaas/pci: (85 commits) PCI/ASPM: Add L1 Substates definitions PCI/ASPM: Reformat ASPM register definitions PCI/ASPM: Use correct capability pointer to program LTR_L1.2_THRESHOLD PCI/ASPM: Account for downstream device's Port Common_Mode_Restore_Time PCI: xgene: Rename xgene_pcie_probe_bridge() to xgene_pcie_probe() PCI: xilinx: Rename xilinx_pcie_link_is_up() to xilinx_pcie_link_up() PCI: altera: Rename altera_pcie_link_is_up() to altera_pcie_link_up() PCI: Fix kernel-doc build warning PCI: Fail pci_map_rom() if the option ROM is invalid PCI: Move pci_map_rom() error path PCI: Move PCI_QUIRKS to the PCI bus menu alpha/PCI: Make pdev_save_srm_config() static PCI: Remove unused declarations PCI: Remove redundant pci_dev, pci_bus, resource declarations PCI: Remove redundant pcibios_set_master() declarations PCI/PME: Handle invalid data when reading Root Status PCI: hv: Use effective affinity mask PCI: pciehp: Do not clear Presence Detect Changed during initialization PCI: pciehp: Fix race condition handling surprise link down PCI: Distribute available resources to hotplug-capable bridges ...
195 lines
6.3 KiB
C
195 lines
6.3 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* linux/arch/alpha/kernel/pci_impl.h
|
|
*
|
|
* This file contains declarations and inline functions for interfacing
|
|
* with the PCI initialization routines.
|
|
*/
|
|
|
|
struct pci_dev;
|
|
struct pci_controller;
|
|
struct pci_iommu_arena;
|
|
|
|
/*
|
|
* We can't just blindly use 64K for machines with EISA busses; they
|
|
* may also have PCI-PCI bridges present, and then we'd configure the
|
|
* bridge incorrectly.
|
|
*
|
|
* Also, we start at 0x8000 or 0x9000, in hopes to get all devices'
|
|
* IO space areas allocated *before* 0xC000; this is because certain
|
|
* BIOSes (Millennium for one) use PCI Config space "mechanism #2"
|
|
* accesses to probe the bus. If a device's registers appear at 0xC000,
|
|
* it may see an INx/OUTx at that address during BIOS emulation of the
|
|
* VGA BIOS, and some cards, notably Adaptec 2940UW, take mortal offense.
|
|
*/
|
|
|
|
#define EISA_DEFAULT_IO_BASE 0x9000 /* start above 8th slot */
|
|
#define DEFAULT_IO_BASE 0x8000 /* start at 8th slot */
|
|
|
|
/*
|
|
* We try to make the DEFAULT_MEM_BASE addresses *always* have more than
|
|
* a single bit set. This is so that devices like the broken Myrinet card
|
|
* will always have a PCI memory address that will never match a IDSEL
|
|
* address in PCI Config space, which can cause problems with early rev cards.
|
|
*/
|
|
|
|
/*
|
|
* An XL is AVANTI (APECS) family, *but* it has only 27 bits of ISA address
|
|
* that get passed through the PCI<->ISA bridge chip. Although this causes
|
|
* us to set the PCI->Mem window bases lower than normal, we still allocate
|
|
* PCI bus devices' memory addresses *below* the low DMA mapping window,
|
|
* and hope they fit below 64Mb (to avoid conflicts), and so that they can
|
|
* be accessed via SPARSE space.
|
|
*
|
|
* We accept the risk that a broken Myrinet card will be put into a true XL
|
|
* and thus can more easily run into the problem described below.
|
|
*/
|
|
#define XL_DEFAULT_MEM_BASE ((16+2)*1024*1024) /* 16M to 64M-1 is avail */
|
|
|
|
/*
|
|
* APECS and LCA have only 34 bits for physical addresses, thus limiting PCI
|
|
* bus memory addresses for SPARSE access to be less than 128Mb.
|
|
*/
|
|
#define APECS_AND_LCA_DEFAULT_MEM_BASE ((16+2)*1024*1024)
|
|
|
|
/*
|
|
* Because MCPCIA and T2 core logic support more bits for
|
|
* physical addresses, they should allow an expanded range of SPARSE
|
|
* memory addresses. However, we do not use them all, in order to
|
|
* avoid the HAE manipulation that would be needed.
|
|
*/
|
|
#define MCPCIA_DEFAULT_MEM_BASE ((32+2)*1024*1024)
|
|
#define T2_DEFAULT_MEM_BASE ((16+1)*1024*1024)
|
|
|
|
/*
|
|
* Because CIA and PYXIS have more bits for physical addresses,
|
|
* they support an expanded range of SPARSE memory addresses.
|
|
*/
|
|
#define DEFAULT_MEM_BASE ((128+16)*1024*1024)
|
|
|
|
/* ??? Experimenting with no HAE for CIA. */
|
|
#define CIA_DEFAULT_MEM_BASE ((32+2)*1024*1024)
|
|
|
|
#define IRONGATE_DEFAULT_MEM_BASE ((256*8-16)*1024*1024)
|
|
|
|
#define DEFAULT_AGP_APER_SIZE (64*1024*1024)
|
|
|
|
/*
|
|
* A small note about bridges and interrupts. The DECchip 21050 (and
|
|
* later) adheres to the PCI-PCI bridge specification. This says that
|
|
* the interrupts on the other side of a bridge are swizzled in the
|
|
* following manner:
|
|
*
|
|
* Dev Interrupt Interrupt
|
|
* Pin on Pin on
|
|
* Device Connector
|
|
*
|
|
* 4 A A
|
|
* B B
|
|
* C C
|
|
* D D
|
|
*
|
|
* 5 A B
|
|
* B C
|
|
* C D
|
|
* D A
|
|
*
|
|
* 6 A C
|
|
* B D
|
|
* C A
|
|
* D B
|
|
*
|
|
* 7 A D
|
|
* B A
|
|
* C B
|
|
* D C
|
|
*
|
|
* Where A = pin 1, B = pin 2 and so on and pin=0 = default = A.
|
|
* Thus, each swizzle is ((pin-1) + (device#-4)) % 4
|
|
*
|
|
* pci_swizzle_interrupt_pin() swizzles for exactly one bridge. The routine
|
|
* pci_common_swizzle() handles multiple bridges. But there are a
|
|
* couple boards that do strange things.
|
|
*/
|
|
|
|
|
|
/* The following macro is used to implement the table-based irq mapping
|
|
function for all single-bus Alphas. */
|
|
|
|
#define COMMON_TABLE_LOOKUP \
|
|
({ long _ctl_ = -1; \
|
|
if (slot >= min_idsel && slot <= max_idsel && pin < irqs_per_slot) \
|
|
_ctl_ = irq_tab[slot - min_idsel][pin]; \
|
|
_ctl_; })
|
|
|
|
|
|
/* A PCI IOMMU allocation arena. There are typically two of these
|
|
regions per bus. */
|
|
/* ??? The 8400 has a 32-byte pte entry, and the entire table apparently
|
|
lives directly on the host bridge (no tlb?). We don't support this
|
|
machine, but if we ever did, we'd need to parameterize all this quite
|
|
a bit further. Probably with per-bus operation tables. */
|
|
|
|
struct pci_iommu_arena
|
|
{
|
|
spinlock_t lock;
|
|
struct pci_controller *hose;
|
|
#define IOMMU_INVALID_PTE 0x2 /* 32:63 bits MBZ */
|
|
#define IOMMU_RESERVED_PTE 0xface
|
|
unsigned long *ptes;
|
|
dma_addr_t dma_base;
|
|
unsigned int size;
|
|
unsigned int next_entry;
|
|
unsigned int align_entry;
|
|
};
|
|
|
|
#if defined(CONFIG_ALPHA_SRM) && \
|
|
(defined(CONFIG_ALPHA_CIA) || defined(CONFIG_ALPHA_LCA))
|
|
# define NEED_SRM_SAVE_RESTORE
|
|
#else
|
|
# undef NEED_SRM_SAVE_RESTORE
|
|
#endif
|
|
|
|
#if defined(CONFIG_ALPHA_GENERIC) || defined(NEED_SRM_SAVE_RESTORE)
|
|
# define ALPHA_RESTORE_SRM_SETUP
|
|
#else
|
|
# undef ALPHA_RESTORE_SRM_SETUP
|
|
#endif
|
|
|
|
#ifdef ALPHA_RESTORE_SRM_SETUP
|
|
extern void pci_restore_srm_config(void);
|
|
#else
|
|
#define pci_restore_srm_config() do {} while (0)
|
|
#endif
|
|
|
|
/* The hose list. */
|
|
extern struct pci_controller *hose_head, **hose_tail;
|
|
extern struct pci_controller *pci_isa_hose;
|
|
|
|
extern unsigned long alpha_agpgart_size;
|
|
|
|
extern void common_init_pci(void);
|
|
#define common_swizzle pci_common_swizzle
|
|
extern struct pci_controller *alloc_pci_controller(void);
|
|
extern struct resource *alloc_resource(void);
|
|
|
|
extern struct pci_iommu_arena *iommu_arena_new_node(int,
|
|
struct pci_controller *,
|
|
dma_addr_t, unsigned long,
|
|
unsigned long);
|
|
extern struct pci_iommu_arena *iommu_arena_new(struct pci_controller *,
|
|
dma_addr_t, unsigned long,
|
|
unsigned long);
|
|
extern const char *const pci_io_names[];
|
|
extern const char *const pci_mem_names[];
|
|
extern const char pci_hae0_name[];
|
|
|
|
extern unsigned long size_for_memory(unsigned long max);
|
|
|
|
extern int iommu_reserve(struct pci_iommu_arena *, long, long);
|
|
extern int iommu_release(struct pci_iommu_arena *, long, long);
|
|
extern int iommu_bind(struct pci_iommu_arena *, long, long, struct page **);
|
|
extern int iommu_unbind(struct pci_iommu_arena *, long, long);
|
|
|
|
|