diff options
Diffstat (limited to 'drivers/net/pcmcia/ibmtr_cs.c')
-rw-r--r-- | drivers/net/pcmcia/ibmtr_cs.c | 54 |
1 files changed, 26 insertions, 28 deletions
diff --git a/drivers/net/pcmcia/ibmtr_cs.c b/drivers/net/pcmcia/ibmtr_cs.c index 06618af1a468..0d914f3b2941 100644 --- a/drivers/net/pcmcia/ibmtr_cs.c +++ b/drivers/net/pcmcia/ibmtr_cs.c | |||
@@ -69,17 +69,6 @@ | |||
69 | #define PCMCIA | 69 | #define PCMCIA |
70 | #include "../tokenring/ibmtr.c" | 70 | #include "../tokenring/ibmtr.c" |
71 | 71 | ||
72 | #ifdef PCMCIA_DEBUG | ||
73 | static int pc_debug = PCMCIA_DEBUG; | ||
74 | module_param(pc_debug, int, 0); | ||
75 | #define DEBUG(n, args...) if (pc_debug>(n)) printk(KERN_DEBUG args) | ||
76 | static char *version = | ||
77 | "ibmtr_cs.c 1.10 1996/01/06 05:19:00 (Steve Kipisz)\n" | ||
78 | " 2.2.7 1999/05/03 12:00:00 (Mike Phillips)\n" | ||
79 | " 2.4.2 2001/30/28 Midnight (Burt Silverman)\n"; | ||
80 | #else | ||
81 | #define DEBUG(n, args...) | ||
82 | #endif | ||
83 | 72 | ||
84 | /*====================================================================*/ | 73 | /*====================================================================*/ |
85 | 74 | ||
@@ -143,7 +132,7 @@ static int __devinit ibmtr_attach(struct pcmcia_device *link) | |||
143 | ibmtr_dev_t *info; | 132 | ibmtr_dev_t *info; |
144 | struct net_device *dev; | 133 | struct net_device *dev; |
145 | 134 | ||
146 | DEBUG(0, "ibmtr_attach()\n"); | 135 | dev_dbg(&link->dev, "ibmtr_attach()\n"); |
147 | 136 | ||
148 | /* Create new token-ring device */ | 137 | /* Create new token-ring device */ |
149 | info = kzalloc(sizeof(*info), GFP_KERNEL); | 138 | info = kzalloc(sizeof(*info), GFP_KERNEL); |
@@ -190,7 +179,7 @@ static void ibmtr_detach(struct pcmcia_device *link) | |||
190 | struct net_device *dev = info->dev; | 179 | struct net_device *dev = info->dev; |
191 | struct tok_info *ti = netdev_priv(dev); | 180 | struct tok_info *ti = netdev_priv(dev); |
192 | 181 | ||
193 | DEBUG(0, "ibmtr_detach(0x%p)\n", link); | 182 | dev_dbg(&link->dev, "ibmtr_detach\n"); |
194 | 183 | ||
195 | /* | 184 | /* |
196 | * When the card removal interrupt hits tok_interrupt(), | 185 | * When the card removal interrupt hits tok_interrupt(), |
@@ -217,9 +206,6 @@ static void ibmtr_detach(struct pcmcia_device *link) | |||
217 | 206 | ||
218 | ======================================================================*/ | 207 | ======================================================================*/ |
219 | 208 | ||
220 | #define CS_CHECK(fn, ret) \ | ||
221 | do { last_fn = (fn); if ((last_ret = (ret)) != 0) goto cs_failed; } while (0) | ||
222 | |||
223 | static int __devinit ibmtr_config(struct pcmcia_device *link) | 209 | static int __devinit ibmtr_config(struct pcmcia_device *link) |
224 | { | 210 | { |
225 | ibmtr_dev_t *info = link->priv; | 211 | ibmtr_dev_t *info = link->priv; |
@@ -227,9 +213,9 @@ static int __devinit ibmtr_config(struct pcmcia_device *link) | |||
227 | struct tok_info *ti = netdev_priv(dev); | 213 | struct tok_info *ti = netdev_priv(dev); |
228 | win_req_t req; | 214 | win_req_t req; |
229 | memreq_t mem; | 215 | memreq_t mem; |
230 | int i, last_ret, last_fn; | 216 | int i, ret; |
231 | 217 | ||
232 | DEBUG(0, "ibmtr_config(0x%p)\n", link); | 218 | dev_dbg(&link->dev, "ibmtr_config\n"); |
233 | 219 | ||
234 | link->conf.ConfigIndex = 0x61; | 220 | link->conf.ConfigIndex = 0x61; |
235 | 221 | ||
@@ -241,11 +227,15 @@ static int __devinit ibmtr_config(struct pcmcia_device *link) | |||
241 | if (i != 0) { | 227 | if (i != 0) { |
242 | /* Couldn't get 0xA20-0xA23. Try ALTERNATE at 0xA24-0xA27. */ | 228 | /* Couldn't get 0xA20-0xA23. Try ALTERNATE at 0xA24-0xA27. */ |
243 | link->io.BasePort1 = 0xA24; | 229 | link->io.BasePort1 = 0xA24; |
244 | CS_CHECK(RequestIO, pcmcia_request_io(link, &link->io)); | 230 | ret = pcmcia_request_io(link, &link->io); |
231 | if (ret) | ||
232 | goto failed; | ||
245 | } | 233 | } |
246 | dev->base_addr = link->io.BasePort1; | 234 | dev->base_addr = link->io.BasePort1; |
247 | 235 | ||
248 | CS_CHECK(RequestIRQ, pcmcia_request_irq(link, &link->irq)); | 236 | ret = pcmcia_request_irq(link, &link->irq); |
237 | if (ret) | ||
238 | goto failed; | ||
249 | dev->irq = link->irq.AssignedIRQ; | 239 | dev->irq = link->irq.AssignedIRQ; |
250 | ti->irq = link->irq.AssignedIRQ; | 240 | ti->irq = link->irq.AssignedIRQ; |
251 | ti->global_int_enable=GLOBAL_INT_ENABLE+((dev->irq==9) ? 2 : dev->irq); | 241 | ti->global_int_enable=GLOBAL_INT_ENABLE+((dev->irq==9) ? 2 : dev->irq); |
@@ -256,11 +246,15 @@ static int __devinit ibmtr_config(struct pcmcia_device *link) | |||
256 | req.Base = 0; | 246 | req.Base = 0; |
257 | req.Size = 0x2000; | 247 | req.Size = 0x2000; |
258 | req.AccessSpeed = 250; | 248 | req.AccessSpeed = 250; |
259 | CS_CHECK(RequestWindow, pcmcia_request_window(&link, &req, &link->win)); | 249 | ret = pcmcia_request_window(&link, &req, &link->win); |
250 | if (ret) | ||
251 | goto failed; | ||
260 | 252 | ||
261 | mem.CardOffset = mmiobase; | 253 | mem.CardOffset = mmiobase; |
262 | mem.Page = 0; | 254 | mem.Page = 0; |
263 | CS_CHECK(MapMemPage, pcmcia_map_mem_page(link->win, &mem)); | 255 | ret = pcmcia_map_mem_page(link->win, &mem); |
256 | if (ret) | ||
257 | goto failed; | ||
264 | ti->mmio = ioremap(req.Base, req.Size); | 258 | ti->mmio = ioremap(req.Base, req.Size); |
265 | 259 | ||
266 | /* Allocate the SRAM memory window */ | 260 | /* Allocate the SRAM memory window */ |
@@ -269,17 +263,23 @@ static int __devinit ibmtr_config(struct pcmcia_device *link) | |||
269 | req.Base = 0; | 263 | req.Base = 0; |
270 | req.Size = sramsize * 1024; | 264 | req.Size = sramsize * 1024; |
271 | req.AccessSpeed = 250; | 265 | req.AccessSpeed = 250; |
272 | CS_CHECK(RequestWindow, pcmcia_request_window(&link, &req, &info->sram_win_handle)); | 266 | ret = pcmcia_request_window(&link, &req, &info->sram_win_handle); |
267 | if (ret) | ||
268 | goto failed; | ||
273 | 269 | ||
274 | mem.CardOffset = srambase; | 270 | mem.CardOffset = srambase; |
275 | mem.Page = 0; | 271 | mem.Page = 0; |
276 | CS_CHECK(MapMemPage, pcmcia_map_mem_page(info->sram_win_handle, &mem)); | 272 | ret = pcmcia_map_mem_page(info->sram_win_handle, &mem); |
273 | if (ret) | ||
274 | goto failed; | ||
277 | 275 | ||
278 | ti->sram_base = mem.CardOffset >> 12; | 276 | ti->sram_base = mem.CardOffset >> 12; |
279 | ti->sram_virt = ioremap(req.Base, req.Size); | 277 | ti->sram_virt = ioremap(req.Base, req.Size); |
280 | ti->sram_phys = req.Base; | 278 | ti->sram_phys = req.Base; |
281 | 279 | ||
282 | CS_CHECK(RequestConfiguration, pcmcia_request_configuration(link, &link->conf)); | 280 | ret = pcmcia_request_configuration(link, &link->conf); |
281 | if (ret) | ||
282 | goto failed; | ||
283 | 283 | ||
284 | /* Set up the Token-Ring Controller Configuration Register and | 284 | /* Set up the Token-Ring Controller Configuration Register and |
285 | turn on the card. Check the "Local Area Network Credit Card | 285 | turn on the card. Check the "Local Area Network Credit Card |
@@ -305,8 +305,6 @@ static int __devinit ibmtr_config(struct pcmcia_device *link) | |||
305 | dev->dev_addr); | 305 | dev->dev_addr); |
306 | return 0; | 306 | return 0; |
307 | 307 | ||
308 | cs_failed: | ||
309 | cs_error(link, last_fn, last_ret); | ||
310 | failed: | 308 | failed: |
311 | ibmtr_release(link); | 309 | ibmtr_release(link); |
312 | return -ENODEV; | 310 | return -ENODEV; |
@@ -325,7 +323,7 @@ static void ibmtr_release(struct pcmcia_device *link) | |||
325 | ibmtr_dev_t *info = link->priv; | 323 | ibmtr_dev_t *info = link->priv; |
326 | struct net_device *dev = info->dev; | 324 | struct net_device *dev = info->dev; |
327 | 325 | ||
328 | DEBUG(0, "ibmtr_release(0x%p)\n", link); | 326 | dev_dbg(&link->dev, "ibmtr_release\n"); |
329 | 327 | ||
330 | if (link->win) { | 328 | if (link->win) { |
331 | struct tok_info *ti = netdev_priv(dev); | 329 | struct tok_info *ti = netdev_priv(dev); |