diff options
author | Jonathan Cameron <jic23@cam.ac.uk> | 2011-10-30 08:47:25 -0400 |
---|---|---|
committer | Jean Delvare <khali@endymion.delvare> | 2011-10-30 08:47:25 -0400 |
commit | 06a67848c6681a73e621e47c056490d51a07289f (patch) | |
tree | df6e3df869b7b1a1f40f09b9b3a6f8b8a2ad12d6 | |
parent | 4403988afc0a92b8faf59b46f51d25fafaf0e63d (diff) |
i2c: Functions for byte-swapped smbus_write/read_word_data
Reimplemented at least 17 times discounting error mangling cases
where it could be used.
Signed-off-by: Jonathan Cameron <jic23@cam.ac.uk>
Signed-off-by: Jean Delvare <khali@linux-fr.org>
-rw-r--r-- | Documentation/i2c/smbus-protocol | 8 | ||||
-rw-r--r-- | include/linux/i2c.h | 17 |
2 files changed, 25 insertions, 0 deletions
diff --git a/Documentation/i2c/smbus-protocol b/Documentation/i2c/smbus-protocol index 7c19d1a2bea0..49f5b680809d 100644 --- a/Documentation/i2c/smbus-protocol +++ b/Documentation/i2c/smbus-protocol | |||
@@ -88,6 +88,10 @@ byte. But this time, the data is a complete word (16 bits). | |||
88 | 88 | ||
89 | S Addr Wr [A] Comm [A] S Addr Rd [A] [DataLow] A [DataHigh] NA P | 89 | S Addr Wr [A] Comm [A] S Addr Rd [A] [DataLow] A [DataHigh] NA P |
90 | 90 | ||
91 | Note the convenience function i2c_smbus_read_word_swapped is | ||
92 | available for reads where the two data bytes are the other way | ||
93 | around (not SMBus compliant, but very popular.) | ||
94 | |||
91 | 95 | ||
92 | SMBus Write Byte: i2c_smbus_write_byte_data() | 96 | SMBus Write Byte: i2c_smbus_write_byte_data() |
93 | ============================================== | 97 | ============================================== |
@@ -108,6 +112,10 @@ specified through the Comm byte. | |||
108 | 112 | ||
109 | S Addr Wr [A] Comm [A] DataLow [A] DataHigh [A] P | 113 | S Addr Wr [A] Comm [A] DataLow [A] DataHigh [A] P |
110 | 114 | ||
115 | Note the convenience function i2c_smbus_write_word_swapped is | ||
116 | available for writes where the two data bytes are the other way | ||
117 | around (not SMBus compliant, but very popular.) | ||
118 | |||
111 | 119 | ||
112 | SMBus Process Call: i2c_smbus_process_call() | 120 | SMBus Process Call: i2c_smbus_process_call() |
113 | ============================================= | 121 | ============================================= |
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 | ||
38 | extern struct bus_type i2c_bus_type; | 39 | extern struct bus_type i2c_bus_type; |
39 | extern struct device_type i2c_adapter_type; | 40 | extern 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); |
89 | extern s32 i2c_smbus_write_word_data(const struct i2c_client *client, | 90 | extern s32 i2c_smbus_write_word_data(const struct i2c_client *client, |
90 | u8 command, u16 value); | 91 | u8 command, u16 value); |
92 | |||
93 | static inline s32 | ||
94 | i2c_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 | |||
101 | static inline s32 | ||
102 | i2c_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 */ |
92 | extern s32 i2c_smbus_read_block_data(const struct i2c_client *client, | 109 | extern s32 i2c_smbus_read_block_data(const struct i2c_client *client, |
93 | u8 command, u8 *values); | 110 | u8 command, u8 *values); |