summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Friesel <derf@finalrewind.org>2015-12-24 15:47:33 +0100
committerDaniel Friesel <derf@finalrewind.org>2015-12-24 15:47:33 +0100
commit54380f5a63b5e5e220a77fb712309217be81170b (patch)
tree8b28d8cb8fb1431bec3310be6d9b4213da8030f5
parent6f2f93ed41668564878efbd9d2d9adb32d54ddd4 (diff)
i2cget, i2cset: more error handling
-rw-r--r--commandline/i2cget.c23
-rw-r--r--commandline/i2cset.c18
2 files changed, 28 insertions, 13 deletions
diff --git a/commandline/i2cget.c b/commandline/i2cget.c
index 041ffad..c7cd18f 100644
--- a/commandline/i2cget.c
+++ b/commandline/i2cget.c
@@ -6,7 +6,7 @@
int main(int argc, char **argv)
{
- int i, address, cmdbuf, got_ack;
+ int i, address, cmdbuf;
unsigned int ret;
char *conv_err;
@@ -22,23 +22,32 @@ int main(int argc, char **argv)
address = strtol(argv[1], &conv_err, 0);
if (conv_err && *conv_err) {
- fprintf(stderr, "address: Conversion error at '%s'", conv_err);
+ fprintf(stderr, "address: Conversion error at '%s'\n", conv_err);
return 2;
}
- i2c_tx_byte((address << 1) | 0);
+ if (!i2c_tx_byte((address << 1) | 0)) {
+ fprintf(stderr, "Received NAK from slave 0x%02x, aborting\n", address);
+ return 3;
+ }
for (i = 2; i < argc; i++) {
cmdbuf = strtol(argv[i], &conv_err, 0);
if (conv_err && *conv_err) {
- fprintf(stderr, "read command: Conversion error at '%s'", conv_err);
+ fprintf(stderr, "read command: Conversion error at '%s'\n", conv_err);
return 2;
}
- i2c_tx_byte(cmdbuf);
+ if (!i2c_tx_byte(cmdbuf)) {
+ fprintf(stderr, "Received NAK after byte %d (0x%02x)\n", i-1, cmdbuf);
+ return 4;
+ }
}
i2c_start();
- got_ack = i2c_tx_byte((address << 1) | 1);
+ if (!i2c_tx_byte((address << 1) | 1)) {
+ fprintf(stderr, "Received NAK after reSTART from slave 0x%02x, aborting\n", address);
+ return 3;
+ }
ret = i2c_rx_byte(0);
@@ -47,5 +56,5 @@ int main(int argc, char **argv)
printf("%i\n", ret);
- return got_ack ? 0 : 1;
+ return 0;
}
diff --git a/commandline/i2cset.c b/commandline/i2cset.c
index 3edaf81..5b2662c 100644
--- a/commandline/i2cset.c
+++ b/commandline/i2cset.c
@@ -6,7 +6,7 @@
int main(int argc, char **argv)
{
- int i, address, cmdbuf, got_ack;
+ int i, address, cmdbuf;
char *conv_err;
i2c_getopt(argc, argv);
@@ -21,23 +21,29 @@ int main(int argc, char **argv)
address = strtol(argv[1], &conv_err, 0);
if (conv_err && *conv_err) {
- fprintf(stderr, "Conversion error at '%s'", conv_err);
+ fprintf(stderr, "Conversion error at '%s'\n", conv_err);
return 2;
}
- got_ack = i2c_tx_byte(address << 1);
+ if (!i2c_tx_byte(address << 1)) {
+ fprintf(stderr, "Received NAK from slave 0x%02x, aborting\n", address);
+ return 3;
+ }
for (i = 2; i < argc; i++) {
cmdbuf = strtol(argv[i], &conv_err, 0);
if (conv_err && *conv_err) {
- fprintf(stderr, "write command: conversion error at '%s'", conv_err);
+ fprintf(stderr, "write command: conversion error at '%s'\n", conv_err);
return 2;
}
- i2c_tx_byte(cmdbuf);
+ if (!i2c_tx_byte(cmdbuf)) {
+ fprintf(stderr, "Received NAK after byte %d (0x%02x)\n", i-1, cmdbuf);
+ return 4;
+ }
}
i2c_stop();
i2c_deinit();
- return got_ack ? 0 : 1;
+ return 0;
}