1 /* SPDX-License-Identifier: GPL-2.0-only */
3 * Copyright (C) 2016 SiFive
6 #ifndef _ASM_RISCV_PCI_H
7 #define _ASM_RISCV_PCI_H
9 #include <linux/types.h>
10 #include <linux/slab.h>
11 #include <linux/dma-mapping.h>
15 #define PCIBIOS_MIN_IO 0
16 #define PCIBIOS_MIN_MEM 0
18 /* RISC-V shim does not initialize PCI bus */
19 #define pcibios_assign_all_busses() 1
21 extern int isa_dma_bridge_buggy;
24 static inline int pci_get_legacy_ide_irq(struct pci_dev *dev, int channel)
26 /* no legacy IRQ on risc-v */
30 static inline int pci_proc_domain(struct pci_bus *bus)
32 /* always show the domain in /proc */
38 static inline int pcibus_to_node(struct pci_bus *bus)
40 return dev_to_node(&bus->dev);
42 #ifndef cpumask_of_pcibus
43 #define cpumask_of_pcibus(bus) (pcibus_to_node(bus) == -1 ? \
45 cpumask_of_node(pcibus_to_node(bus)))
47 #endif /* CONFIG_NUMA */
49 #endif /* CONFIG_PCI */
51 #endif /* _ASM_RISCV_PCI_H */