Commit ead995f8 authored by Artem Bityutskiy's avatar Artem Bityutskiy Committed by David Woodhouse

mtd: introduce mtd_resume interface

Signed-off-by: default avatarArtem Bityutskiy <artem.bityutskiy@linux.intel.com>
Signed-off-by: default avatarDavid Woodhouse <David.Woodhouse@intel.com>
parent 3fe4bae8
...@@ -192,7 +192,7 @@ static void physmap_flash_shutdown(struct platform_device *dev) ...@@ -192,7 +192,7 @@ static void physmap_flash_shutdown(struct platform_device *dev)
for (i = 0; i < MAX_RESOURCES && info->mtd[i]; i++) for (i = 0; i < MAX_RESOURCES && info->mtd[i]; i++)
if (info->mtd[i]->suspend && info->mtd[i]->resume) if (info->mtd[i]->suspend && info->mtd[i]->resume)
if (mtd_suspend(info->mtd[i]) == 0) if (mtd_suspend(info->mtd[i]) == 0)
info->mtd[i]->resume(info->mtd[i]); mtd_resume(info->mtd[i]);
} }
#else #else
#define physmap_flash_shutdown NULL #define physmap_flash_shutdown NULL
......
...@@ -126,7 +126,7 @@ static void pxa2xx_flash_shutdown(struct platform_device *dev) ...@@ -126,7 +126,7 @@ static void pxa2xx_flash_shutdown(struct platform_device *dev)
struct pxa2xx_flash_info *info = platform_get_drvdata(dev); struct pxa2xx_flash_info *info = platform_get_drvdata(dev);
if (info && mtd_suspend(info->mtd) == 0) if (info && mtd_suspend(info->mtd) == 0)
info->mtd->resume(info->mtd); mtd_resume(info->mtd);
} }
#else #else
#define pxa2xx_flash_shutdown NULL #define pxa2xx_flash_shutdown NULL
......
...@@ -121,7 +121,7 @@ static void rbtx4939_flash_shutdown(struct platform_device *dev) ...@@ -121,7 +121,7 @@ static void rbtx4939_flash_shutdown(struct platform_device *dev)
if (info->mtd->suspend && info->mtd->resume) if (info->mtd->suspend && info->mtd->resume)
if (mtd_suspend(info->mtd) == 0) if (mtd_suspend(info->mtd) == 0)
info->mtd->resume(info->mtd); mtd_resume(info->mtd);
} }
#else #else
#define rbtx4939_flash_shutdown NULL #define rbtx4939_flash_shutdown NULL
......
...@@ -378,7 +378,7 @@ static void sa1100_mtd_shutdown(struct platform_device *dev) ...@@ -378,7 +378,7 @@ static void sa1100_mtd_shutdown(struct platform_device *dev)
{ {
struct sa_info *info = platform_get_drvdata(dev); struct sa_info *info = platform_get_drvdata(dev);
if (info && mtd_suspend(info->mtd) == 0) if (info && mtd_suspend(info->mtd) == 0)
info->mtd->resume(info->mtd); mtd_resume(info->mtd);
} }
#else #else
#define sa1100_mtd_shutdown NULL #define sa1100_mtd_shutdown NULL
......
...@@ -644,7 +644,7 @@ static void concat_resume(struct mtd_info *mtd) ...@@ -644,7 +644,7 @@ static void concat_resume(struct mtd_info *mtd)
for (i = 0; i < concat->num_subdev; i++) { for (i = 0; i < concat->num_subdev; i++) {
struct mtd_info *subdev = concat->subdev[i]; struct mtd_info *subdev = concat->subdev[i];
subdev->resume(subdev); mtd_resume(subdev);
} }
} }
......
...@@ -129,7 +129,7 @@ static int mtd_cls_resume(struct device *dev) ...@@ -129,7 +129,7 @@ static int mtd_cls_resume(struct device *dev)
struct mtd_info *mtd = dev_to_mtd(dev); struct mtd_info *mtd = dev_to_mtd(dev);
if (mtd && mtd->resume) if (mtd && mtd->resume)
mtd->resume(mtd); mtd_resume(mtd);
return 0; return 0;
} }
......
...@@ -313,7 +313,7 @@ static int part_suspend(struct mtd_info *mtd) ...@@ -313,7 +313,7 @@ static int part_suspend(struct mtd_info *mtd)
static void part_resume(struct mtd_info *mtd) static void part_resume(struct mtd_info *mtd)
{ {
struct mtd_part *part = PART(mtd); struct mtd_part *part = PART(mtd);
part->master->resume(part->master); mtd_resume(part->master);
} }
static int part_block_isbad(struct mtd_info *mtd, loff_t ofs) static int part_block_isbad(struct mtd_info *mtd, loff_t ofs)
......
...@@ -209,7 +209,7 @@ static int nomadik_nand_resume(struct device *dev) ...@@ -209,7 +209,7 @@ static int nomadik_nand_resume(struct device *dev)
{ {
struct nomadik_nand_host *host = dev_get_drvdata(dev); struct nomadik_nand_host *host = dev_get_drvdata(dev);
if (host) if (host)
host->mtd.resume(&host->mtd); mtd_resume(&host->mtd);
return 0; return 0;
} }
......
...@@ -1291,7 +1291,7 @@ static int pxa3xx_nand_resume(struct platform_device *pdev) ...@@ -1291,7 +1291,7 @@ static int pxa3xx_nand_resume(struct platform_device *pdev)
nand_writel(info, NDSR, NDSR_MASK); nand_writel(info, NDSR, NDSR_MASK);
for (cs = 0; cs < pdata->num_cs; cs++) { for (cs = 0; cs < pdata->num_cs; cs++) {
mtd = info->host[cs]->mtd; mtd = info->host[cs]->mtd;
mtd->resume(mtd); mtd_resume(mtd);
} }
return 0; return 0;
......
...@@ -211,15 +211,13 @@ struct mtd_info { ...@@ -211,15 +211,13 @@ struct mtd_info {
int (*unlock) (struct mtd_info *mtd, loff_t ofs, uint64_t len); int (*unlock) (struct mtd_info *mtd, loff_t ofs, uint64_t len);
int (*is_locked) (struct mtd_info *mtd, loff_t ofs, uint64_t len); int (*is_locked) (struct mtd_info *mtd, loff_t ofs, uint64_t len);
int (*suspend) (struct mtd_info *mtd); int (*suspend) (struct mtd_info *mtd);
void (*resume) (struct mtd_info *mtd);
/* Backing device capabilities for this device /* Backing device capabilities for this device
* - provides mmap capabilities * - provides mmap capabilities
*/ */
struct backing_dev_info *backing_dev_info; struct backing_dev_info *backing_dev_info;
/* Power Management functions */
void (*resume) (struct mtd_info *mtd);
/* Bad block management functions */ /* Bad block management functions */
int (*block_isbad) (struct mtd_info *mtd, loff_t ofs); int (*block_isbad) (struct mtd_info *mtd, loff_t ofs);
int (*block_markbad) (struct mtd_info *mtd, loff_t ofs); int (*block_markbad) (struct mtd_info *mtd, loff_t ofs);
...@@ -403,6 +401,11 @@ static inline int mtd_suspend(struct mtd_info *mtd) ...@@ -403,6 +401,11 @@ static inline int mtd_suspend(struct mtd_info *mtd)
return mtd->suspend(mtd); return mtd->suspend(mtd);
} }
static inline void mtd_resume(struct mtd_info *mtd)
{
mtd->resume(mtd);
}
static inline struct mtd_info *dev_to_mtd(struct device *dev) static inline struct mtd_info *dev_to_mtd(struct device *dev)
{ {
return dev ? dev_get_drvdata(dev) : NULL; return dev ? dev_get_drvdata(dev) : NULL;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment