diff options
-rw-r--r-- | drivers/firewire/Makefile | 1 | ||||
-rw-r--r-- | drivers/firewire/init_ohci1394_dma.c (renamed from drivers/ieee1394/init_ohci1394_dma.c) | 76 | ||||
-rw-r--r-- | drivers/ieee1394/Makefile | 2 |
3 files changed, 51 insertions, 28 deletions
diff --git a/drivers/firewire/Makefile b/drivers/firewire/Makefile index 3c6a7fb20aa7..e3870d5c43dd 100644 --- a/drivers/firewire/Makefile +++ b/drivers/firewire/Makefile | |||
@@ -13,3 +13,4 @@ obj-$(CONFIG_FIREWIRE_OHCI) += firewire-ohci.o | |||
13 | obj-$(CONFIG_FIREWIRE_SBP2) += firewire-sbp2.o | 13 | obj-$(CONFIG_FIREWIRE_SBP2) += firewire-sbp2.o |
14 | obj-$(CONFIG_FIREWIRE_NET) += firewire-net.o | 14 | obj-$(CONFIG_FIREWIRE_NET) += firewire-net.o |
15 | obj-$(CONFIG_FIREWIRE_NOSY) += nosy.o | 15 | obj-$(CONFIG_FIREWIRE_NOSY) += nosy.o |
16 | obj-$(CONFIG_PROVIDE_OHCI1394_DMA_INIT) += init_ohci1394_dma.o | ||
diff --git a/drivers/ieee1394/init_ohci1394_dma.c b/drivers/firewire/init_ohci1394_dma.c index ddaab6eb8ace..a9a347adb353 100644 --- a/drivers/ieee1394/init_ohci1394_dma.c +++ b/drivers/firewire/init_ohci1394_dma.c | |||
@@ -32,23 +32,41 @@ | |||
32 | * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | 32 | * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
33 | */ | 33 | */ |
34 | 34 | ||
35 | #include <linux/interrupt.h> /* for ohci1394.h */ | ||
36 | #include <linux/delay.h> | 35 | #include <linux/delay.h> |
36 | #include <linux/io.h> | ||
37 | #include <linux/kernel.h> | ||
37 | #include <linux/pci.h> /* for PCI defines */ | 38 | #include <linux/pci.h> /* for PCI defines */ |
38 | #include <linux/init_ohci1394_dma.h> | 39 | #include <linux/string.h> |
40 | |||
39 | #include <asm/pci-direct.h> /* for direct PCI config space access */ | 41 | #include <asm/pci-direct.h> /* for direct PCI config space access */ |
40 | #include <asm/fixmap.h> | 42 | #include <asm/fixmap.h> |
41 | 43 | ||
42 | #include "ieee1394_types.h" | 44 | #include <linux/init_ohci1394_dma.h> |
43 | #include "ohci1394.h" | 45 | #include "ohci.h" |
44 | 46 | ||
45 | int __initdata init_ohci1394_dma_early; | 47 | int __initdata init_ohci1394_dma_early; |
46 | 48 | ||
49 | struct ohci { | ||
50 | void __iomem *registers; | ||
51 | }; | ||
52 | |||
53 | static inline void reg_write(const struct ohci *ohci, int offset, u32 data) | ||
54 | { | ||
55 | writel(data, ohci->registers + offset); | ||
56 | } | ||
57 | |||
58 | static inline u32 reg_read(const struct ohci *ohci, int offset) | ||
59 | { | ||
60 | return readl(ohci->registers + offset); | ||
61 | } | ||
62 | |||
63 | #define OHCI_LOOP_COUNT 100 /* Number of loops for reg read waits */ | ||
64 | |||
47 | /* Reads a PHY register of an OHCI-1394 controller */ | 65 | /* Reads a PHY register of an OHCI-1394 controller */ |
48 | static inline u8 __init get_phy_reg(struct ti_ohci *ohci, u8 addr) | 66 | static inline u8 __init get_phy_reg(struct ohci *ohci, u8 addr) |
49 | { | 67 | { |
50 | int i; | 68 | int i; |
51 | quadlet_t r; | 69 | u32 r; |
52 | 70 | ||
53 | reg_write(ohci, OHCI1394_PhyControl, (addr << 8) | 0x00008000); | 71 | reg_write(ohci, OHCI1394_PhyControl, (addr << 8) | 0x00008000); |
54 | 72 | ||
@@ -63,22 +81,22 @@ static inline u8 __init get_phy_reg(struct ti_ohci *ohci, u8 addr) | |||
63 | } | 81 | } |
64 | 82 | ||
65 | /* Writes to a PHY register of an OHCI-1394 controller */ | 83 | /* Writes to a PHY register of an OHCI-1394 controller */ |
66 | static inline void __init set_phy_reg(struct ti_ohci *ohci, u8 addr, u8 data) | 84 | static inline void __init set_phy_reg(struct ohci *ohci, u8 addr, u8 data) |
67 | { | 85 | { |
68 | int i; | 86 | int i; |
69 | 87 | ||
70 | reg_write(ohci, OHCI1394_PhyControl, (addr << 8) | data | 0x00004000); | 88 | reg_write(ohci, OHCI1394_PhyControl, (addr << 8) | data | 0x00004000); |
71 | 89 | ||
72 | for (i = 0; i < OHCI_LOOP_COUNT; i++) { | 90 | for (i = 0; i < OHCI_LOOP_COUNT; i++) { |
73 | u32 r = reg_read(ohci, OHCI1394_PhyControl); | 91 | if (!(reg_read(ohci, OHCI1394_PhyControl) & 0x00004000)) |
74 | if (!(r & 0x00004000)) | ||
75 | break; | 92 | break; |
76 | mdelay(1); | 93 | mdelay(1); |
77 | } | 94 | } |
78 | } | 95 | } |
79 | 96 | ||
80 | /* Resets an OHCI-1394 controller (for sane state before initialization) */ | 97 | /* Resets an OHCI-1394 controller (for sane state before initialization) */ |
81 | static inline void __init init_ohci1394_soft_reset(struct ti_ohci *ohci) { | 98 | static inline void __init init_ohci1394_soft_reset(struct ohci *ohci) |
99 | { | ||
82 | int i; | 100 | int i; |
83 | 101 | ||
84 | reg_write(ohci, OHCI1394_HCControlSet, OHCI1394_HCControl_softReset); | 102 | reg_write(ohci, OHCI1394_HCControlSet, OHCI1394_HCControl_softReset); |
@@ -91,10 +109,14 @@ static inline void __init init_ohci1394_soft_reset(struct ti_ohci *ohci) { | |||
91 | } | 109 | } |
92 | } | 110 | } |
93 | 111 | ||
112 | #define OHCI1394_MAX_AT_REQ_RETRIES 0xf | ||
113 | #define OHCI1394_MAX_AT_RESP_RETRIES 0x2 | ||
114 | #define OHCI1394_MAX_PHYS_RESP_RETRIES 0x8 | ||
115 | |||
94 | /* Basic OHCI-1394 register and port inititalization */ | 116 | /* Basic OHCI-1394 register and port inititalization */ |
95 | static inline void __init init_ohci1394_initialize(struct ti_ohci *ohci) | 117 | static inline void __init init_ohci1394_initialize(struct ohci *ohci) |
96 | { | 118 | { |
97 | quadlet_t bus_options; | 119 | u32 bus_options; |
98 | int num_ports, i; | 120 | int num_ports, i; |
99 | 121 | ||
100 | /* Put some defaults to these undefined bus options */ | 122 | /* Put some defaults to these undefined bus options */ |
@@ -116,7 +138,7 @@ static inline void __init init_ohci1394_initialize(struct ti_ohci *ohci) | |||
116 | 138 | ||
117 | /* enable phys */ | 139 | /* enable phys */ |
118 | reg_write(ohci, OHCI1394_LinkControlSet, | 140 | reg_write(ohci, OHCI1394_LinkControlSet, |
119 | OHCI1394_LinkControl_RcvPhyPkt); | 141 | OHCI1394_LinkControl_rcvPhyPkt); |
120 | 142 | ||
121 | /* Don't accept phy packets into AR request context */ | 143 | /* Don't accept phy packets into AR request context */ |
122 | reg_write(ohci, OHCI1394_LinkControlClear, 0x00000400); | 144 | reg_write(ohci, OHCI1394_LinkControlClear, 0x00000400); |
@@ -128,7 +150,7 @@ static inline void __init init_ohci1394_initialize(struct ti_ohci *ohci) | |||
128 | reg_write(ohci, OHCI1394_IsoXmitIntEventClear, 0xffffffff); | 150 | reg_write(ohci, OHCI1394_IsoXmitIntEventClear, 0xffffffff); |
129 | 151 | ||
130 | /* Accept asyncronous transfer requests from all nodes for now */ | 152 | /* Accept asyncronous transfer requests from all nodes for now */ |
131 | reg_write(ohci,OHCI1394_AsReqFilterHiSet, 0x80000000); | 153 | reg_write(ohci, OHCI1394_AsReqFilterHiSet, 0x80000000); |
132 | 154 | ||
133 | /* Specify asyncronous transfer retries */ | 155 | /* Specify asyncronous transfer retries */ |
134 | reg_write(ohci, OHCI1394_ATRetries, | 156 | reg_write(ohci, OHCI1394_ATRetries, |
@@ -137,7 +159,8 @@ static inline void __init init_ohci1394_initialize(struct ti_ohci *ohci) | |||
137 | (OHCI1394_MAX_PHYS_RESP_RETRIES<<8)); | 159 | (OHCI1394_MAX_PHYS_RESP_RETRIES<<8)); |
138 | 160 | ||
139 | /* We don't want hardware swapping */ | 161 | /* We don't want hardware swapping */ |
140 | reg_write(ohci, OHCI1394_HCControlClear, OHCI1394_HCControl_noByteSwap); | 162 | reg_write(ohci, OHCI1394_HCControlClear, |
163 | OHCI1394_HCControl_noByteSwapData); | ||
141 | 164 | ||
142 | /* Enable link */ | 165 | /* Enable link */ |
143 | reg_write(ohci, OHCI1394_HCControlSet, OHCI1394_HCControl_linkEnable); | 166 | reg_write(ohci, OHCI1394_HCControlSet, OHCI1394_HCControl_linkEnable); |
@@ -164,11 +187,11 @@ static inline void __init init_ohci1394_initialize(struct ti_ohci *ohci) | |||
164 | * has to be enabled after each bus reset when needed. We resort | 187 | * has to be enabled after each bus reset when needed. We resort |
165 | * to polling here because on early boot, we have no interrupts. | 188 | * to polling here because on early boot, we have no interrupts. |
166 | */ | 189 | */ |
167 | static inline void __init init_ohci1394_wait_for_busresets(struct ti_ohci *ohci) | 190 | static inline void __init init_ohci1394_wait_for_busresets(struct ohci *ohci) |
168 | { | 191 | { |
169 | int i, events; | 192 | int i, events; |
170 | 193 | ||
171 | for (i=0; i < 9; i++) { | 194 | for (i = 0; i < 9; i++) { |
172 | mdelay(200); | 195 | mdelay(200); |
173 | events = reg_read(ohci, OHCI1394_IntEventSet); | 196 | events = reg_read(ohci, OHCI1394_IntEventSet); |
174 | if (events & OHCI1394_busReset) | 197 | if (events & OHCI1394_busReset) |
@@ -182,18 +205,18 @@ static inline void __init init_ohci1394_wait_for_busresets(struct ti_ohci *ohci) | |||
182 | * This enables remote DMA access over IEEE1394 from every host for the low | 205 | * This enables remote DMA access over IEEE1394 from every host for the low |
183 | * 4GB of address space. DMA accesses above 4GB are not available currently. | 206 | * 4GB of address space. DMA accesses above 4GB are not available currently. |
184 | */ | 207 | */ |
185 | static inline void __init init_ohci1394_enable_physical_dma(struct ti_ohci *hci) | 208 | static inline void __init init_ohci1394_enable_physical_dma(struct ohci *ohci) |
186 | { | 209 | { |
187 | reg_write(hci, OHCI1394_PhyReqFilterHiSet, 0xffffffff); | 210 | reg_write(ohci, OHCI1394_PhyReqFilterHiSet, 0xffffffff); |
188 | reg_write(hci, OHCI1394_PhyReqFilterLoSet, 0xffffffff); | 211 | reg_write(ohci, OHCI1394_PhyReqFilterLoSet, 0xffffffff); |
189 | reg_write(hci, OHCI1394_PhyUpperBound, 0xffff0000); | 212 | reg_write(ohci, OHCI1394_PhyUpperBound, 0xffff0000); |
190 | } | 213 | } |
191 | 214 | ||
192 | /** | 215 | /** |
193 | * init_ohci1394_reset_and_init_dma - init controller and enable DMA | 216 | * init_ohci1394_reset_and_init_dma - init controller and enable DMA |
194 | * This initializes the given controller and enables physical DMA engine in it. | 217 | * This initializes the given controller and enables physical DMA engine in it. |
195 | */ | 218 | */ |
196 | static inline void __init init_ohci1394_reset_and_init_dma(struct ti_ohci *ohci) | 219 | static inline void __init init_ohci1394_reset_and_init_dma(struct ohci *ohci) |
197 | { | 220 | { |
198 | /* Start off with a soft reset, clears everything to a sane state. */ | 221 | /* Start off with a soft reset, clears everything to a sane state. */ |
199 | init_ohci1394_soft_reset(ohci); | 222 | init_ohci1394_soft_reset(ohci); |
@@ -225,7 +248,7 @@ static inline void __init init_ohci1394_reset_and_init_dma(struct ti_ohci *ohci) | |||
225 | static inline void __init init_ohci1394_controller(int num, int slot, int func) | 248 | static inline void __init init_ohci1394_controller(int num, int slot, int func) |
226 | { | 249 | { |
227 | unsigned long ohci_base; | 250 | unsigned long ohci_base; |
228 | struct ti_ohci ohci; | 251 | struct ohci ohci; |
229 | 252 | ||
230 | printk(KERN_INFO "init_ohci1394_dma: initializing OHCI-1394" | 253 | printk(KERN_INFO "init_ohci1394_dma: initializing OHCI-1394" |
231 | " at %02x:%02x.%x\n", num, slot, func); | 254 | " at %02x:%02x.%x\n", num, slot, func); |
@@ -235,7 +258,7 @@ static inline void __init init_ohci1394_controller(int num, int slot, int func) | |||
235 | 258 | ||
236 | set_fixmap_nocache(FIX_OHCI1394_BASE, ohci_base); | 259 | set_fixmap_nocache(FIX_OHCI1394_BASE, ohci_base); |
237 | 260 | ||
238 | ohci.registers = (void *)fix_to_virt(FIX_OHCI1394_BASE); | 261 | ohci.registers = (void __iomem *)fix_to_virt(FIX_OHCI1394_BASE); |
239 | 262 | ||
240 | init_ohci1394_reset_and_init_dma(&ohci); | 263 | init_ohci1394_reset_and_init_dma(&ohci); |
241 | } | 264 | } |
@@ -247,6 +270,7 @@ static inline void __init init_ohci1394_controller(int num, int slot, int func) | |||
247 | void __init init_ohci1394_dma_on_all_controllers(void) | 270 | void __init init_ohci1394_dma_on_all_controllers(void) |
248 | { | 271 | { |
249 | int num, slot, func; | 272 | int num, slot, func; |
273 | u32 class; | ||
250 | 274 | ||
251 | if (!early_pci_allowed()) | 275 | if (!early_pci_allowed()) |
252 | return; | 276 | return; |
@@ -255,9 +279,9 @@ void __init init_ohci1394_dma_on_all_controllers(void) | |||
255 | for (num = 0; num < 32; num++) { | 279 | for (num = 0; num < 32; num++) { |
256 | for (slot = 0; slot < 32; slot++) { | 280 | for (slot = 0; slot < 32; slot++) { |
257 | for (func = 0; func < 8; func++) { | 281 | for (func = 0; func < 8; func++) { |
258 | u32 class = read_pci_config(num,slot,func, | 282 | class = read_pci_config(num, slot, func, |
259 | PCI_CLASS_REVISION); | 283 | PCI_CLASS_REVISION); |
260 | if ((class == 0xffffffff)) | 284 | if (class == 0xffffffff) |
261 | continue; /* No device at this func */ | 285 | continue; /* No device at this func */ |
262 | 286 | ||
263 | if (class>>8 != PCI_CLASS_SERIAL_FIREWIRE_OHCI) | 287 | if (class>>8 != PCI_CLASS_SERIAL_FIREWIRE_OHCI) |
diff --git a/drivers/ieee1394/Makefile b/drivers/ieee1394/Makefile index 1f8153b57503..427b86b87760 100644 --- a/drivers/ieee1394/Makefile +++ b/drivers/ieee1394/Makefile | |||
@@ -14,5 +14,3 @@ obj-$(CONFIG_IEEE1394_RAWIO) += raw1394.o | |||
14 | obj-$(CONFIG_IEEE1394_SBP2) += sbp2.o | 14 | obj-$(CONFIG_IEEE1394_SBP2) += sbp2.o |
15 | obj-$(CONFIG_IEEE1394_DV1394) += dv1394.o | 15 | obj-$(CONFIG_IEEE1394_DV1394) += dv1394.o |
16 | obj-$(CONFIG_IEEE1394_ETH1394) += eth1394.o | 16 | obj-$(CONFIG_IEEE1394_ETH1394) += eth1394.o |
17 | |||
18 | obj-$(CONFIG_PROVIDE_OHCI1394_DMA_INIT) += init_ohci1394_dma.o | ||