[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <1308696897-25161-1-git-send-email-bfreed@chromium.org>
Date: Tue, 21 Jun 2011 15:54:55 -0700
From: Bryan Freed <bfreed@...omium.org>
To: linux-kernel@...r.kernel.org
Cc: jic23@....ac.uk, jbrenner@...sinc.com, gregkh@...e.de,
arnd@...db.de, Bryan Freed <bfreed@...omium.org>
Subject: [PATCH 1/3] light sensor: Add SMBUS support to the tsl2563 driver.
This is so we can support it on x86 SMBUS adapters.
Signed-off-by: Bryan Freed <bfreed@...omium.org>
---
drivers/staging/iio/light/tsl2563.c | 29 ++++++++++++++++++++++++++++-
1 files changed, 28 insertions(+), 1 deletions(-)
diff --git a/drivers/staging/iio/light/tsl2563.c b/drivers/staging/iio/light/tsl2563.c
index 9cffa2e..04aa155 100644
--- a/drivers/staging/iio/light/tsl2563.c
+++ b/drivers/staging/iio/light/tsl2563.c
@@ -137,6 +137,8 @@ struct tsl2563_chip {
u32 data1;
};
+static int use_smbus;
+
static int tsl2563_write(struct i2c_client *client, u8 reg, u8 value)
{
int ret;
@@ -145,15 +147,35 @@ static int tsl2563_write(struct i2c_client *client, u8 reg, u8 value)
buf[0] = TSL2563_CMD | reg;
buf[1] = value;
+ if (use_smbus) {
+ ret = i2c_smbus_write_byte_data(client, buf[0], value);
+ return ret;
+ }
+
ret = i2c_master_send(client, buf, sizeof(buf));
return (ret == sizeof(buf)) ? 0 : ret;
}
-static int tsl2563_read(struct i2c_client *client, u8 reg, void *buf, int len)
+static int tsl2563_read(struct i2c_client *client, u8 reg, u8 *buf, int len)
{
int ret;
u8 cmd = TSL2563_CMD | reg;
+ if (use_smbus) {
+ if (len == 1) {
+ ret = i2c_smbus_read_byte_data(client, cmd);
+ buf[0] = ret & 0xff;
+ } else if (len == 2) {
+ ret = i2c_smbus_read_word_data(client, cmd);
+ buf[0] = ret & 0xff;
+ buf[1] = (ret >> 8) & 0xff;
+ } else
+ ret = -1;
+ if (ret < 0)
+ return 0; /* failure */
+ return len; /* success */
+ }
+
ret = i2c_master_send(client, &cmd, sizeof(cmd));
if (ret != sizeof(cmd))
return ret;
@@ -712,6 +734,11 @@ static int __devinit tsl2563_probe(struct i2c_client *client,
int err = 0;
int ret;
u8 id;
+ u32 smbus_func = I2C_FUNC_SMBUS_BYTE_DATA | I2C_FUNC_SMBUS_WORD_DATA;
+
+ /* We support both I2C and SMBUS adapter interfaces. */
+ if (i2c_check_functionality(client->adapter, smbus_func))
+ use_smbus = 1;
indio_dev = iio_allocate_device(sizeof(*chip));
if (!indio_dev)
--
1.7.3.1
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists