1 /* $Id: pci_impl.h,v 1.6 2000/03/25 05:18:11 davem Exp $
2 * pci_impl.h: Helper definitions for PCI controller support.
4 * Copyright (C) 1999 David S. Miller (davem@redhat.com)
10 #include <linux/types.h>
11 #include <linux/spinlock.h>
14 extern spinlock_t pci_controller_lock
;
15 extern struct pci_controller_info
*pci_controller_root
;
17 extern struct pci_pbm_info
*pci_bus2pbm
[256];
18 extern unsigned char pci_highest_busnum
;
19 extern int pci_num_controllers
;
21 /* PCI bus scanning and fixup support. */
22 extern void pci_fill_in_pbm_cookies(struct pci_bus
*pbus
,
23 struct pci_pbm_info
*pbm
,
25 extern void pci_record_assignments(struct pci_pbm_info
*pbm
,
26 struct pci_bus
*pbus
);
27 extern void pci_assign_unassigned(struct pci_pbm_info
*pbm
,
28 struct pci_bus
*pbus
);
29 extern void pci_fixup_irq(struct pci_pbm_info
*pbm
,
30 struct pci_bus
*pbus
);
31 extern void pci_determine_66mhz_disposition(struct pci_pbm_info
*pbm
,
32 struct pci_bus
*pbus
);
33 extern void pci_setup_busmastering(struct pci_pbm_info
*pbm
,
34 struct pci_bus
*pbus
);
36 /* Error reporting support. */
37 extern void pci_scan_for_target_abort(struct pci_controller_info
*, struct pci_pbm_info
*, struct pci_bus
*);
38 extern void pci_scan_for_master_abort(struct pci_controller_info
*, struct pci_pbm_info
*, struct pci_bus
*);
39 extern void pci_scan_for_parity_error(struct pci_controller_info
*, struct pci_pbm_info
*, struct pci_bus
*);
41 /* Configuration space access. */
42 extern spinlock_t pci_poke_lock
;
43 extern volatile int pci_poke_in_progress
;
44 extern volatile int pci_poke_faulted
;
46 static __inline__
void pci_config_read8(u8
*addr
, u8
*ret
)
51 spin_lock_irqsave(&pci_poke_lock
, flags
);
52 pci_poke_in_progress
= 1;
54 __asm__
__volatile__("membar #Sync\n\t"
55 "lduba [%1] %2, %0\n\t"
58 : "r" (addr
), "i" (ASI_PHYS_BYPASS_EC_E_L
)
60 pci_poke_in_progress
= 0;
61 if (!pci_poke_faulted
)
63 spin_unlock_irqrestore(&pci_poke_lock
, flags
);
66 static __inline__
void pci_config_read16(u16
*addr
, u16
*ret
)
71 spin_lock_irqsave(&pci_poke_lock
, flags
);
72 pci_poke_in_progress
= 1;
74 __asm__
__volatile__("membar #Sync\n\t"
75 "lduha [%1] %2, %0\n\t"
78 : "r" (addr
), "i" (ASI_PHYS_BYPASS_EC_E_L
)
80 pci_poke_in_progress
= 0;
81 if (!pci_poke_faulted
)
83 spin_unlock_irqrestore(&pci_poke_lock
, flags
);
86 static __inline__
void pci_config_read32(u32
*addr
, u32
*ret
)
91 spin_lock_irqsave(&pci_poke_lock
, flags
);
92 pci_poke_in_progress
= 1;
94 __asm__
__volatile__("membar #Sync\n\t"
95 "lduwa [%1] %2, %0\n\t"
98 : "r" (addr
), "i" (ASI_PHYS_BYPASS_EC_E_L
)
100 pci_poke_in_progress
= 0;
101 if (!pci_poke_faulted
)
103 spin_unlock_irqrestore(&pci_poke_lock
, flags
);
106 static __inline__
void pci_config_write8(u8
*addr
, u8 val
)
110 spin_lock_irqsave(&pci_poke_lock
, flags
);
111 pci_poke_in_progress
= 1;
112 pci_poke_faulted
= 0;
113 __asm__
__volatile__("membar #Sync\n\t"
114 "stba %0, [%1] %2\n\t"
117 : "r" (val
), "r" (addr
), "i" (ASI_PHYS_BYPASS_EC_E_L
)
119 pci_poke_in_progress
= 0;
120 spin_unlock_irqrestore(&pci_poke_lock
, flags
);
123 static __inline__
void pci_config_write16(u16
*addr
, u16 val
)
127 spin_lock_irqsave(&pci_poke_lock
, flags
);
128 pci_poke_in_progress
= 1;
129 pci_poke_faulted
= 0;
130 __asm__
__volatile__("membar #Sync\n\t"
131 "stha %0, [%1] %2\n\t"
134 : "r" (val
), "r" (addr
), "i" (ASI_PHYS_BYPASS_EC_E_L
)
136 pci_poke_in_progress
= 0;
137 spin_unlock_irqrestore(&pci_poke_lock
, flags
);
140 static __inline__
void pci_config_write32(u32
*addr
, u32 val
)
144 spin_lock_irqsave(&pci_poke_lock
, flags
);
145 pci_poke_in_progress
= 1;
146 pci_poke_faulted
= 0;
147 __asm__
__volatile__("membar #Sync\n\t"
148 "stwa %0, [%1] %2\n\t"
151 : "r" (val
), "r" (addr
), "i" (ASI_PHYS_BYPASS_EC_E_L
)
153 pci_poke_in_progress
= 0;
154 spin_unlock_irqrestore(&pci_poke_lock
, flags
);
157 #endif /* !(PCI_IMPL_H) */