diff options
-rw-r--r-- | drivers/i2c/i2c-core.c | 133 |
1 files changed, 124 insertions, 9 deletions
diff --git a/drivers/i2c/i2c-core.c b/drivers/i2c/i2c-core.c index 3695a4a1ab77..527d51319f3c 100644 --- a/drivers/i2c/i2c-core.c +++ b/drivers/i2c/i2c-core.c | |||
@@ -945,10 +945,39 @@ module_exit(i2c_exit); | |||
945 | * ---------------------------------------------------- | 945 | * ---------------------------------------------------- |
946 | */ | 946 | */ |
947 | 947 | ||
948 | /** | ||
949 | * i2c_transfer - execute a single or combined I2C message | ||
950 | * @adap: Handle to I2C bus | ||
951 | * @msgs: One or more messages to execute before STOP is issued to | ||
952 | * terminate the operation; each message begins with a START. | ||
953 | * @num: Number of messages to be executed. | ||
954 | * | ||
955 | * Returns negative errno, else the number of messages executed. | ||
956 | * | ||
957 | * Note that there is no requirement that each message be sent to | ||
958 | * the same slave address, although that is the most common model. | ||
959 | */ | ||
948 | int i2c_transfer(struct i2c_adapter * adap, struct i2c_msg *msgs, int num) | 960 | int i2c_transfer(struct i2c_adapter * adap, struct i2c_msg *msgs, int num) |
949 | { | 961 | { |
950 | int ret; | 962 | int ret; |
951 | 963 | ||
964 | /* REVISIT the fault reporting model here is weak: | ||
965 | * | ||
966 | * - When we get an error after receiving N bytes from a slave, | ||
967 | * there is no way to report "N". | ||
968 | * | ||
969 | * - When we get a NAK after transmitting N bytes to a slave, | ||
970 | * there is no way to report "N" ... or to let the master | ||
971 | * continue executing the rest of this combined message, if | ||
972 | * that's the appropriate response. | ||
973 | * | ||
974 | * - When for example "num" is two and we successfully complete | ||
975 | * the first message but get an error part way through the | ||
976 | * second, it's unclear whether that should be reported as | ||
977 | * one (discarding status on the second message) or errno | ||
978 | * (discarding status on the first one). | ||
979 | */ | ||
980 | |||
952 | if (adap->algo->master_xfer) { | 981 | if (adap->algo->master_xfer) { |
953 | #ifdef DEBUG | 982 | #ifdef DEBUG |
954 | for (ret = 0; ret < num; ret++) { | 983 | for (ret = 0; ret < num; ret++) { |
@@ -979,6 +1008,14 @@ int i2c_transfer(struct i2c_adapter * adap, struct i2c_msg *msgs, int num) | |||
979 | } | 1008 | } |
980 | EXPORT_SYMBOL(i2c_transfer); | 1009 | EXPORT_SYMBOL(i2c_transfer); |
981 | 1010 | ||
1011 | /** | ||
1012 | * i2c_master_send - issue a single I2C message in master transmit mode | ||
1013 | * @client: Handle to slave device | ||
1014 | * @buf: Data that will be written to the slave | ||
1015 | * @count: How many bytes to write | ||
1016 | * | ||
1017 | * Returns negative errno, or else the number of bytes written. | ||
1018 | */ | ||
982 | int i2c_master_send(struct i2c_client *client,const char *buf ,int count) | 1019 | int i2c_master_send(struct i2c_client *client,const char *buf ,int count) |
983 | { | 1020 | { |
984 | int ret; | 1021 | int ret; |
@@ -998,6 +1035,14 @@ int i2c_master_send(struct i2c_client *client,const char *buf ,int count) | |||
998 | } | 1035 | } |
999 | EXPORT_SYMBOL(i2c_master_send); | 1036 | EXPORT_SYMBOL(i2c_master_send); |
1000 | 1037 | ||
1038 | /** | ||
1039 | * i2c_master_recv - issue a single I2C message in master receive mode | ||
1040 | * @client: Handle to slave device | ||
1041 | * @buf: Where to store data read from slave | ||
1042 | * @count: How many bytes to read | ||
1043 | * | ||
1044 | * Returns negative errno, or else the number of bytes read. | ||
1045 | */ | ||
1001 | int i2c_master_recv(struct i2c_client *client, char *buf ,int count) | 1046 | int i2c_master_recv(struct i2c_client *client, char *buf ,int count) |
1002 | { | 1047 | { |
1003 | struct i2c_adapter *adap=client->adapter; | 1048 | struct i2c_adapter *adap=client->adapter; |
@@ -1303,6 +1348,13 @@ static int i2c_smbus_check_pec(u8 cpec, struct i2c_msg *msg) | |||
1303 | return 0; | 1348 | return 0; |
1304 | } | 1349 | } |
1305 | 1350 | ||
1351 | /** | ||
1352 | * i2c_smbus_read_byte - SMBus "receive byte" protocol | ||
1353 | * @client: Handle to slave device | ||
1354 | * | ||
1355 | * This executes the SMBus "receive byte" protocol, returning negative errno | ||
1356 | * else the byte received from the device. | ||
1357 | */ | ||
1306 | s32 i2c_smbus_read_byte(struct i2c_client *client) | 1358 | s32 i2c_smbus_read_byte(struct i2c_client *client) |
1307 | { | 1359 | { |
1308 | union i2c_smbus_data data; | 1360 | union i2c_smbus_data data; |
@@ -1315,6 +1367,14 @@ s32 i2c_smbus_read_byte(struct i2c_client *client) | |||
1315 | } | 1367 | } |
1316 | EXPORT_SYMBOL(i2c_smbus_read_byte); | 1368 | EXPORT_SYMBOL(i2c_smbus_read_byte); |
1317 | 1369 | ||
1370 | /** | ||
1371 | * i2c_smbus_write_byte - SMBus "send byte" protocol | ||
1372 | * @client: Handle to slave device | ||
1373 | * @value: Byte to be sent | ||
1374 | * | ||
1375 | * This executes the SMBus "send byte" protocol, returning negative errno | ||
1376 | * else zero on success. | ||
1377 | */ | ||
1318 | s32 i2c_smbus_write_byte(struct i2c_client *client, u8 value) | 1378 | s32 i2c_smbus_write_byte(struct i2c_client *client, u8 value) |
1319 | { | 1379 | { |
1320 | return i2c_smbus_xfer(client->adapter,client->addr,client->flags, | 1380 | return i2c_smbus_xfer(client->adapter,client->addr,client->flags, |
@@ -1322,6 +1382,14 @@ s32 i2c_smbus_write_byte(struct i2c_client *client, u8 value) | |||
1322 | } | 1382 | } |
1323 | EXPORT_SYMBOL(i2c_smbus_write_byte); | 1383 | EXPORT_SYMBOL(i2c_smbus_write_byte); |
1324 | 1384 | ||
1385 | /** | ||
1386 | * i2c_smbus_read_byte_data - SMBus "read byte" protocol | ||
1387 | * @client: Handle to slave device | ||
1388 | * @command: Byte interpreted by slave | ||
1389 | * | ||
1390 | * This executes the SMBus "read byte" protocol, returning negative errno | ||
1391 | * else a data byte received from the device. | ||
1392 | */ | ||
1325 | s32 i2c_smbus_read_byte_data(struct i2c_client *client, u8 command) | 1393 | s32 i2c_smbus_read_byte_data(struct i2c_client *client, u8 command) |
1326 | { | 1394 | { |
1327 | union i2c_smbus_data data; | 1395 | union i2c_smbus_data data; |
@@ -1334,6 +1402,15 @@ s32 i2c_smbus_read_byte_data(struct i2c_client *client, u8 command) | |||
1334 | } | 1402 | } |
1335 | EXPORT_SYMBOL(i2c_smbus_read_byte_data); | 1403 | EXPORT_SYMBOL(i2c_smbus_read_byte_data); |
1336 | 1404 | ||
1405 | /** | ||
1406 | * i2c_smbus_write_byte_data - SMBus "write byte" protocol | ||
1407 | * @client: Handle to slave device | ||
1408 | * @command: Byte interpreted by slave | ||
1409 | * @value: Byte being written | ||
1410 | * | ||
1411 | * This executes the SMBus "write byte" protocol, returning negative errno | ||
1412 | * else zero on success. | ||
1413 | */ | ||
1337 | s32 i2c_smbus_write_byte_data(struct i2c_client *client, u8 command, u8 value) | 1414 | s32 i2c_smbus_write_byte_data(struct i2c_client *client, u8 command, u8 value) |
1338 | { | 1415 | { |
1339 | union i2c_smbus_data data; | 1416 | union i2c_smbus_data data; |
@@ -1344,6 +1421,14 @@ s32 i2c_smbus_write_byte_data(struct i2c_client *client, u8 command, u8 value) | |||
1344 | } | 1421 | } |
1345 | EXPORT_SYMBOL(i2c_smbus_write_byte_data); | 1422 | EXPORT_SYMBOL(i2c_smbus_write_byte_data); |
1346 | 1423 | ||
1424 | /** | ||
1425 | * i2c_smbus_read_word_data - SMBus "read word" protocol | ||
1426 | * @client: Handle to slave device | ||
1427 | * @command: Byte interpreted by slave | ||
1428 | * | ||
1429 | * This executes the SMBus "read word" protocol, returning negative errno | ||
1430 | * else a 16-bit unsigned "word" received from the device. | ||
1431 | */ | ||
1347 | s32 i2c_smbus_read_word_data(struct i2c_client *client, u8 command) | 1432 | s32 i2c_smbus_read_word_data(struct i2c_client *client, u8 command) |
1348 | { | 1433 | { |
1349 | union i2c_smbus_data data; | 1434 | union i2c_smbus_data data; |
@@ -1356,6 +1441,15 @@ s32 i2c_smbus_read_word_data(struct i2c_client *client, u8 command) | |||
1356 | } | 1441 | } |
1357 | EXPORT_SYMBOL(i2c_smbus_read_word_data); | 1442 | EXPORT_SYMBOL(i2c_smbus_read_word_data); |
1358 | 1443 | ||
1444 | /** | ||
1445 | * i2c_smbus_write_word_data - SMBus "write word" protocol | ||
1446 | * @client: Handle to slave device | ||
1447 | * @command: Byte interpreted by slave | ||
1448 | * @value: 16-bit "word" being written | ||
1449 | * | ||
1450 | * This executes the SMBus "write word" protocol, returning negative errno | ||
1451 | * else zero on success. | ||
1452 | */ | ||
1359 | s32 i2c_smbus_write_word_data(struct i2c_client *client, u8 command, u16 value) | 1453 | s32 i2c_smbus_write_word_data(struct i2c_client *client, u8 command, u16 value) |
1360 | { | 1454 | { |
1361 | union i2c_smbus_data data; | 1455 | union i2c_smbus_data data; |
@@ -1367,15 +1461,14 @@ s32 i2c_smbus_write_word_data(struct i2c_client *client, u8 command, u16 value) | |||
1367 | EXPORT_SYMBOL(i2c_smbus_write_word_data); | 1461 | EXPORT_SYMBOL(i2c_smbus_write_word_data); |
1368 | 1462 | ||
1369 | /** | 1463 | /** |
1370 | * i2c_smbus_read_block_data - SMBus block read request | 1464 | * i2c_smbus_read_block_data - SMBus "block read" protocol |
1371 | * @client: Handle to slave device | 1465 | * @client: Handle to slave device |
1372 | * @command: Command byte issued to let the slave know what data should | 1466 | * @command: Byte interpreted by slave |
1373 | * be returned | ||
1374 | * @values: Byte array into which data will be read; big enough to hold | 1467 | * @values: Byte array into which data will be read; big enough to hold |
1375 | * the data returned by the slave. SMBus allows at most 32 bytes. | 1468 | * the data returned by the slave. SMBus allows at most 32 bytes. |
1376 | * | 1469 | * |
1377 | * Returns the number of bytes read in the slave's response, else a | 1470 | * This executes the SMBus "block read" protocol, returning negative errno |
1378 | * negative number to indicate some kind of error. | 1471 | * else the number of data bytes in the slave's response. |
1379 | * | 1472 | * |
1380 | * Note that using this function requires that the client's adapter support | 1473 | * Note that using this function requires that the client's adapter support |
1381 | * the I2C_FUNC_SMBUS_READ_BLOCK_DATA functionality. Not all adapter drivers | 1474 | * the I2C_FUNC_SMBUS_READ_BLOCK_DATA functionality. Not all adapter drivers |
@@ -1399,6 +1492,16 @@ s32 i2c_smbus_read_block_data(struct i2c_client *client, u8 command, | |||
1399 | } | 1492 | } |
1400 | EXPORT_SYMBOL(i2c_smbus_read_block_data); | 1493 | EXPORT_SYMBOL(i2c_smbus_read_block_data); |
1401 | 1494 | ||
1495 | /** | ||
1496 | * i2c_smbus_write_block_data - SMBus "block write" protocol | ||
1497 | * @client: Handle to slave device | ||
1498 | * @command: Byte interpreted by slave | ||
1499 | * @length: Size of data block; SMBus allows at most 32 bytes | ||
1500 | * @values: Byte array which will be written. | ||
1501 | * | ||
1502 | * This executes the SMBus "block write" protocol, returning negative errno | ||
1503 | * else zero on success. | ||
1504 | */ | ||
1402 | s32 i2c_smbus_write_block_data(struct i2c_client *client, u8 command, | 1505 | s32 i2c_smbus_write_block_data(struct i2c_client *client, u8 command, |
1403 | u8 length, const u8 *values) | 1506 | u8 length, const u8 *values) |
1404 | { | 1507 | { |
@@ -1615,9 +1718,21 @@ static s32 i2c_smbus_xfer_emulated(struct i2c_adapter * adapter, u16 addr, | |||
1615 | return 0; | 1718 | return 0; |
1616 | } | 1719 | } |
1617 | 1720 | ||
1618 | 1721 | /** | |
1722 | * i2c_smbus_xfer - execute SMBus protocol operations | ||
1723 | * @adapter: Handle to I2C bus | ||
1724 | * @addr: Address of SMBus slave on that bus | ||
1725 | * @flags: I2C_CLIENT_* flags (usually zero or I2C_CLIENT_PEC) | ||
1726 | * @read_write: I2C_SMBUS_READ or I2C_SMBUS_WRITE | ||
1727 | * @command: Byte interpreted by slave, for protocols which use such bytes | ||
1728 | * @protocol: SMBus protocol operation to execute, such as I2C_SMBUS_PROC_CALL | ||
1729 | * @data: Data to be read or written | ||
1730 | * | ||
1731 | * This executes an SMBus protocol operation, and returns a negative | ||
1732 | * errno code else zero on success. | ||
1733 | */ | ||
1619 | s32 i2c_smbus_xfer(struct i2c_adapter * adapter, u16 addr, unsigned short flags, | 1734 | s32 i2c_smbus_xfer(struct i2c_adapter * adapter, u16 addr, unsigned short flags, |
1620 | char read_write, u8 command, int size, | 1735 | char read_write, u8 command, int protocol, |
1621 | union i2c_smbus_data * data) | 1736 | union i2c_smbus_data * data) |
1622 | { | 1737 | { |
1623 | s32 res; | 1738 | s32 res; |
@@ -1627,11 +1742,11 @@ s32 i2c_smbus_xfer(struct i2c_adapter * adapter, u16 addr, unsigned short flags, | |||
1627 | if (adapter->algo->smbus_xfer) { | 1742 | if (adapter->algo->smbus_xfer) { |
1628 | mutex_lock(&adapter->bus_lock); | 1743 | mutex_lock(&adapter->bus_lock); |
1629 | res = adapter->algo->smbus_xfer(adapter,addr,flags,read_write, | 1744 | res = adapter->algo->smbus_xfer(adapter,addr,flags,read_write, |
1630 | command,size,data); | 1745 | command, protocol, data); |
1631 | mutex_unlock(&adapter->bus_lock); | 1746 | mutex_unlock(&adapter->bus_lock); |
1632 | } else | 1747 | } else |
1633 | res = i2c_smbus_xfer_emulated(adapter,addr,flags,read_write, | 1748 | res = i2c_smbus_xfer_emulated(adapter,addr,flags,read_write, |
1634 | command,size,data); | 1749 | command, protocol, data); |
1635 | 1750 | ||
1636 | return res; | 1751 | return res; |
1637 | } | 1752 | } |