diff options
author | Dominik Brodowski <linux@dominikbrodowski.net> | 2009-10-18 19:07:34 -0400 |
---|---|---|
committer | David Woodhouse <David.Woodhouse@intel.com> | 2009-10-18 19:40:37 -0400 |
commit | 5da6bbe2f9e1db56b4a94cad2ace7d9992b1d666 (patch) | |
tree | b851288ad16e7f2679cb8047b9d43efad29a6d18 /drivers/mtd/maps | |
parent | 9729b260ea5ef4b2c5de0643a7b764b408e275b1 (diff) |
pcmcia: convert pcmciamtd driver to use new CIS helpers
Convert the (broken) pcmciamtd driver to use the new CIS helpers.
Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net>
Signed-off-by: David Woodhouse <David.Woodhouse@intel.com>
Diffstat (limited to 'drivers/mtd/maps')
-rw-r--r-- | drivers/mtd/maps/pcmciamtd.c | 175 |
1 files changed, 91 insertions, 84 deletions
diff --git a/drivers/mtd/maps/pcmciamtd.c b/drivers/mtd/maps/pcmciamtd.c index d600c2deff73..52c07f21be01 100644 --- a/drivers/mtd/maps/pcmciamtd.c +++ b/drivers/mtd/maps/pcmciamtd.c | |||
@@ -354,101 +354,108 @@ static void pcmciamtd_release(struct pcmcia_device *link) | |||
354 | } | 354 | } |
355 | 355 | ||
356 | 356 | ||
357 | static void card_settings(struct pcmciamtd_dev *dev, struct pcmcia_device *link, int *new_name) | 357 | #ifdef CONFIG_MTD_DEBUG |
358 | static int pcmciamtd_cistpl_format(struct pcmcia_device *p_dev, | ||
359 | tuple_t *tuple, | ||
360 | void *priv_data) | ||
358 | { | 361 | { |
359 | int rc; | ||
360 | tuple_t tuple; | ||
361 | cisparse_t parse; | 362 | cisparse_t parse; |
362 | u_char buf[64]; | ||
363 | |||
364 | tuple.Attributes = 0; | ||
365 | tuple.TupleData = (cisdata_t *)buf; | ||
366 | tuple.TupleDataMax = sizeof(buf); | ||
367 | tuple.TupleOffset = 0; | ||
368 | tuple.DesiredTuple = RETURN_FIRST_TUPLE; | ||
369 | |||
370 | rc = pcmcia_get_first_tuple(link, &tuple); | ||
371 | while (rc == 0) { | ||
372 | rc = pcmcia_get_tuple_data(link, &tuple); | ||
373 | if (rc != 0) { | ||
374 | cs_error(link, GetTupleData, rc); | ||
375 | break; | ||
376 | } | ||
377 | rc = pcmcia_parse_tuple(&tuple, &parse); | ||
378 | if (rc != 0) { | ||
379 | cs_error(link, ParseTuple, rc); | ||
380 | break; | ||
381 | } | ||
382 | 363 | ||
383 | switch(tuple.TupleCode) { | 364 | if (!pcmcia_parse_tuple(tuple, &parse)) { |
384 | case CISTPL_FORMAT: { | 365 | cistpl_format_t *t = &parse.format; |
385 | cistpl_format_t *t = &parse.format; | 366 | (void)t; /* Shut up, gcc */ |
386 | (void)t; /* Shut up, gcc */ | 367 | DEBUG(2, "Format type: %u, Error Detection: %u, offset = %u, length =%u", |
387 | DEBUG(2, "Format type: %u, Error Detection: %u, offset = %u, length =%u", | 368 | t->type, t->edc, t->offset, t->length); |
388 | t->type, t->edc, t->offset, t->length); | 369 | } |
389 | break; | 370 | return -ENOSPC; |
371 | } | ||
390 | 372 | ||
391 | } | 373 | static int pcmciamtd_cistpl_jedec(struct pcmcia_device *p_dev, |
374 | tuple_t *tuple, | ||
375 | void *priv_data) | ||
376 | { | ||
377 | cisparse_t parse; | ||
378 | int i; | ||
392 | 379 | ||
393 | case CISTPL_DEVICE: { | 380 | if (!pcmcia_parse_tuple(tuple, &parse)) { |
394 | cistpl_device_t *t = &parse.device; | 381 | cistpl_jedec_t *t = &parse.jedec; |
395 | int i; | 382 | for (i = 0; i < t->nid; i++) |
396 | DEBUG(2, "Common memory:"); | 383 | DEBUG(2, "JEDEC: 0x%02x 0x%02x", t->id[i].mfr, t->id[i].info); |
397 | dev->pcmcia_map.size = t->dev[0].size; | 384 | } |
398 | for(i = 0; i < t->ndev; i++) { | 385 | return -ENOSPC; |
399 | DEBUG(2, "Region %d, type = %u", i, t->dev[i].type); | 386 | } |
400 | DEBUG(2, "Region %d, wp = %u", i, t->dev[i].wp); | 387 | #endif |
401 | DEBUG(2, "Region %d, speed = %u ns", i, t->dev[i].speed); | ||
402 | DEBUG(2, "Region %d, size = %u bytes", i, t->dev[i].size); | ||
403 | } | ||
404 | break; | ||
405 | } | ||
406 | 388 | ||
407 | case CISTPL_VERS_1: { | 389 | static int pcmciamtd_cistpl_device(struct pcmcia_device *p_dev, |
408 | cistpl_vers_1_t *t = &parse.version_1; | 390 | tuple_t *tuple, |
409 | int i; | 391 | void *priv_data) |
410 | if(t->ns) { | 392 | { |
411 | dev->mtd_name[0] = '\0'; | 393 | struct pcmciamtd_dev *dev = priv_data; |
412 | for(i = 0; i < t->ns; i++) { | 394 | cisparse_t parse; |
413 | if(i) | 395 | cistpl_device_t *t = &parse.device; |
414 | strcat(dev->mtd_name, " "); | 396 | |
415 | strcat(dev->mtd_name, t->str+t->ofs[i]); | 397 | if (pcmcia_parse_tuple(tuple, &parse)) |
416 | } | 398 | return -EINVAL; |
417 | } | 399 | |
418 | DEBUG(2, "Found name: %s", dev->mtd_name); | 400 | DEBUG(2, "Common memory:"); |
419 | break; | 401 | dev->pcmcia_map.size = t->dev[0].size; |
420 | } | 402 | /* from here on: DEBUG only */ |
403 | for (i = 0; i < t->ndev; i++) { | ||
404 | DEBUG(2, "Region %d, type = %u", i, t->dev[i].type); | ||
405 | DEBUG(2, "Region %d, wp = %u", i, t->dev[i].wp); | ||
406 | DEBUG(2, "Region %d, speed = %u ns", i, t->dev[i].speed); | ||
407 | DEBUG(2, "Region %d, size = %u bytes", i, t->dev[i].size); | ||
408 | } | ||
409 | return 0; | ||
410 | } | ||
421 | 411 | ||
422 | case CISTPL_JEDEC_C: { | 412 | static int pcmciamtd_cistpl_geo(struct pcmcia_device *p_dev, |
423 | cistpl_jedec_t *t = &parse.jedec; | 413 | tuple_t *tuple, |
424 | int i; | 414 | void *priv_data) |
425 | for(i = 0; i < t->nid; i++) { | 415 | { |
426 | DEBUG(2, "JEDEC: 0x%02x 0x%02x", t->id[i].mfr, t->id[i].info); | 416 | struct pcmciamtd_dev *dev = priv_data; |
427 | } | 417 | cisparse_t parse; |
428 | break; | 418 | cistpl_device_geo_t *t = &parse.device_geo; |
429 | } | 419 | |
420 | if (pcmcia_parse_tuple(tuple, &parse)) | ||
421 | return -EINVAL; | ||
422 | |||
423 | dev->pcmcia_map.bankwidth = t->geo[0].buswidth; | ||
424 | /* from here on: DEBUG only */ | ||
425 | for (i = 0; i < t->ngeo; i++) { | ||
426 | DEBUG(2, "region: %d bankwidth = %u", i, t->geo[i].buswidth); | ||
427 | DEBUG(2, "region: %d erase_block = %u", i, t->geo[i].erase_block); | ||
428 | DEBUG(2, "region: %d read_block = %u", i, t->geo[i].read_block); | ||
429 | DEBUG(2, "region: %d write_block = %u", i, t->geo[i].write_block); | ||
430 | DEBUG(2, "region: %d partition = %u", i, t->geo[i].partition); | ||
431 | DEBUG(2, "region: %d interleave = %u", i, t->geo[i].interleave); | ||
432 | } | ||
433 | return 0; | ||
434 | } | ||
430 | 435 | ||
431 | case CISTPL_DEVICE_GEO: { | ||
432 | cistpl_device_geo_t *t = &parse.device_geo; | ||
433 | int i; | ||
434 | dev->pcmcia_map.bankwidth = t->geo[0].buswidth; | ||
435 | for(i = 0; i < t->ngeo; i++) { | ||
436 | DEBUG(2, "region: %d bankwidth = %u", i, t->geo[i].buswidth); | ||
437 | DEBUG(2, "region: %d erase_block = %u", i, t->geo[i].erase_block); | ||
438 | DEBUG(2, "region: %d read_block = %u", i, t->geo[i].read_block); | ||
439 | DEBUG(2, "region: %d write_block = %u", i, t->geo[i].write_block); | ||
440 | DEBUG(2, "region: %d partition = %u", i, t->geo[i].partition); | ||
441 | DEBUG(2, "region: %d interleave = %u", i, t->geo[i].interleave); | ||
442 | } | ||
443 | break; | ||
444 | } | ||
445 | 436 | ||
446 | default: | 437 | static void card_settings(struct pcmciamtd_dev *dev, struct pcmcia_device *link, int *new_name) |
447 | DEBUG(2, "Unknown tuple code %d", tuple.TupleCode); | 438 | { |
448 | } | 439 | int i; |
449 | 440 | ||
450 | rc = pcmcia_get_next_tuple(link, &tuple); | 441 | if (p_dev->prod_id[0]) { |
442 | dev->mtd_name[0] = '\0'; | ||
443 | for (i = 0; i < 4; i++) { | ||
444 | if (i) | ||
445 | strcat(dev->mtd_name, " "); | ||
446 | if (p_dev->prod_id[i]) | ||
447 | strcat(dev->mtd_name, p_dev->prod_id[i]); | ||
448 | } | ||
449 | DEBUG(2, "Found name: %s", dev->mtd_name); | ||
451 | } | 450 | } |
451 | |||
452 | #ifdef CONFIG_MTD_DEBUG | ||
453 | pcmcia_loop_tuple(p_dev, CISTPL_FORMAT, pcmciamtd_cistpl_format, NULL); | ||
454 | pcmcia_loop_tuple(p_dev, CISTPL_JEDEC_C, pcmciamtd_cistpl_jedec, NULL); | ||
455 | #endif | ||
456 | pcmcia_loop_tuple(p_dev, CISTPL_DEVICE, pcmciamtd_cistpl_device, dev); | ||
457 | pcmcia_loop_tuple(p_dev, CISTPL_DEVICE_GEO, pcmciamtd_cistpl_geo, dev); | ||
458 | |||
452 | if(!dev->pcmcia_map.size) | 459 | if(!dev->pcmcia_map.size) |
453 | dev->pcmcia_map.size = MAX_PCMCIA_ADDR; | 460 | dev->pcmcia_map.size = MAX_PCMCIA_ADDR; |
454 | 461 | ||