diff options
author | Dominik Brodowski <linux@dominikbrodowski.net> | 2008-08-02 09:30:31 -0400 |
---|---|---|
committer | Dominik Brodowski <linux@dominikbrodowski.net> | 2008-08-22 19:22:00 -0400 |
commit | 8e2fc39ddea7fe8c6798837da282db88a09af793 (patch) | |
tree | 7cba37b5b86f4ff25562012a14e29424e3872de0 /drivers/net/wireless | |
parent | 498ac1899b62626bf6879a251d75c22ec564c559 (diff) |
pcmcia: pcmcia_config_loop() default CIS entry handling
Many drivers use the default CIS entry within their pcmcia_config_loop()
callback function. Therefore, factor the default CIS entry handling out.
Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net>
Diffstat (limited to 'drivers/net/wireless')
-rw-r--r-- | drivers/net/wireless/airo_cs.c | 51 | ||||
-rw-r--r-- | drivers/net/wireless/atmel_cs.c | 9 | ||||
-rw-r--r-- | drivers/net/wireless/hostap/hostap_cs.c | 24 | ||||
-rw-r--r-- | drivers/net/wireless/orinoco_cs.c | 18 | ||||
-rw-r--r-- | drivers/net/wireless/spectrum_cs.c | 18 |
5 files changed, 52 insertions, 68 deletions
diff --git a/drivers/net/wireless/airo_cs.c b/drivers/net/wireless/airo_cs.c index d7216730f18e..657adf85ab77 100644 --- a/drivers/net/wireless/airo_cs.c +++ b/drivers/net/wireless/airo_cs.c | |||
@@ -206,19 +206,12 @@ static void airo_detach(struct pcmcia_device *link) | |||
206 | #define CS_CHECK(fn, ret) \ | 206 | #define CS_CHECK(fn, ret) \ |
207 | do { last_fn = (fn); if ((last_ret = (ret)) != 0) goto cs_failed; } while (0) | 207 | do { last_fn = (fn); if ((last_ret = (ret)) != 0) goto cs_failed; } while (0) |
208 | 208 | ||
209 | struct airo_cs_config_data { | ||
210 | cistpl_cftable_entry_t dflt; | ||
211 | win_req_t req; | ||
212 | }; | ||
213 | |||
214 | static int airo_cs_config_check(struct pcmcia_device *p_dev, | 209 | static int airo_cs_config_check(struct pcmcia_device *p_dev, |
215 | cistpl_cftable_entry_t *cfg, | 210 | cistpl_cftable_entry_t *cfg, |
211 | cistpl_cftable_entry_t *dflt, | ||
216 | void *priv_data) | 212 | void *priv_data) |
217 | { | 213 | { |
218 | struct airo_cs_config_data *cfg_mem = priv_data; | 214 | win_req_t *req = priv_data; |
219 | |||
220 | if (cfg->flags & CISTPL_CFTABLE_DEFAULT) | ||
221 | cfg_mem->dflt = *cfg; | ||
222 | 215 | ||
223 | if (cfg->index == 0) | 216 | if (cfg->index == 0) |
224 | return -ENODEV; | 217 | return -ENODEV; |
@@ -233,17 +226,17 @@ static int airo_cs_config_check(struct pcmcia_device *p_dev, | |||
233 | /* Note that the CIS values need to be rescaled */ | 226 | /* Note that the CIS values need to be rescaled */ |
234 | if (cfg->vpp1.present & (1<<CISTPL_POWER_VNOM)) | 227 | if (cfg->vpp1.present & (1<<CISTPL_POWER_VNOM)) |
235 | p_dev->conf.Vpp = cfg->vpp1.param[CISTPL_POWER_VNOM]/10000; | 228 | p_dev->conf.Vpp = cfg->vpp1.param[CISTPL_POWER_VNOM]/10000; |
236 | else if (cfg_mem->dflt.vpp1.present & (1<<CISTPL_POWER_VNOM)) | 229 | else if (dflt->vpp1.present & (1<<CISTPL_POWER_VNOM)) |
237 | p_dev->conf.Vpp = cfg_mem->dflt.vpp1.param[CISTPL_POWER_VNOM]/10000; | 230 | p_dev->conf.Vpp = dflt->vpp1.param[CISTPL_POWER_VNOM]/10000; |
238 | 231 | ||
239 | /* Do we need to allocate an interrupt? */ | 232 | /* Do we need to allocate an interrupt? */ |
240 | if (cfg->irq.IRQInfo1 || cfg_mem->dflt.irq.IRQInfo1) | 233 | if (cfg->irq.IRQInfo1 || dflt->irq.IRQInfo1) |
241 | p_dev->conf.Attributes |= CONF_ENABLE_IRQ; | 234 | p_dev->conf.Attributes |= CONF_ENABLE_IRQ; |
242 | 235 | ||
243 | /* IO window settings */ | 236 | /* IO window settings */ |
244 | p_dev->io.NumPorts1 = p_dev->io.NumPorts2 = 0; | 237 | p_dev->io.NumPorts1 = p_dev->io.NumPorts2 = 0; |
245 | if ((cfg->io.nwin > 0) || (cfg_mem->dflt.io.nwin > 0)) { | 238 | if ((cfg->io.nwin > 0) || (dflt->io.nwin > 0)) { |
246 | cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &cfg_mem->dflt.io; | 239 | cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &dflt->io; |
247 | p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO; | 240 | p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO; |
248 | if (!(io->flags & CISTPL_IO_8BIT)) | 241 | if (!(io->flags & CISTPL_IO_8BIT)) |
249 | p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_16; | 242 | p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_16; |
@@ -273,14 +266,14 @@ static int airo_cs_config_check(struct pcmcia_device *p_dev, | |||
273 | needs to be mapped to virtual space with ioremap() before it | 266 | needs to be mapped to virtual space with ioremap() before it |
274 | is used. | 267 | is used. |
275 | */ | 268 | */ |
276 | if ((cfg->mem.nwin > 0) || (cfg_mem->dflt.mem.nwin > 0)) { | 269 | if ((cfg->mem.nwin > 0) || (dflt->mem.nwin > 0)) { |
277 | cistpl_mem_t *mem = (cfg->mem.nwin) ? &cfg->mem : &cfg_mem->dflt.mem; | 270 | cistpl_mem_t *mem = (cfg->mem.nwin) ? &cfg->mem : &dflt->mem; |
278 | memreq_t map; | 271 | memreq_t map; |
279 | cfg_mem->req.Attributes = WIN_DATA_WIDTH_16|WIN_MEMORY_TYPE_CM; | 272 | req->Attributes = WIN_DATA_WIDTH_16|WIN_MEMORY_TYPE_CM; |
280 | cfg_mem->req.Base = mem->win[0].host_addr; | 273 | req->Base = mem->win[0].host_addr; |
281 | cfg_mem->req.Size = mem->win[0].len; | 274 | req->Size = mem->win[0].len; |
282 | cfg_mem->req.AccessSpeed = 0; | 275 | req->AccessSpeed = 0; |
283 | if (pcmcia_request_window(&p_dev, &cfg_mem->req, &p_dev->win) != 0) | 276 | if (pcmcia_request_window(&p_dev, req, &p_dev->win) != 0) |
284 | return -ENODEV; | 277 | return -ENODEV; |
285 | map.Page = 0; | 278 | map.Page = 0; |
286 | map.CardOffset = mem->win[0].card_addr; | 279 | map.CardOffset = mem->win[0].card_addr; |
@@ -295,15 +288,15 @@ static int airo_cs_config_check(struct pcmcia_device *p_dev, | |||
295 | static int airo_config(struct pcmcia_device *link) | 288 | static int airo_config(struct pcmcia_device *link) |
296 | { | 289 | { |
297 | local_info_t *dev; | 290 | local_info_t *dev; |
298 | struct airo_cs_config_data *cfg_mem; | 291 | win_req_t *req; |
299 | int last_fn, last_ret; | 292 | int last_fn, last_ret; |
300 | 293 | ||
301 | dev = link->priv; | 294 | dev = link->priv; |
302 | 295 | ||
303 | DEBUG(0, "airo_config(0x%p)\n", link); | 296 | DEBUG(0, "airo_config(0x%p)\n", link); |
304 | 297 | ||
305 | cfg_mem = kzalloc(sizeof(struct airo_cs_config_data), GFP_KERNEL); | 298 | req = kzalloc(sizeof(win_req_t), GFP_KERNEL); |
306 | if (!cfg_mem) | 299 | if (!req) |
307 | return -ENOMEM; | 300 | return -ENOMEM; |
308 | 301 | ||
309 | /* | 302 | /* |
@@ -320,7 +313,7 @@ static int airo_config(struct pcmcia_device *link) | |||
320 | * and most client drivers will only use the CIS to fill in | 313 | * and most client drivers will only use the CIS to fill in |
321 | * implementation-defined details. | 314 | * implementation-defined details. |
322 | */ | 315 | */ |
323 | last_ret = pcmcia_loop_config(link, airo_cs_config_check, cfg_mem); | 316 | last_ret = pcmcia_loop_config(link, airo_cs_config_check, req); |
324 | if (last_ret) | 317 | if (last_ret) |
325 | goto failed; | 318 | goto failed; |
326 | 319 | ||
@@ -365,17 +358,17 @@ static int airo_config(struct pcmcia_device *link) | |||
365 | printk(" & 0x%04x-0x%04x", link->io.BasePort2, | 358 | printk(" & 0x%04x-0x%04x", link->io.BasePort2, |
366 | link->io.BasePort2+link->io.NumPorts2-1); | 359 | link->io.BasePort2+link->io.NumPorts2-1); |
367 | if (link->win) | 360 | if (link->win) |
368 | printk(", mem 0x%06lx-0x%06lx", cfg_mem->req.Base, | 361 | printk(", mem 0x%06lx-0x%06lx", req->Base, |
369 | cfg_mem->req.Base+cfg_mem->req.Size-1); | 362 | req->Base+req->Size-1); |
370 | printk("\n"); | 363 | printk("\n"); |
371 | kfree(cfg_mem); | 364 | kfree(req); |
372 | return 0; | 365 | return 0; |
373 | 366 | ||
374 | cs_failed: | 367 | cs_failed: |
375 | cs_error(link, last_fn, last_ret); | 368 | cs_error(link, last_fn, last_ret); |
376 | failed: | 369 | failed: |
377 | airo_release(link); | 370 | airo_release(link); |
378 | kfree(cfg_mem); | 371 | kfree(req); |
379 | return -ENODEV; | 372 | return -ENODEV; |
380 | } /* airo_config */ | 373 | } /* airo_config */ |
381 | 374 | ||
diff --git a/drivers/net/wireless/atmel_cs.c b/drivers/net/wireless/atmel_cs.c index 12efd44d64a1..c71aae992ecc 100644 --- a/drivers/net/wireless/atmel_cs.c +++ b/drivers/net/wireless/atmel_cs.c | |||
@@ -226,14 +226,12 @@ static int card_present(void *arg) | |||
226 | 226 | ||
227 | static int atmel_config_check(struct pcmcia_device *p_dev, | 227 | static int atmel_config_check(struct pcmcia_device *p_dev, |
228 | cistpl_cftable_entry_t *cfg, | 228 | cistpl_cftable_entry_t *cfg, |
229 | cistpl_cftable_entry_t *dflt, | ||
229 | void *priv_data) | 230 | void *priv_data) |
230 | { | 231 | { |
231 | cistpl_cftable_entry_t *dflt = priv_data; | ||
232 | |||
233 | if (cfg->flags & CISTPL_CFTABLE_DEFAULT) | ||
234 | *dflt = *cfg; | ||
235 | if (cfg->index == 0) | 232 | if (cfg->index == 0) |
236 | return -ENODEV; | 233 | return -ENODEV; |
234 | |||
237 | /* Does this card need audio output? */ | 235 | /* Does this card need audio output? */ |
238 | if (cfg->flags & CISTPL_CFTABLE_AUDIO) { | 236 | if (cfg->flags & CISTPL_CFTABLE_AUDIO) { |
239 | p_dev->conf.Attributes |= CONF_ENABLE_SPKR; | 237 | p_dev->conf.Attributes |= CONF_ENABLE_SPKR; |
@@ -278,7 +276,6 @@ static int atmel_config(struct pcmcia_device *link) | |||
278 | local_info_t *dev; | 276 | local_info_t *dev; |
279 | int last_fn, last_ret; | 277 | int last_fn, last_ret; |
280 | struct pcmcia_device_id *did; | 278 | struct pcmcia_device_id *did; |
281 | cistpl_cftable_entry_t dflt = { 0 }; | ||
282 | 279 | ||
283 | dev = link->priv; | 280 | dev = link->priv; |
284 | did = handle_to_dev(link).driver_data; | 281 | did = handle_to_dev(link).driver_data; |
@@ -297,7 +294,7 @@ static int atmel_config(struct pcmcia_device *link) | |||
297 | these things without consulting the CIS, and most client drivers | 294 | these things without consulting the CIS, and most client drivers |
298 | will only use the CIS to fill in implementation-defined details. | 295 | will only use the CIS to fill in implementation-defined details. |
299 | */ | 296 | */ |
300 | if (pcmcia_loop_config(link, atmel_config_check, &dflt)) | 297 | if (pcmcia_loop_config(link, atmel_config_check, NULL)) |
301 | goto failed; | 298 | goto failed; |
302 | 299 | ||
303 | /* | 300 | /* |
diff --git a/drivers/net/wireless/hostap/hostap_cs.c b/drivers/net/wireless/hostap/hostap_cs.c index 2abaa90b799d..f9595ca71a06 100644 --- a/drivers/net/wireless/hostap/hostap_cs.c +++ b/drivers/net/wireless/hostap/hostap_cs.c | |||
@@ -537,23 +537,21 @@ do { last_fn = (fn); if ((last_ret = (ret)) != 0) goto cs_failed; } while (0) | |||
537 | * socket and make the device available to the system */ | 537 | * socket and make the device available to the system */ |
538 | 538 | ||
539 | struct prism2_config_data { | 539 | struct prism2_config_data { |
540 | cistpl_cftable_entry_t dflt; | ||
541 | config_info_t conf; | 540 | config_info_t conf; |
542 | }; | 541 | }; |
543 | 542 | ||
544 | static int prism2_config_check(struct pcmcia_device *p_dev, | 543 | static int prism2_config_check(struct pcmcia_device *p_dev, |
545 | cistpl_cftable_entry_t *cfg, | 544 | cistpl_cftable_entry_t *cfg, |
545 | cistpl_cftable_entry_t *dflt, | ||
546 | void *priv_data) | 546 | void *priv_data) |
547 | { | 547 | { |
548 | struct prism2_config_data *cfg_mem = priv_data; | 548 | struct prism2_config_data *cfg_mem = priv_data; |
549 | 549 | ||
550 | if (cfg->flags & CISTPL_CFTABLE_DEFAULT) | ||
551 | cfg_mem->dflt = *cfg; | ||
552 | if (cfg->index == 0) | 550 | if (cfg->index == 0) |
553 | return -ENODEV; | 551 | return -ENODEV; |
554 | 552 | ||
555 | PDEBUG(DEBUG_EXTRA, "Checking CFTABLE_ENTRY 0x%02X " | 553 | PDEBUG(DEBUG_EXTRA, "Checking CFTABLE_ENTRY 0x%02X " |
556 | "(default 0x%02X)\n", cfg->index, cfg_mem->dflt.index); | 554 | "(default 0x%02X)\n", cfg->index, dflt->index); |
557 | 555 | ||
558 | /* Does this card need audio output? */ | 556 | /* Does this card need audio output? */ |
559 | if (cfg->flags & CISTPL_CFTABLE_AUDIO) { | 557 | if (cfg->flags & CISTPL_CFTABLE_AUDIO) { |
@@ -570,8 +568,8 @@ static int prism2_config_check(struct pcmcia_device *p_dev, | |||
570 | " this entry\n"); | 568 | " this entry\n"); |
571 | return -ENODEV; | 569 | return -ENODEV; |
572 | } | 570 | } |
573 | } else if (cfg_mem->dflt.vcc.present & (1 << CISTPL_POWER_VNOM)) { | 571 | } else if (dflt->vcc.present & (1 << CISTPL_POWER_VNOM)) { |
574 | if (cfg_mem->conf.Vcc != cfg_mem->dflt.vcc.param[CISTPL_POWER_VNOM] / | 572 | if (cfg_mem->conf.Vcc != dflt->vcc.param[CISTPL_POWER_VNOM] / |
575 | 10000 && !ignore_cis_vcc) { | 573 | 10000 && !ignore_cis_vcc) { |
576 | PDEBUG(DEBUG_EXTRA, " Vcc (default) mismatch " | 574 | PDEBUG(DEBUG_EXTRA, " Vcc (default) mismatch " |
577 | "- skipping this entry\n"); | 575 | "- skipping this entry\n"); |
@@ -581,11 +579,11 @@ static int prism2_config_check(struct pcmcia_device *p_dev, | |||
581 | 579 | ||
582 | if (cfg->vpp1.present & (1 << CISTPL_POWER_VNOM)) | 580 | if (cfg->vpp1.present & (1 << CISTPL_POWER_VNOM)) |
583 | p_dev->conf.Vpp = cfg->vpp1.param[CISTPL_POWER_VNOM] / 10000; | 581 | p_dev->conf.Vpp = cfg->vpp1.param[CISTPL_POWER_VNOM] / 10000; |
584 | else if (cfg_mem->dflt.vpp1.present & (1 << CISTPL_POWER_VNOM)) | 582 | else if (dflt->vpp1.present & (1 << CISTPL_POWER_VNOM)) |
585 | p_dev->conf.Vpp = cfg_mem->dflt.vpp1.param[CISTPL_POWER_VNOM] / 10000; | 583 | p_dev->conf.Vpp = dflt->vpp1.param[CISTPL_POWER_VNOM] / 10000; |
586 | 584 | ||
587 | /* Do we need to allocate an interrupt? */ | 585 | /* Do we need to allocate an interrupt? */ |
588 | if (cfg->irq.IRQInfo1 || cfg_mem->dflt.irq.IRQInfo1) | 586 | if (cfg->irq.IRQInfo1 || dflt->irq.IRQInfo1) |
589 | p_dev->conf.Attributes |= CONF_ENABLE_IRQ; | 587 | p_dev->conf.Attributes |= CONF_ENABLE_IRQ; |
590 | else if (!(p_dev->conf.Attributes & CONF_ENABLE_IRQ)) { | 588 | else if (!(p_dev->conf.Attributes & CONF_ENABLE_IRQ)) { |
591 | /* At least Compaq WL200 does not have IRQInfo1 set, | 589 | /* At least Compaq WL200 does not have IRQInfo1 set, |
@@ -597,11 +595,11 @@ static int prism2_config_check(struct pcmcia_device *p_dev, | |||
597 | 595 | ||
598 | /* IO window settings */ | 596 | /* IO window settings */ |
599 | PDEBUG(DEBUG_EXTRA, "IO window settings: cfg->io.nwin=%d " | 597 | PDEBUG(DEBUG_EXTRA, "IO window settings: cfg->io.nwin=%d " |
600 | "cfg_mem->dflt.io.nwin=%d\n", | 598 | "dflt->io.nwin=%d\n", |
601 | cfg->io.nwin, cfg_mem->dflt.io.nwin); | 599 | cfg->io.nwin, dflt->io.nwin); |
602 | p_dev->io.NumPorts1 = p_dev->io.NumPorts2 = 0; | 600 | p_dev->io.NumPorts1 = p_dev->io.NumPorts2 = 0; |
603 | if ((cfg->io.nwin > 0) || (cfg_mem->dflt.io.nwin > 0)) { | 601 | if ((cfg->io.nwin > 0) || (dflt->io.nwin > 0)) { |
604 | cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &cfg_mem->dflt.io; | 602 | cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &dflt->io; |
605 | p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO; | 603 | p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO; |
606 | PDEBUG(DEBUG_EXTRA, "io->flags = 0x%04X, " | 604 | PDEBUG(DEBUG_EXTRA, "io->flags = 0x%04X, " |
607 | "io.base=0x%04x, len=%d\n", io->flags, | 605 | "io.base=0x%04x, len=%d\n", io->flags, |
diff --git a/drivers/net/wireless/orinoco_cs.c b/drivers/net/wireless/orinoco_cs.c index 67a172dfb2db..8a367f96db37 100644 --- a/drivers/net/wireless/orinoco_cs.c +++ b/drivers/net/wireless/orinoco_cs.c | |||
@@ -165,18 +165,16 @@ static void orinoco_cs_detach(struct pcmcia_device *link) | |||
165 | } while (0) | 165 | } while (0) |
166 | 166 | ||
167 | struct orinoco_cs_config_data { | 167 | struct orinoco_cs_config_data { |
168 | cistpl_cftable_entry_t dflt; | ||
169 | config_info_t conf; | 168 | config_info_t conf; |
170 | }; | 169 | }; |
171 | 170 | ||
172 | static int orinoco_cs_config_check(struct pcmcia_device *p_dev, | 171 | static int orinoco_cs_config_check(struct pcmcia_device *p_dev, |
173 | cistpl_cftable_entry_t *cfg, | 172 | cistpl_cftable_entry_t *cfg, |
173 | cistpl_cftable_entry_t *dflt, | ||
174 | void *priv_data) | 174 | void *priv_data) |
175 | { | 175 | { |
176 | struct orinoco_cs_config_data *cfg_mem = priv_data; | 176 | struct orinoco_cs_config_data *cfg_mem = priv_data; |
177 | 177 | ||
178 | if (cfg->flags & CISTPL_CFTABLE_DEFAULT) | ||
179 | cfg_mem->dflt = *cfg; | ||
180 | if (cfg->index == 0) | 178 | if (cfg->index == 0) |
181 | goto next_entry; | 179 | goto next_entry; |
182 | 180 | ||
@@ -188,9 +186,9 @@ static int orinoco_cs_config_check(struct pcmcia_device *p_dev, | |||
188 | if (!ignore_cis_vcc) | 186 | if (!ignore_cis_vcc) |
189 | goto next_entry; | 187 | goto next_entry; |
190 | } | 188 | } |
191 | } else if (cfg_mem->dflt.vcc.present & (1 << CISTPL_POWER_VNOM)) { | 189 | } else if (dflt->vcc.present & (1 << CISTPL_POWER_VNOM)) { |
192 | if (cfg_mem->conf.Vcc != cfg_mem->dflt.vcc.param[CISTPL_POWER_VNOM] / 10000) { | 190 | if (cfg_mem->conf.Vcc != dflt->vcc.param[CISTPL_POWER_VNOM] / 10000) { |
193 | DEBUG(2, "spectrum_cs_config: Vcc mismatch (cfg_mem->conf.Vcc = %d, CIS = %d)\n", cfg_mem->conf.Vcc, cfg_mem->dflt.vcc.param[CISTPL_POWER_VNOM] / 10000); | 191 | DEBUG(2, "spectrum_cs_config: Vcc mismatch (cfg_mem->conf.Vcc = %d, CIS = %d)\n", cfg_mem->conf.Vcc, dflt->vcc.param[CISTPL_POWER_VNOM] / 10000); |
194 | if (!ignore_cis_vcc) | 192 | if (!ignore_cis_vcc) |
195 | goto next_entry; | 193 | goto next_entry; |
196 | } | 194 | } |
@@ -199,17 +197,17 @@ static int orinoco_cs_config_check(struct pcmcia_device *p_dev, | |||
199 | if (cfg->vpp1.present & (1 << CISTPL_POWER_VNOM)) | 197 | if (cfg->vpp1.present & (1 << CISTPL_POWER_VNOM)) |
200 | p_dev->conf.Vpp = | 198 | p_dev->conf.Vpp = |
201 | cfg->vpp1.param[CISTPL_POWER_VNOM] / 10000; | 199 | cfg->vpp1.param[CISTPL_POWER_VNOM] / 10000; |
202 | else if (cfg_mem->dflt.vpp1.present & (1 << CISTPL_POWER_VNOM)) | 200 | else if (dflt->vpp1.present & (1 << CISTPL_POWER_VNOM)) |
203 | p_dev->conf.Vpp = | 201 | p_dev->conf.Vpp = |
204 | cfg_mem->dflt.vpp1.param[CISTPL_POWER_VNOM] / 10000; | 202 | dflt->vpp1.param[CISTPL_POWER_VNOM] / 10000; |
205 | 203 | ||
206 | /* Do we need to allocate an interrupt? */ | 204 | /* Do we need to allocate an interrupt? */ |
207 | p_dev->conf.Attributes |= CONF_ENABLE_IRQ; | 205 | p_dev->conf.Attributes |= CONF_ENABLE_IRQ; |
208 | 206 | ||
209 | /* IO window settings */ | 207 | /* IO window settings */ |
210 | p_dev->io.NumPorts1 = p_dev->io.NumPorts2 = 0; | 208 | p_dev->io.NumPorts1 = p_dev->io.NumPorts2 = 0; |
211 | if ((cfg->io.nwin > 0) || (cfg_mem->dflt.io.nwin > 0)) { | 209 | if ((cfg->io.nwin > 0) || (dflt->io.nwin > 0)) { |
212 | cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &cfg_mem->dflt.io; | 210 | cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &dflt->io; |
213 | p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO; | 211 | p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO; |
214 | if (!(io->flags & CISTPL_IO_8BIT)) | 212 | if (!(io->flags & CISTPL_IO_8BIT)) |
215 | p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_16; | 213 | p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_16; |
diff --git a/drivers/net/wireless/spectrum_cs.c b/drivers/net/wireless/spectrum_cs.c index 7536aa91dad7..e28878dfaba3 100644 --- a/drivers/net/wireless/spectrum_cs.c +++ b/drivers/net/wireless/spectrum_cs.c | |||
@@ -634,18 +634,16 @@ static void spectrum_cs_detach(struct pcmcia_device *link) | |||
634 | */ | 634 | */ |
635 | 635 | ||
636 | struct spectrum_cs_config_data { | 636 | struct spectrum_cs_config_data { |
637 | cistpl_cftable_entry_t dflt; | ||
638 | config_info_t conf; | 637 | config_info_t conf; |
639 | }; | 638 | }; |
640 | 639 | ||
641 | static int spectrum_cs_config_check(struct pcmcia_device *p_dev, | 640 | static int spectrum_cs_config_check(struct pcmcia_device *p_dev, |
642 | cistpl_cftable_entry_t *cfg, | 641 | cistpl_cftable_entry_t *cfg, |
642 | cistpl_cftable_entry_t *dflt, | ||
643 | void *priv_data) | 643 | void *priv_data) |
644 | { | 644 | { |
645 | struct spectrum_cs_config_data *cfg_mem = priv_data; | 645 | struct spectrum_cs_config_data *cfg_mem = priv_data; |
646 | 646 | ||
647 | if (cfg->flags & CISTPL_CFTABLE_DEFAULT) | ||
648 | cfg_mem->dflt = *cfg; | ||
649 | if (cfg->index == 0) | 647 | if (cfg->index == 0) |
650 | goto next_entry; | 648 | goto next_entry; |
651 | 649 | ||
@@ -657,9 +655,9 @@ static int spectrum_cs_config_check(struct pcmcia_device *p_dev, | |||
657 | if (!ignore_cis_vcc) | 655 | if (!ignore_cis_vcc) |
658 | goto next_entry; | 656 | goto next_entry; |
659 | } | 657 | } |
660 | } else if (cfg_mem->dflt.vcc.present & (1 << CISTPL_POWER_VNOM)) { | 658 | } else if (dflt->vcc.present & (1 << CISTPL_POWER_VNOM)) { |
661 | if (cfg_mem->conf.Vcc != cfg_mem->dflt.vcc.param[CISTPL_POWER_VNOM] / 10000) { | 659 | if (cfg_mem->conf.Vcc != dflt->vcc.param[CISTPL_POWER_VNOM] / 10000) { |
662 | DEBUG(2, "spectrum_cs_config: Vcc mismatch (cfg_mem->conf.Vcc = %d, CIS = %d)\n", cfg_mem->conf.Vcc, cfg_mem->dflt.vcc.param[CISTPL_POWER_VNOM] / 10000); | 660 | DEBUG(2, "spectrum_cs_config: Vcc mismatch (cfg_mem->conf.Vcc = %d, CIS = %d)\n", cfg_mem->conf.Vcc, dflt->vcc.param[CISTPL_POWER_VNOM] / 10000); |
663 | if (!ignore_cis_vcc) | 661 | if (!ignore_cis_vcc) |
664 | goto next_entry; | 662 | goto next_entry; |
665 | } | 663 | } |
@@ -668,17 +666,17 @@ static int spectrum_cs_config_check(struct pcmcia_device *p_dev, | |||
668 | if (cfg->vpp1.present & (1 << CISTPL_POWER_VNOM)) | 666 | if (cfg->vpp1.present & (1 << CISTPL_POWER_VNOM)) |
669 | p_dev->conf.Vpp = | 667 | p_dev->conf.Vpp = |
670 | cfg->vpp1.param[CISTPL_POWER_VNOM] / 10000; | 668 | cfg->vpp1.param[CISTPL_POWER_VNOM] / 10000; |
671 | else if (cfg_mem->dflt.vpp1.present & (1 << CISTPL_POWER_VNOM)) | 669 | else if (dflt->vpp1.present & (1 << CISTPL_POWER_VNOM)) |
672 | p_dev->conf.Vpp = | 670 | p_dev->conf.Vpp = |
673 | cfg_mem->dflt.vpp1.param[CISTPL_POWER_VNOM] / 10000; | 671 | dflt->vpp1.param[CISTPL_POWER_VNOM] / 10000; |
674 | 672 | ||
675 | /* Do we need to allocate an interrupt? */ | 673 | /* Do we need to allocate an interrupt? */ |
676 | p_dev->conf.Attributes |= CONF_ENABLE_IRQ; | 674 | p_dev->conf.Attributes |= CONF_ENABLE_IRQ; |
677 | 675 | ||
678 | /* IO window settings */ | 676 | /* IO window settings */ |
679 | p_dev->io.NumPorts1 = p_dev->io.NumPorts2 = 0; | 677 | p_dev->io.NumPorts1 = p_dev->io.NumPorts2 = 0; |
680 | if ((cfg->io.nwin > 0) || (cfg_mem->dflt.io.nwin > 0)) { | 678 | if ((cfg->io.nwin > 0) || (dflt->io.nwin > 0)) { |
681 | cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &cfg_mem->dflt.io; | 679 | cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &dflt->io; |
682 | p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO; | 680 | p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO; |
683 | if (!(io->flags & CISTPL_IO_8BIT)) | 681 | if (!(io->flags & CISTPL_IO_8BIT)) |
684 | p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_16; | 682 | p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_16; |