Commit 2b6a6e67 authored by Hartmut Knaack's avatar Hartmut Knaack Committed by Jonathan Cameron

tools:iio: save errno first

The man-page of errno states, that errno should be saved before doing any
library call, as that call may have changed the value of errno. So, when
encountering any error, save errno first.
This patch affects generic_buffer.c, iio_event_monitor.c and iio_utils.c.
Signed-off-by: default avatarHartmut Knaack <knaack.h@gmx.de>
Signed-off-by: default avatarJonathan Cameron <jic23@kernel.org>
parent f96d055e
...@@ -296,8 +296,8 @@ int main(int argc, char **argv) ...@@ -296,8 +296,8 @@ int main(int argc, char **argv)
/* Attempt to open non blocking the access dev */ /* Attempt to open non blocking the access dev */
fp = open(buffer_access, O_RDONLY | O_NONBLOCK); fp = open(buffer_access, O_RDONLY | O_NONBLOCK);
if (fp == -1) { /* If it isn't there make the node */ if (fp == -1) { /* If it isn't there make the node */
printf("Failed to open %s\n", buffer_access);
ret = -errno; ret = -errno;
printf("Failed to open %s\n", buffer_access);
goto error_free_buffer_access; goto error_free_buffer_access;
} }
......
...@@ -269,8 +269,8 @@ int main(int argc, char **argv) ...@@ -269,8 +269,8 @@ int main(int argc, char **argv)
fd = open(chrdev_name, 0); fd = open(chrdev_name, 0);
if (fd == -1) { if (fd == -1) {
fprintf(stdout, "Failed to open %s\n", chrdev_name);
ret = -errno; ret = -errno;
fprintf(stdout, "Failed to open %s\n", chrdev_name);
goto error_free_chrdev_name; goto error_free_chrdev_name;
} }
...@@ -279,8 +279,8 @@ int main(int argc, char **argv) ...@@ -279,8 +279,8 @@ int main(int argc, char **argv)
close(fd); close(fd);
if (ret == -1 || event_fd == -1) { if (ret == -1 || event_fd == -1) {
fprintf(stdout, "Failed to retrieve event fd\n");
ret = -errno; ret = -errno;
fprintf(stdout, "Failed to retrieve event fd\n");
goto error_free_chrdev_name; goto error_free_chrdev_name;
} }
...@@ -291,8 +291,8 @@ int main(int argc, char **argv) ...@@ -291,8 +291,8 @@ int main(int argc, char **argv)
printf("nothing available\n"); printf("nothing available\n");
continue; continue;
} else { } else {
perror("Failed to read event from device");
ret = -errno; ret = -errno;
perror("Failed to read event from device");
break; break;
} }
} }
......
...@@ -129,8 +129,8 @@ int iioutils_get_type(unsigned *is_signed, ...@@ -129,8 +129,8 @@ int iioutils_get_type(unsigned *is_signed,
} }
sysfsfp = fopen(filename, "r"); sysfsfp = fopen(filename, "r");
if (sysfsfp == NULL) { if (sysfsfp == NULL) {
printf("failed to open %s\n", filename);
ret = -errno; ret = -errno;
printf("failed to open %s\n", filename);
goto error_free_filename; goto error_free_filename;
} }
...@@ -141,8 +141,8 @@ int iioutils_get_type(unsigned *is_signed, ...@@ -141,8 +141,8 @@ int iioutils_get_type(unsigned *is_signed,
bits_used, bits_used,
&padint, shift); &padint, shift);
if (ret < 0) { if (ret < 0) {
printf("failed to pass scan type description\n");
ret = -errno; ret = -errno;
printf("failed to pass scan type description\n");
goto error_close_sysfsfp; goto error_close_sysfsfp;
} }
*be = (endianchar == 'b'); *be = (endianchar == 'b');
...@@ -332,8 +332,8 @@ int build_channel_array(const char *device_dir, ...@@ -332,8 +332,8 @@ int build_channel_array(const char *device_dir,
} }
sysfsfp = fopen(filename, "r"); sysfsfp = fopen(filename, "r");
if (sysfsfp == NULL) { if (sysfsfp == NULL) {
free(filename);
ret = -errno; ret = -errno;
free(filename);
count--; count--;
goto error_cleanup_array; goto error_cleanup_array;
} }
...@@ -505,8 +505,8 @@ int _write_sysfs_int(char *filename, char *basedir, int val, int verify) ...@@ -505,8 +505,8 @@ int _write_sysfs_int(char *filename, char *basedir, int val, int verify)
sprintf(temp, "%s/%s", basedir, filename); sprintf(temp, "%s/%s", basedir, filename);
sysfsfp = fopen(temp, "w"); sysfsfp = fopen(temp, "w");
if (sysfsfp == NULL) { if (sysfsfp == NULL) {
printf("failed to open %s\n", temp);
ret = -errno; ret = -errno;
printf("failed to open %s\n", temp);
goto error_free; goto error_free;
} }
fprintf(sysfsfp, "%d", val); fprintf(sysfsfp, "%d", val);
...@@ -514,8 +514,8 @@ int _write_sysfs_int(char *filename, char *basedir, int val, int verify) ...@@ -514,8 +514,8 @@ int _write_sysfs_int(char *filename, char *basedir, int val, int verify)
if (verify) { if (verify) {
sysfsfp = fopen(temp, "r"); sysfsfp = fopen(temp, "r");
if (sysfsfp == NULL) { if (sysfsfp == NULL) {
printf("failed to open %s\n", temp);
ret = -errno; ret = -errno;
printf("failed to open %s\n", temp);
goto error_free; goto error_free;
} }
fscanf(sysfsfp, "%d", &test); fscanf(sysfsfp, "%d", &test);
...@@ -556,8 +556,8 @@ int _write_sysfs_string(char *filename, char *basedir, char *val, int verify) ...@@ -556,8 +556,8 @@ int _write_sysfs_string(char *filename, char *basedir, char *val, int verify)
sprintf(temp, "%s/%s", basedir, filename); sprintf(temp, "%s/%s", basedir, filename);
sysfsfp = fopen(temp, "w"); sysfsfp = fopen(temp, "w");
if (sysfsfp == NULL) { if (sysfsfp == NULL) {
printf("Could not open %s\n", temp);
ret = -errno; ret = -errno;
printf("Could not open %s\n", temp);
goto error_free; goto error_free;
} }
fprintf(sysfsfp, "%s", val); fprintf(sysfsfp, "%s", val);
...@@ -565,8 +565,8 @@ int _write_sysfs_string(char *filename, char *basedir, char *val, int verify) ...@@ -565,8 +565,8 @@ int _write_sysfs_string(char *filename, char *basedir, char *val, int verify)
if (verify) { if (verify) {
sysfsfp = fopen(temp, "r"); sysfsfp = fopen(temp, "r");
if (sysfsfp == NULL) { if (sysfsfp == NULL) {
printf("could not open file to verify\n");
ret = -errno; ret = -errno;
printf("could not open file to verify\n");
goto error_free; goto error_free;
} }
fscanf(sysfsfp, "%s", temp); fscanf(sysfsfp, "%s", temp);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment