X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=src%2Fhugepages.c;h=ac9441d092ecc9227e977f9971a3c0d323c614c3;hb=915fb28ee1a2fb80f1f0b73f2869bcf981c932c2;hp=120dd798c0d507db3534a510b104f4850b93e7d9;hpb=c4413ca9cec4a16b12c2dbdfde5b821a35de5e0e;p=collectd.git diff --git a/src/hugepages.c b/src/hugepages.c index 120dd798..ac9441d0 100644 --- a/src/hugepages.c +++ b/src/hugepages.c @@ -187,6 +187,7 @@ static int read_syshugepages(const char* path, const char* node) while ((result = readdir(dir)) != NULL) { if (strncmp(result->d_name, hugepages_dir, sizeof(hugepages_dir)-1)) { /* not node dir */ + errno = 0; continue; } @@ -196,10 +197,17 @@ static int read_syshugepages(const char* path, const char* node) e_info.d_name = result->d_name; e_info.node = node; walk_directory(path2, read_hugepage_entry, &e_info, 0); + errno = 0; } - closedir(dir); + /* Check if NULL return from readdir() was an error */ + if (errno != 0) { + ERROR("%s: readdir failed", g_plugin_name); + closedir(dir); + return -1; + } + closedir(dir); return 0; } @@ -234,15 +242,23 @@ static int read_nodes(void) while ((result = readdir(dir)) != NULL) { if (strncmp(result->d_name, node_string, sizeof(node_string)-1)) { /* not node dir */ + errno = 0; continue; } ssnprintf(path, (size_t) lim, sys_node_hugepages, result->d_name); read_syshugepages(path, result->d_name); + errno = 0; } - closedir(dir); + /* Check if NULL return from readdir() was an error */ + if (errno != 0) { + ERROR("%s: readdir failed", g_plugin_name); + closedir(dir); + return -1; + } + closedir(dir); return 0; }