From 3208a56fd30ec591f40ceda3e581757092dbca4a Mon Sep 17 00:00:00 2001 From: Saeed Bishara Date: Sun, 6 Dec 2009 18:26:19 +0200 Subject: [PATCH] --- yaml --- r: 178075 b: refs/heads/master c: 6481f2b52cd5411ea6342b749daf0e4f3b390d7b h: refs/heads/master i: 178073: f44775eda7c8eed63dca8b76b67100e3a5b12e1c 178071: e61c52566c36d114ffc1f60b328f63d963548344 v: v3 --- [refs] | 2 +- trunk/drivers/ata/sata_mv.c | 43 +++++++++++++++++++++++++++++++++++++ 2 files changed, 44 insertions(+), 1 deletion(-) mode change 100644 => 100755 trunk/drivers/ata/sata_mv.c diff --git a/[refs] b/[refs] index d7ddd8740537..6a6a6764e948 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: c77a2f4e6b76c9094182dfa653ece4243f6df80c +refs/heads/master: 6481f2b52cd5411ea6342b749daf0e4f3b390d7b diff --git a/trunk/drivers/ata/sata_mv.c b/trunk/drivers/ata/sata_mv.c old mode 100644 new mode 100755 index b625b3614989..0f7704c0b4cc --- a/trunk/drivers/ata/sata_mv.c +++ b/trunk/drivers/ata/sata_mv.c @@ -4112,9 +4112,52 @@ static int __devexit mv_platform_remove(struct platform_device *pdev) return 0; } +#ifdef CONFIG_PM +static int mv_platform_suspend(struct platform_device *pdev, pm_message_t state) +{ + struct ata_host *host = dev_get_drvdata(&pdev->dev); + if (host) + return ata_host_suspend(host, state); + else + return 0; +} + +static int mv_platform_resume(struct platform_device *pdev) +{ + struct ata_host *host = dev_get_drvdata(&pdev->dev); + int ret; + + if (host) { + struct mv_host_priv *hpriv = host->private_data; + const struct mv_sata_platform_data *mv_platform_data = \ + pdev->dev.platform_data; + /* + * (Re-)program MBUS remapping windows if we are asked to. + */ + if (mv_platform_data->dram != NULL) + mv_conf_mbus_windows(hpriv, mv_platform_data->dram); + + /* initialize adapter */ + ret = mv_init_host(host, chip_soc); + if (ret) { + printk(KERN_ERR DRV_NAME ": Error during HW init\n"); + return ret; + } + ata_host_resume(host); + } + + return 0; +} +#else +#define mv_platform_suspend NULL +#define mv_platform_resume NULL +#endif + static struct platform_driver mv_platform_driver = { .probe = mv_platform_probe, .remove = __devexit_p(mv_platform_remove), + .suspend = mv_platform_suspend, + .resume = mv_platform_resume, .driver = { .name = DRV_NAME, .owner = THIS_MODULE,