aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2011-10-30 18:54:59 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2011-10-30 18:54:59 -0400
commit839d8810747bbf39e0a5a7f223b67bffa7945f8d (patch)
treec16583342b871107f6805c21da4b1a96cfaa7aac /include/linux
parent0cfdc724390fb9370f27bb9a133eadf69114dd21 (diff)
parent06a67848c6681a73e621e47c056490d51a07289f (diff)
Merge branch 'i2c-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jdelvare/staging
* 'i2c-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jdelvare/staging: i2c: Functions for byte-swapped smbus_write/read_word_data i2c-algo-pca: Return standard fault codes i2c-algo-bit: Return standard fault codes i2c-algo-bit: Be verbose on bus testing failure i2c-algo-bit: Let user test buses without failing i2c/scx200_acb: Fix section mismatch warning in scx200_pci_drv i2c: I2C_ELEKTOR should depend on HAS_IOPORT
Diffstat (limited to 'include/linux')
-rw-r--r--include/linux/i2c.h17
1 files changed, 17 insertions, 0 deletions
diff --git a/include/linux/i2c.h b/include/linux/i2c.h
index a6c652ef516d..38a21c3edd2c 100644
--- a/include/linux/i2c.h
+++ b/include/linux/i2c.h
@@ -34,6 +34,7 @@
34#include <linux/sched.h> /* for completion */ 34#include <linux/sched.h> /* for completion */
35#include <linux/mutex.h> 35#include <linux/mutex.h>
36#include <linux/of.h> /* for struct device_node */ 36#include <linux/of.h> /* for struct device_node */
37#include <linux/swab.h> /* for swab16 */
37 38
38extern struct bus_type i2c_bus_type; 39extern struct bus_type i2c_bus_type;
39extern struct device_type i2c_adapter_type; 40extern struct device_type i2c_adapter_type;
@@ -88,6 +89,22 @@ extern s32 i2c_smbus_read_word_data(const struct i2c_client *client,
88 u8 command); 89 u8 command);
89extern s32 i2c_smbus_write_word_data(const struct i2c_client *client, 90extern s32 i2c_smbus_write_word_data(const struct i2c_client *client,
90 u8 command, u16 value); 91 u8 command, u16 value);
92
93static inline s32
94i2c_smbus_read_word_swapped(const struct i2c_client *client, u8 command)
95{
96 s32 value = i2c_smbus_read_word_data(client, command);
97
98 return (value < 0) ? value : swab16(value);
99}
100
101static inline s32
102i2c_smbus_write_word_swapped(const struct i2c_client *client,
103 u8 command, u16 value)
104{
105 return i2c_smbus_write_word_data(client, command, swab16(value));
106}
107
91/* Returns the number of read bytes */ 108/* Returns the number of read bytes */
92extern s32 i2c_smbus_read_block_data(const struct i2c_client *client, 109extern s32 i2c_smbus_read_block_data(const struct i2c_client *client,
93 u8 command, u8 *values); 110 u8 command, u8 *values);