ref: d5866987ff5c457ba732f2b52803000c213c26eb
parent: 17d2394c43b6bef5b767a6f3e7f53398070c02ae
author: James Zern <[email protected]>
date: Sat Mar 15 08:35:44 EDT 2014
y4minput: add more error reporting on read failure Change-Id: Iedb136e4019ec3eb3005ea567efb33902dccfb8d
--- a/y4minput.c
+++ b/y4minput.c
@@ -22,13 +22,14 @@
static int file_read(void *buf, size_t size, FILE *file) {
const int kMaxRetries = 5;
int retry_count = 0;
+ int file_error;
size_t len = 0;
do {
const size_t n = fread((uint8_t*)buf + len, 1, size - len, file);
len += n;
- if (ferror(file)) {
+ file_error = ferror(file);
+ if (file_error) {
if (errno == EINTR || errno == EAGAIN) {
- ++retry_count;
clearerr(file);
continue;
} else {
@@ -37,7 +38,14 @@
return 0;
}
}
- } while (!feof(file) && len < size && retry_count < kMaxRetries);
+ } while (!feof(file) && len < size && ++retry_count < kMaxRetries);
+
+ if (!feof(file) && len != size) {
+ fprintf(stderr, "Error reading file: %u of %u bytes read,"
+ " error: %d, retries: %d, %d: %s\n",
+ (uint32_t)len, (uint32_t)size, file_error, retry_count,
+ errno, strerror(errno));
+ }
return len == size;
}