| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | #ifndef ASMARM_PCI_H | 
|  | 2 | #define ASMARM_PCI_H | 
|  | 3 |  | 
|  | 4 | #ifdef __KERNEL__ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 5 | #include <asm-generic/pci-dma-compat.h> | 
| Rob Herring | dc8d966 | 2011-06-29 10:59:45 -0500 | [diff] [blame] | 6 | #include <asm-generic/pci-bridge.h> | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 7 |  | 
| Anton Vorontsov | 5288217 | 2010-04-19 13:20:49 +0100 | [diff] [blame] | 8 | #include <asm/mach/pci.h> /* for pci_sys_data */ | 
| Rob Herring | c9d95fb | 2011-06-28 21:16:13 -0500 | [diff] [blame^] | 9 |  | 
|  | 10 | extern unsigned long pcibios_min_io; | 
|  | 11 | #define PCIBIOS_MIN_IO pcibios_min_io | 
|  | 12 | extern unsigned long pcibios_min_mem; | 
|  | 13 | #define PCIBIOS_MIN_MEM pcibios_min_mem | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 14 |  | 
| Rob Herring | dc8d966 | 2011-06-29 10:59:45 -0500 | [diff] [blame] | 15 | static inline int pcibios_assign_all_busses(void) | 
|  | 16 | { | 
|  | 17 | return pci_has_flag(PCI_REASSIGN_ALL_RSRC); | 
|  | 18 | } | 
|  | 19 |  | 
| Anton Vorontsov | 5288217 | 2010-04-19 13:20:49 +0100 | [diff] [blame] | 20 | #ifdef CONFIG_PCI_DOMAINS | 
|  | 21 | static inline int pci_domain_nr(struct pci_bus *bus) | 
|  | 22 | { | 
|  | 23 | struct pci_sys_data *root = bus->sysdata; | 
|  | 24 |  | 
|  | 25 | return root->domain; | 
|  | 26 | } | 
|  | 27 |  | 
|  | 28 | static inline int pci_proc_domain(struct pci_bus *bus) | 
|  | 29 | { | 
|  | 30 | return pci_domain_nr(bus); | 
|  | 31 | } | 
|  | 32 | #endif /* CONFIG_PCI_DOMAINS */ | 
|  | 33 |  | 
| Mike Rapoport | a8fc078 | 2007-09-23 15:59:52 +0100 | [diff] [blame] | 34 | #ifdef CONFIG_PCI_HOST_ITE8152 | 
|  | 35 | /* ITE bridge requires setting latency timer to avoid early bus access | 
|  | 36 | termination by PIC bus mater devices | 
|  | 37 | */ | 
|  | 38 | extern void pcibios_set_master(struct pci_dev *dev); | 
|  | 39 | #else | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 40 | static inline void pcibios_set_master(struct pci_dev *dev) | 
|  | 41 | { | 
|  | 42 | /* No special bus mastering setup handling */ | 
|  | 43 | } | 
| Mike Rapoport | a8fc078 | 2007-09-23 15:59:52 +0100 | [diff] [blame] | 44 | #endif | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 45 |  | 
| David Shaohua Li | c9c3e45 | 2005-04-01 00:07:31 -0500 | [diff] [blame] | 46 | static inline void pcibios_penalize_isa_irq(int irq, int active) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 47 | { | 
|  | 48 | /* We don't do dynamic PCI IRQ allocation */ | 
|  | 49 | } | 
|  | 50 |  | 
|  | 51 | /* | 
|  | 52 | * The PCI address space does equal the physical memory address space. | 
|  | 53 | * The networking and block device layers use this boolean for bounce | 
|  | 54 | * buffer decisions. | 
|  | 55 | */ | 
| Russell King | 88c381b | 2008-09-13 21:23:06 +0100 | [diff] [blame] | 56 | #define PCI_DMA_BUS_IS_PHYS     (1) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 57 |  | 
| Andrew Morton | bb4a61b | 2005-06-06 23:07:46 -0700 | [diff] [blame] | 58 | #ifdef CONFIG_PCI | 
| David S. Miller | e24c2d9 | 2005-06-02 12:55:50 -0700 | [diff] [blame] | 59 | static inline void pci_dma_burst_advice(struct pci_dev *pdev, | 
|  | 60 | enum pci_dma_burst_strategy *strat, | 
|  | 61 | unsigned long *strategy_parameter) | 
|  | 62 | { | 
|  | 63 | *strat = PCI_DMA_BURST_INFINITY; | 
|  | 64 | *strategy_parameter = ~0UL; | 
|  | 65 | } | 
| Andrew Morton | bb4a61b | 2005-06-06 23:07:46 -0700 | [diff] [blame] | 66 | #endif | 
| David S. Miller | e24c2d9 | 2005-06-02 12:55:50 -0700 | [diff] [blame] | 67 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 68 | #define HAVE_PCI_MMAP | 
|  | 69 | extern int pci_mmap_page_range(struct pci_dev *dev, struct vm_area_struct *vma, | 
|  | 70 | enum pci_mmap_state mmap_state, int write_combine); | 
|  | 71 |  | 
|  | 72 | extern void | 
|  | 73 | pcibios_resource_to_bus(struct pci_dev *dev, struct pci_bus_region *region, | 
|  | 74 | struct resource *res); | 
|  | 75 |  | 
| Dominik Brodowski | 43c3473 | 2005-08-04 18:06:21 -0700 | [diff] [blame] | 76 | extern void | 
|  | 77 | pcibios_bus_to_resource(struct pci_dev *dev, struct resource *res, | 
|  | 78 | struct pci_bus_region *region); | 
|  | 79 |  | 
| Russell King | dd438e7 | 2008-07-25 20:55:52 +0100 | [diff] [blame] | 80 | /* | 
|  | 81 | * Dummy implementation; always return 0. | 
|  | 82 | */ | 
|  | 83 | static inline int pci_get_legacy_ide_irq(struct pci_dev *dev, int channel) | 
|  | 84 | { | 
|  | 85 | return 0; | 
|  | 86 | } | 
|  | 87 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 88 | #endif /* __KERNEL__ */ | 
|  | 89 |  | 
|  | 90 | #endif |