diff options
Diffstat (limited to 'drivers/mtd/onenand')
-rw-r--r-- | drivers/mtd/onenand/onenand_base.c | 36 |
1 files changed, 33 insertions, 3 deletions
diff --git a/drivers/mtd/onenand/onenand_base.c b/drivers/mtd/onenand/onenand_base.c index 75d757882697..a002d4025b29 100644 --- a/drivers/mtd/onenand/onenand_base.c +++ b/drivers/mtd/onenand/onenand_base.c | |||
@@ -505,7 +505,7 @@ static int onenand_update_bufferram(struct mtd_info *mtd, loff_t addr, | |||
505 | * | 505 | * |
506 | * Get the device and lock it for exclusive access | 506 | * Get the device and lock it for exclusive access |
507 | */ | 507 | */ |
508 | static void onenand_get_device(struct mtd_info *mtd, int new_state) | 508 | static int onenand_get_device(struct mtd_info *mtd, int new_state) |
509 | { | 509 | { |
510 | struct onenand_chip *this = mtd->priv; | 510 | struct onenand_chip *this = mtd->priv; |
511 | DECLARE_WAITQUEUE(wait, current); | 511 | DECLARE_WAITQUEUE(wait, current); |
@@ -520,12 +520,18 @@ static void onenand_get_device(struct mtd_info *mtd, int new_state) | |||
520 | spin_unlock(&this->chip_lock); | 520 | spin_unlock(&this->chip_lock); |
521 | break; | 521 | break; |
522 | } | 522 | } |
523 | if (new_state == FL_PM_SUSPENDED) { | ||
524 | spin_unlock(&this->chip_lock); | ||
525 | return (this->state == FL_PM_SUSPENDED) ? 0 : -EAGAIN; | ||
526 | } | ||
523 | set_current_state(TASK_UNINTERRUPTIBLE); | 527 | set_current_state(TASK_UNINTERRUPTIBLE); |
524 | add_wait_queue(&this->wq, &wait); | 528 | add_wait_queue(&this->wq, &wait); |
525 | spin_unlock(&this->chip_lock); | 529 | spin_unlock(&this->chip_lock); |
526 | schedule(); | 530 | schedule(); |
527 | remove_wait_queue(&this->wq, &wait); | 531 | remove_wait_queue(&this->wq, &wait); |
528 | } | 532 | } |
533 | |||
534 | return 0; | ||
529 | } | 535 | } |
530 | 536 | ||
531 | /** | 537 | /** |
@@ -1440,6 +1446,30 @@ static int onenand_probe(struct mtd_info *mtd) | |||
1440 | return 0; | 1446 | return 0; |
1441 | } | 1447 | } |
1442 | 1448 | ||
1449 | /** | ||
1450 | * onenand_suspend - [MTD Interface] Suspend the OneNAND flash | ||
1451 | * @param mtd MTD device structure | ||
1452 | */ | ||
1453 | static int onenand_suspend(struct mtd_info *mtd) | ||
1454 | { | ||
1455 | return onenand_get_device(mtd, FL_PM_SUSPENDED); | ||
1456 | } | ||
1457 | |||
1458 | /** | ||
1459 | * onenand_resume - [MTD Interface] Resume the OneNAND flash | ||
1460 | * @param mtd MTD device structure | ||
1461 | */ | ||
1462 | static void onenand_resume(struct mtd_info *mtd) | ||
1463 | { | ||
1464 | struct onenand_chip *this = mtd->priv; | ||
1465 | |||
1466 | if (this->state == FL_PM_SUSPENDED) | ||
1467 | onenand_release_device(mtd); | ||
1468 | else | ||
1469 | printk(KERN_ERR "resume() called for the chip which is not" | ||
1470 | "in suspended state\n"); | ||
1471 | } | ||
1472 | |||
1443 | 1473 | ||
1444 | /** | 1474 | /** |
1445 | * onenand_scan - [OneNAND Interface] Scan for the OneNAND device | 1475 | * onenand_scan - [OneNAND Interface] Scan for the OneNAND device |
@@ -1527,8 +1557,8 @@ int onenand_scan(struct mtd_info *mtd, int maxchips) | |||
1527 | mtd->sync = onenand_sync; | 1557 | mtd->sync = onenand_sync; |
1528 | mtd->lock = NULL; | 1558 | mtd->lock = NULL; |
1529 | mtd->unlock = onenand_unlock; | 1559 | mtd->unlock = onenand_unlock; |
1530 | mtd->suspend = NULL; | 1560 | mtd->suspend = onenand_suspend; |
1531 | mtd->resume = NULL; | 1561 | mtd->resume = onenand_resume; |
1532 | mtd->block_isbad = onenand_block_isbad; | 1562 | mtd->block_isbad = onenand_block_isbad; |
1533 | mtd->block_markbad = onenand_block_markbad; | 1563 | mtd->block_markbad = onenand_block_markbad; |
1534 | mtd->owner = THIS_MODULE; | 1564 | mtd->owner = THIS_MODULE; |