aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/microblaze/include/asm/pci-bridge.h67
-rw-r--r--arch/powerpc/include/asm/pci-bridge.h50
-rw-r--r--include/asm-generic/pci-bridge.h62
3 files changed, 73 insertions, 106 deletions
diff --git a/arch/microblaze/include/asm/pci-bridge.h b/arch/microblaze/include/asm/pci-bridge.h
index 746df91e5796..4cae1d590130 100644
--- a/arch/microblaze/include/asm/pci-bridge.h
+++ b/arch/microblaze/include/asm/pci-bridge.h
@@ -10,31 +10,19 @@
10#include <linux/pci.h> 10#include <linux/pci.h>
11#include <linux/list.h> 11#include <linux/list.h>
12#include <linux/ioport.h> 12#include <linux/ioport.h>
13#include <asm-generic/pci-bridge.h>
13 14
14struct device_node; 15struct device_node;
15 16
16enum { 17#ifdef CONFIG_PCI
17 /* Force re-assigning all resources (ignore firmware 18extern struct list_head hose_list;
18 * setup completely) 19extern int pcibios_vaddr_is_ioport(void __iomem *address);
19 */ 20#else
20 PCI_REASSIGN_ALL_RSRC = 0x00000001, 21static inline int pcibios_vaddr_is_ioport(void __iomem *address)
21 22{
22 /* Re-assign all bus numbers */ 23 return 0;
23 PCI_REASSIGN_ALL_BUS = 0x00000002, 24}
24 25#endif
25 /* Do not try to assign, just use existing setup */
26 PCI_PROBE_ONLY = 0x00000004,
27
28 /* Don't bother with ISA alignment unless the bridge has
29 * ISA forwarding enabled
30 */
31 PCI_CAN_SKIP_ISA_ALIGN = 0x00000008,
32
33 /* Enable domain numbers in /proc */
34 PCI_ENABLE_PROC_DOMAINS = 0x00000010,
35 /* ... except for domain 0 */
36 PCI_COMPAT_DOMAIN_0 = 0x00000020,
37};
38 26
39/* 27/*
40 * Structure of a PCI controller (host bridge) 28 * Structure of a PCI controller (host bridge)
@@ -164,40 +152,5 @@ extern struct pci_controller *pcibios_alloc_controller(struct device_node *dev);
164extern void pcibios_free_controller(struct pci_controller *phb); 152extern void pcibios_free_controller(struct pci_controller *phb);
165extern void pcibios_setup_phb_resources(struct pci_controller *hose); 153extern void pcibios_setup_phb_resources(struct pci_controller *hose);
166 154
167#ifdef CONFIG_PCI
168extern unsigned int pci_flags;
169
170static inline void pci_set_flags(int flags)
171{
172 pci_flags = flags;
173}
174
175static inline void pci_add_flags(int flags)
176{
177 pci_flags |= flags;
178}
179
180static inline int pci_has_flag(int flag)
181{
182 return pci_flags & flag;
183}
184
185extern struct list_head hose_list;
186
187extern int pcibios_vaddr_is_ioport(void __iomem *address);
188#else
189static inline int pcibios_vaddr_is_ioport(void __iomem *address)
190{
191 return 0;
192}
193
194static inline void pci_set_flags(int flags) { }
195static inline void pci_add_flags(int flags) { }
196static inline int pci_has_flag(int flag)
197{
198 return 0;
199}
200#endif /* CONFIG_PCI */
201
202#endif /* __KERNEL__ */ 155#endif /* __KERNEL__ */
203#endif /* _ASM_MICROBLAZE_PCI_BRIDGE_H */ 156#endif /* _ASM_MICROBLAZE_PCI_BRIDGE_H */
diff --git a/arch/powerpc/include/asm/pci-bridge.h b/arch/powerpc/include/asm/pci-bridge.h
index b3a40c3d5000..8a9cb9f3ed02 100644
--- a/arch/powerpc/include/asm/pci-bridge.h
+++ b/arch/powerpc/include/asm/pci-bridge.h
@@ -10,58 +10,10 @@
10#include <linux/pci.h> 10#include <linux/pci.h>
11#include <linux/list.h> 11#include <linux/list.h>
12#include <linux/ioport.h> 12#include <linux/ioport.h>
13#include <asm-generic/pci-bridge.h>
13 14
14struct device_node; 15struct device_node;
15 16
16enum {
17 /* Force re-assigning all resources (ignore firmware
18 * setup completely)
19 */
20 PCI_REASSIGN_ALL_RSRC = 0x00000001,
21
22 /* Re-assign all bus numbers */
23 PCI_REASSIGN_ALL_BUS = 0x00000002,
24
25 /* Do not try to assign, just use existing setup */
26 PCI_PROBE_ONLY = 0x00000004,
27
28 /* Don't bother with ISA alignment unless the bridge has
29 * ISA forwarding enabled
30 */
31 PCI_CAN_SKIP_ISA_ALIGN = 0x00000008,
32
33 /* Enable domain numbers in /proc */
34 PCI_ENABLE_PROC_DOMAINS = 0x00000010,
35 /* ... except for domain 0 */
36 PCI_COMPAT_DOMAIN_0 = 0x00000020,
37};
38#ifdef CONFIG_PCI
39extern unsigned int pci_flags;
40
41static inline void pci_set_flags(int flags)
42{
43 pci_flags = flags;
44}
45
46static inline void pci_add_flags(int flags)
47{
48 pci_flags |= flags;
49}
50
51static inline int pci_has_flag(int flag)
52{
53 return (pci_flags & flag);
54}
55#else
56static inline void pci_set_flags(int flags) { }
57static inline void pci_add_flags(int flags) { }
58static inline int pci_has_flag(int flag)
59{
60 return 0;
61}
62#endif
63
64
65/* 17/*
66 * Structure of a PCI controller (host bridge) 18 * Structure of a PCI controller (host bridge)
67 */ 19 */
diff --git a/include/asm-generic/pci-bridge.h b/include/asm-generic/pci-bridge.h
new file mode 100644
index 000000000000..4a5aca2a2c94
--- /dev/null
+++ b/include/asm-generic/pci-bridge.h
@@ -0,0 +1,62 @@
1/*
2 * This program is free software; you can redistribute it and/or
3 * modify it under the terms of the GNU General Public License
4 * as published by the Free Software Foundation; either version
5 * 2 of the License, or (at your option) any later version.
6 */
7#ifndef _ASM_GENERIC_PCI_BRIDGE_H
8#define _ASM_GENERIC_PCI_BRIDGE_H
9
10#ifdef __KERNEL__
11
12enum {
13 /* Force re-assigning all resources (ignore firmware
14 * setup completely)
15 */
16 PCI_REASSIGN_ALL_RSRC = 0x00000001,
17
18 /* Re-assign all bus numbers */
19 PCI_REASSIGN_ALL_BUS = 0x00000002,
20
21 /* Do not try to assign, just use existing setup */
22 PCI_PROBE_ONLY = 0x00000004,
23
24 /* Don't bother with ISA alignment unless the bridge has
25 * ISA forwarding enabled
26 */
27 PCI_CAN_SKIP_ISA_ALIGN = 0x00000008,
28
29 /* Enable domain numbers in /proc */
30 PCI_ENABLE_PROC_DOMAINS = 0x00000010,
31 /* ... except for domain 0 */
32 PCI_COMPAT_DOMAIN_0 = 0x00000020,
33};
34
35#ifdef CONFIG_PCI
36extern unsigned int pci_flags;
37
38static inline void pci_set_flags(int flags)
39{
40 pci_flags = flags;
41}
42
43static inline void pci_add_flags(int flags)
44{
45 pci_flags |= flags;
46}
47
48static inline int pci_has_flag(int flag)
49{
50 return pci_flags & flag;
51}
52#else
53static inline void pci_set_flags(int flags) { }
54static inline void pci_add_flags(int flags) { }
55static inline int pci_has_flag(int flag)
56{
57 return 0;
58}
59#endif /* CONFIG_PCI */
60
61#endif /* __KERNEL__ */
62#endif /* _ASM_GENERIC_PCI_BRIDGE_H */