summaryrefslogtreecommitdiff
path: root/target/linux/s3c24xx/patches-2.6.24/1138-From-cc08b5986dfd8d971ee46ce7045fb7863f99a92a-Mon-Se.patch
diff options
context:
space:
mode:
Diffstat (limited to 'target/linux/s3c24xx/patches-2.6.24/1138-From-cc08b5986dfd8d971ee46ce7045fb7863f99a92a-Mon-Se.patch')
-rw-r--r--target/linux/s3c24xx/patches-2.6.24/1138-From-cc08b5986dfd8d971ee46ce7045fb7863f99a92a-Mon-Se.patch121
1 files changed, 121 insertions, 0 deletions
diff --git a/target/linux/s3c24xx/patches-2.6.24/1138-From-cc08b5986dfd8d971ee46ce7045fb7863f99a92a-Mon-Se.patch b/target/linux/s3c24xx/patches-2.6.24/1138-From-cc08b5986dfd8d971ee46ce7045fb7863f99a92a-Mon-Se.patch
new file mode 100644
index 0000000..5c09ff7
--- /dev/null
+++ b/target/linux/s3c24xx/patches-2.6.24/1138-From-cc08b5986dfd8d971ee46ce7045fb7863f99a92a-Mon-Se.patch
@@ -0,0 +1,121 @@
+From 463f236121c752e434de713f6b141ed885c5fc5b Mon Sep 17 00:00:00 2001
+From: Matt Hsu <matt_hsu@openmoko.org>
+Date: Wed, 30 Apr 2008 13:33:58 +0100
+Subject: [PATCH] From cc08b5986dfd8d971ee46ce7045fb7863f99a92a Mon Sep 17 00:00:00 2001
+ Subject: [PATCH] - add suspend/resume function of s3c24xx_hcd driver
+
+Signed-off-by: Matt Hsu <matt_hsu@openmoko.org>
+---
+ drivers/sdio/hcd/s3c24xx/s3c24xx_hcd.c | 65 ++++++++++++++++++++++++++++++++
+ drivers/sdio/hcd/s3c24xx/s3c24xx_hcd.h | 14 +++++++
+ 2 files changed, 79 insertions(+), 0 deletions(-)
+
+diff --git a/drivers/sdio/hcd/s3c24xx/s3c24xx_hcd.c b/drivers/sdio/hcd/s3c24xx/s3c24xx_hcd.c
+index 8c3bbbc..7ead7b7 100644
+--- a/drivers/sdio/hcd/s3c24xx/s3c24xx_hcd.c
++++ b/drivers/sdio/hcd/s3c24xx/s3c24xx_hcd.c
+@@ -1364,11 +1364,76 @@ static int s3c24xx_hcd_remove(struct platform_device * pdev) {
+ return 0;
+ }
+
++#ifdef CONFIG_PM
++
++static int s3c24xx_hcd_suspend(struct platform_device * pdev)
++{
++ struct s3c24xx_hcd_context * context = &hcd_context;
++ unsigned long flags;
++
++ spin_lock_irqsave(&context->lock, flags);
++
++ context->suspend_regs.con = readl(context->base + S3C2410_SDICON);
++ context->suspend_regs.pre = readl(context->base + S3C2410_SDIPRE);
++ context->suspend_regs.cmdarg = readl(context->base + S3C2410_SDICMDARG);
++ context->suspend_regs.cmdcon = readl(context->base + S3C2410_SDICMDCON);
++ context->suspend_regs.cmdsta = readl(context->base + S3C2410_SDICMDSTAT);
++ context->suspend_regs.r0 = readl(context->base + S3C2410_SDIRSP0);
++ context->suspend_regs.r1 = readl(context->base + S3C2410_SDIRSP1);
++ context->suspend_regs.r2 = readl(context->base + S3C2410_SDIRSP2);
++ context->suspend_regs.r3 = readl(context->base + S3C2410_SDIRSP3);
++ context->suspend_regs.timer = readl(context->base + S3C2410_SDITIMER);
++ context->suspend_regs.bsize = readl(context->base + S3C2410_SDIBSIZE);
++ context->suspend_regs.datcon = readl(context->base + S3C2410_SDIDCON);
++ context->suspend_regs.datcnt = readl(context->base + S3C2410_SDIDCNT);
++ context->suspend_regs.datsta = readl(context->base + S3C2410_SDIDSTA);
++ context->suspend_regs.fsta = readl(context->base + S3C2410_SDIFSTA);
++ context->suspend_regs.imask = readl(context->base + S3C2440_SDIIMSK);
++
++ spin_unlock_irqrestore(&context->lock, flags);
++ return 0;
++}
++
++static int s3c24xx_hcd_resume(struct platform_device * pdev)
++{
++ struct s3c24xx_hcd_context * context = &hcd_context;
++ unsigned long flags;
++
++ spin_lock_irqsave(&context->lock, flags);
++
++ writel(context->suspend_regs.con, context->base + S3C2410_SDICON);
++ writel(context->suspend_regs.pre, context->base + S3C2410_SDIPRE);
++ writel(context->suspend_regs.cmdarg, context->base + S3C2410_SDICMDARG);
++ writel(context->suspend_regs.cmdcon, context->base + S3C2410_SDICMDCON);
++ writel(context->suspend_regs.cmdsta, context->base + S3C2410_SDICMDSTAT);
++ writel(context->suspend_regs.r0, context->base + S3C2410_SDIRSP0);
++ writel(context->suspend_regs.r1, context->base + S3C2410_SDIRSP1);
++ writel(context->suspend_regs.r2, context->base + S3C2410_SDIRSP2);
++ writel(context->suspend_regs.r3, context->base + S3C2410_SDIRSP3);
++ writel(context->suspend_regs.timer, context->base + S3C2410_SDITIMER);
++ writel(context->suspend_regs.bsize, context->base + S3C2410_SDIBSIZE);
++ writel(context->suspend_regs.datcon, context->base + S3C2410_SDIDCON);
++ writel(context->suspend_regs.datcnt, context->base + S3C2410_SDIDCNT);
++ writel(context->suspend_regs.datsta, context->base + S3C2410_SDIDSTA);
++ writel(context->suspend_regs.fsta, context->base + S3C2410_SDIFSTA);
++ writel(context->suspend_regs.imask, context->base + S3C2440_SDIIMSK);
++
++ spin_unlock_irqrestore(&context->lock, flags);
++ return 0;
++}
++
++#else
++#define s3c24xx_hcd_suspend = NULL
++#define s3c24xx_hcd_resume = NULL
++#endif
++
+ static struct platform_driver s3c24xx_hcd_sdio =
+ {
+ .driver.name = "s3c24xx-sdio",
+ .probe = s3c24xx_hcd_probe,
+ .remove = s3c24xx_hcd_remove,
++ .suspend = s3c24xx_hcd_suspend,
++ .resume = s3c24xx_hcd_resume,
+ };
+
+ #ifdef CONFIG_DEBUG_FS
+diff --git a/drivers/sdio/hcd/s3c24xx/s3c24xx_hcd.h b/drivers/sdio/hcd/s3c24xx/s3c24xx_hcd.h
+index eb262fc..47fdd33 100644
+--- a/drivers/sdio/hcd/s3c24xx/s3c24xx_hcd.h
++++ b/drivers/sdio/hcd/s3c24xx/s3c24xx_hcd.h
+@@ -57,6 +57,20 @@ struct s3c24xx_hcd_context {
+
+ struct work_struct io_work;
+ struct work_struct irq_work;
++
++#ifdef CONFIG_PM
++ struct {
++ UINT32 con;
++ UINT32 pre;
++ UINT32 cmdarg, cmdcon, cmdsta;
++ UINT32 r0, r1, r2, r3;
++ UINT32 timer;
++ UINT32 bsize;
++ UINT32 datcon, datcnt, datsta;
++ UINT32 fsta;
++ UINT32 imask;
++ } suspend_regs;
++#endif
+ };
+
+ SDIO_STATUS s3c24xx_hcd_config(PSDHCD hcd, PSDCONFIG config);
+--
+1.5.6.5
+