diff options
Diffstat (limited to 'target/linux/s3c24xx/patches/0239-fix-hdq-probe.patch.patch')
-rwxr-xr-x | target/linux/s3c24xx/patches/0239-fix-hdq-probe.patch.patch | 107 |
1 files changed, 0 insertions, 107 deletions
diff --git a/target/linux/s3c24xx/patches/0239-fix-hdq-probe.patch.patch b/target/linux/s3c24xx/patches/0239-fix-hdq-probe.patch.patch deleted file mode 100755 index fbf74184ef..0000000000 --- a/target/linux/s3c24xx/patches/0239-fix-hdq-probe.patch.patch +++ /dev/null @@ -1,107 +0,0 @@ -From 5be7f629cff94bd67ba7d95c800763a9026708f2 Mon Sep 17 00:00:00 2001 -From: Andy Green <andy@openmoko.com> -Date: Wed, 6 Aug 2008 12:16:38 +0100 -Subject: [PATCH] fix-hdq-probe.patch - -Signed-off-by: Andy Green <andy@openmoko.com> ---- - arch/arm/mach-s3c2440/mach-gta02.c | 9 ++++----- - drivers/power/gta02_hdq.c | 22 ++++++++++++++++------ - 2 files changed, 20 insertions(+), 11 deletions(-) - -diff --git a/arch/arm/mach-s3c2440/mach-gta02.c b/arch/arm/mach-s3c2440/mach-gta02.c -index be2d901..aeedd42 100644 ---- a/arch/arm/mach-s3c2440/mach-gta02.c -+++ b/arch/arm/mach-s3c2440/mach-gta02.c -@@ -38,6 +38,7 @@ - #include <linux/spi/glamo.h> - #include <linux/spi/spi_bitbang.h> - #include <linux/mmc/host.h> -+#include <linux/version.h> - - #include <linux/mtd/mtd.h> - #include <linux/mtd/nand.h> -@@ -111,8 +112,7 @@ static int gta02_charger_active_status; - */ - struct fiq_ipc fiq_ipc; - EXPORT_SYMBOL(fiq_ipc); -- --#define DIVISOR_FROM_US(x) ((x) << 1) -+#define DIVISOR_FROM_US(x) ((x) << 3) - - #define FIQ_DIVISOR_VIBRATOR DIVISOR_FROM_US(100) - -@@ -184,9 +184,9 @@ FIQ_HANDLER_ENTRY(256, 512) - if (hdq_shifter & 1) - hdq_ctr = 50 / HDQ_SAMPLE_PERIOD_US; - else -- hdq_ctr = 120 / HDQ_SAMPLE_PERIOD_US; -+ hdq_ctr = 140 / HDQ_SAMPLE_PERIOD_US; - /* carefully precompute the other phase length */ -- hdq_ctr2 = (210 - (hdq_ctr * HDQ_SAMPLE_PERIOD_US)) / -+ hdq_ctr2 = (220 - (hdq_ctr * HDQ_SAMPLE_PERIOD_US)) / - HDQ_SAMPLE_PERIOD_US; - hdq_state = HDQB_ADS_LOW; - hdq_shifter >>= 1; -@@ -782,7 +782,6 @@ struct platform_device gta02_hdq_device = { - }; - #endif - -- - /* NOR Flash */ - - #define GTA02_FLASH_BASE 0x18000000 /* GCS3 */ -diff --git a/drivers/power/gta02_hdq.c b/drivers/power/gta02_hdq.c -index 5a79fd6..6c228b4 100644 ---- a/drivers/power/gta02_hdq.c -+++ b/drivers/power/gta02_hdq.c -@@ -40,7 +40,7 @@ int gta02hdq_read(int address) - mutex_lock(&fiq_ipc.hdq_lock); - - fiq_ipc.hdq_ads = address | HDQ_READ; -- fiq_ipc.hdq_request_ctr++; -+ fiq_ipc.hdq_request_ctr = fiq_ipc.hdq_transaction_ctr + 1; - fiq_kick(); - /* - * FIQ takes care of it while we block our calling process -@@ -53,9 +53,13 @@ int gta02hdq_read(int address) - if (fiq_ipc.hdq_request_ctr != fiq_ipc.hdq_transaction_ctr) - continue; - -- if (fiq_ipc.hdq_error) -+ if (fiq_ipc.hdq_error) { -+ printk(KERN_ERR "hdq timeout %d, %d / %d\n", -+ fiq_ipc.hdq_error, fiq_ipc.hdq_request_ctr, -+ fiq_ipc.hdq_transaction_ctr); - goto done; /* didn't see a response in good time */ -- -+ } -+ - ret = fiq_ipc.hdq_rx_data; - goto done; - } -@@ -193,12 +197,18 @@ static int __init gta02hdq_probe(struct platform_device *pdev) - { - struct resource *r = platform_get_resource(pdev, 0, 0); - -- if (!machine_is_neo1973_gta02()) -+ printk(KERN_ERR "gta02hdq driver starting\n"); -+ -+ if (!machine_is_neo1973_gta02()) { -+ printk(KERN_ERR "gta02hdq_probe only for GTA02\n"); - return -EIO; -+ } - -- if (!r) -+ if (!r) { -+ printk(KERN_ERR "gta02hdq_probe missing resource for GPIO\n"); - return -EINVAL; -- -+ } -+ - platform_set_drvdata(pdev, NULL); - - mutex_init(&fiq_ipc.hdq_lock); --- -1.5.6.3 - |