aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/s3c24xx/patches-2.6.24/1275-lis302dl-allow-unloading-module.patch.patch
diff options
context:
space:
mode:
Diffstat (limited to 'target/linux/s3c24xx/patches-2.6.24/1275-lis302dl-allow-unloading-module.patch.patch')
-rw-r--r--target/linux/s3c24xx/patches-2.6.24/1275-lis302dl-allow-unloading-module.patch.patch38
1 files changed, 38 insertions, 0 deletions
diff --git a/target/linux/s3c24xx/patches-2.6.24/1275-lis302dl-allow-unloading-module.patch.patch b/target/linux/s3c24xx/patches-2.6.24/1275-lis302dl-allow-unloading-module.patch.patch
new file mode 100644
index 0000000000..fb7d233976
--- /dev/null
+++ b/target/linux/s3c24xx/patches-2.6.24/1275-lis302dl-allow-unloading-module.patch.patch
@@ -0,0 +1,38 @@
+From 399efd68e115b6548fe943a7a9fbf04753970e61 Mon Sep 17 00:00:00 2001
+From: Simon Kagstrom <simon.kagstrom@gmail.com>
+Date: Wed, 13 Aug 2008 11:27:11 +0100
+Subject: [PATCH] lis302dl-allow-unloading-module.patch
+
+This patch fixes module unloading for the accelerometer (actually module
+loading failed before). The two problems were that the interrupt was not
+unregistered, and that the device was left in a "strange" state.
+
+Signed-off-by: Simon Kagstrom <simon.kagstrom@gmail.com>
+---
+ drivers/input/misc/lis302dl.c | 6 +++++-
+ 1 files changed, 5 insertions(+), 1 deletions(-)
+
+diff --git a/drivers/input/misc/lis302dl.c b/drivers/input/misc/lis302dl.c
+index de8478d..b97cae7 100644
+--- a/drivers/input/misc/lis302dl.c
++++ b/drivers/input/misc/lis302dl.c
+@@ -462,11 +462,15 @@ static int __devexit lis302dl_remove(struct spi_device *spi)
+ struct lis302dl_info *lis = dev_get_drvdata(&spi->dev);
+ unsigned long flags;
+
+- /* power down the device */
++ /* Reset and power down the device */
+ local_save_flags(flags);
++ reg_write(lis, LIS302DL_REG_CTRL3, 0x00);
++ reg_write(lis, LIS302DL_REG_CTRL2, 0x00);
+ reg_write(lis, LIS302DL_REG_CTRL1, 0x00);
+ local_irq_restore(flags);
+
++ /* Cleanup resources */
++ free_irq(lis->spi_dev->irq, lis);
+ sysfs_remove_group(&spi->dev.kobj, &lis302dl_attr_group);
+ input_unregister_device(lis->input_dev);
+ if (lis->input_dev)
+--
+1.5.6.5
+