aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/mtd/maps
diff options
context:
space:
mode:
authorDominik Brodowski <linux@dominikbrodowski.net>2009-10-18 19:07:34 -0400
committerDavid Woodhouse <David.Woodhouse@intel.com>2009-10-18 19:40:37 -0400
commit5da6bbe2f9e1db56b4a94cad2ace7d9992b1d666 (patch)
treeb851288ad16e7f2679cb8047b9d43efad29a6d18 /drivers/mtd/maps
parent9729b260ea5ef4b2c5de0643a7b764b408e275b1 (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.c175
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
357static void card_settings(struct pcmciamtd_dev *dev, struct pcmcia_device *link, int *new_name) 357#ifdef CONFIG_MTD_DEBUG
358static 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 } 373static 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: { 389static 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: { 412static 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: 437static 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