aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorArnd Bergmann <arnd@arndb.de>2012-04-22 16:54:46 -0400
committerArnd Bergmann <arnd@arndb.de>2012-04-22 16:54:46 -0400
commit3f81b2c49d31e763a9c1da831ceb6cef087cf6c6 (patch)
treee261299ccded5d87db92850b8dfdadab8ae2c514 /drivers
parente816b57a337ea3b755de72bec38c10c864f23015 (diff)
parent6b866c151ad9ea44799b32c3a8c90a03c5b981da (diff)
Merge branch 'stmp_device' of git://git.pengutronix.de/git/wsa/linux into next/stmp-dev
Wolfram Sang <w.sang@pengutronix.de> writes: This series makes support for a certain type of devices mach independant. We want that because such devices (having a special register layout) have been found in mach-mxs and mach-mx6 meanwhile. Since there is no subsystem maintainer for lib/ and the use case is currently only for ARM systems, I have agreed to merge these through the arm-soc tree. * 'stmp_device' of git://git.pengutronix.de/git/wsa/linux: i2c: mxs: use global reset function lib: add support for stmp-style devices Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/i2c/busses/Kconfig1
-rw-r--r--drivers/i2c/busses/i2c-mxs.c9
2 files changed, 3 insertions, 7 deletions
diff --git a/drivers/i2c/busses/Kconfig b/drivers/i2c/busses/Kconfig
index d2c5095deea..ccfd37db3df 100644
--- a/drivers/i2c/busses/Kconfig
+++ b/drivers/i2c/busses/Kconfig
@@ -483,6 +483,7 @@ config I2C_MV64XXX
483config I2C_MXS 483config I2C_MXS
484 tristate "Freescale i.MX28 I2C interface" 484 tristate "Freescale i.MX28 I2C interface"
485 depends on SOC_IMX28 485 depends on SOC_IMX28
486 select STMP_DEVICE
486 help 487 help
487 Say Y here if you want to use the I2C bus controller on 488 Say Y here if you want to use the I2C bus controller on
488 the Freescale i.MX28 processors. 489 the Freescale i.MX28 processors.
diff --git a/drivers/i2c/busses/i2c-mxs.c b/drivers/i2c/busses/i2c-mxs.c
index 3d471d56bf1..08348024194 100644
--- a/drivers/i2c/busses/i2c-mxs.c
+++ b/drivers/i2c/busses/i2c-mxs.c
@@ -26,8 +26,7 @@
26#include <linux/platform_device.h> 26#include <linux/platform_device.h>
27#include <linux/jiffies.h> 27#include <linux/jiffies.h>
28#include <linux/io.h> 28#include <linux/io.h>
29 29#include <linux/stmp_device.h>
30#include <mach/common.h>
31 30
32#define DRIVER_NAME "mxs-i2c" 31#define DRIVER_NAME "mxs-i2c"
33 32
@@ -111,13 +110,9 @@ struct mxs_i2c_dev {
111 struct i2c_adapter adapter; 110 struct i2c_adapter adapter;
112}; 111};
113 112
114/*
115 * TODO: check if calls to here are really needed. If not, we could get rid of
116 * mxs_reset_block and the mach-dependency. Needs an I2C analyzer, probably.
117 */
118static void mxs_i2c_reset(struct mxs_i2c_dev *i2c) 113static void mxs_i2c_reset(struct mxs_i2c_dev *i2c)
119{ 114{
120 mxs_reset_block(i2c->regs); 115 stmp_reset_block(i2c->regs);
121 writel(MXS_I2C_IRQ_MASK << 8, i2c->regs + MXS_I2C_CTRL1_SET); 116 writel(MXS_I2C_IRQ_MASK << 8, i2c->regs + MXS_I2C_CTRL1_SET);
122 writel(MXS_I2C_QUEUECTRL_PIO_QUEUE_MODE, 117 writel(MXS_I2C_QUEUECTRL_PIO_QUEUE_MODE,
123 i2c->regs + MXS_I2C_QUEUECTRL_SET); 118 i2c->regs + MXS_I2C_QUEUECTRL_SET);