From: bwzhou Date: Tue, 24 Jun 2008 16:27:58 +0000 (+0000) Subject: Branch b1_6 X-Git-Tag: GIT_EPOCH_B_RELEASE_1_6_7~2^3~542 X-Git-Url: https://git.whamcloud.com/?a=commitdiff_plain;h=0c3c5390c52b7f2087543fb4513257f95db0f133;p=fs%2Flustre-release.git Branch b1_6 b=13285 r=adilger, bobijam (cid-1579) johann, deen (cid-1613) johann, bobijam (cid-1685) Coverity bugs --- diff --git a/lustre/tests/openfile.c b/lustre/tests/openfile.c index 66aba74..0349134 100644 --- a/lustre/tests/openfile.c +++ b/lustre/tests/openfile.c @@ -63,9 +63,9 @@ int main(int argc, char** argv) char* fname=NULL; int mode_set=0; int flag_set=0; - int file_set=0; int c; int save_errno; + int print_usage=0; char* cloned_flags = NULL; if (argc == 1) @@ -79,7 +79,8 @@ int main(int argc, char** argv) cloned_flags = (char *)malloc(strlen(optarg)+1); if (cloned_flags == NULL) { fprintf(stderr, "Insufficient memory.\n"); - exit(-1); + save_errno = -1; + goto out; } strncpy(cloned_flags, optarg, strlen(optarg)+1); @@ -110,10 +111,10 @@ int main(int argc, char** argv) if (flag_table[i].flag == -1) { fprintf(stderr, "No such flag: %s\n", tmp); - exit(-1); + save_errno = -1; + goto out; } } - free(cloned_flags); #ifdef DEBUG printf("flags = %x\n", flags); #endif @@ -131,21 +132,23 @@ int main(int argc, char** argv) break; default: fprintf(stderr, "Bad parameters.\n"); - Usage_and_abort(); + print_usage = 1; + goto out; } } if (optind == argc) { fprintf(stderr, "Bad parameters.\n"); - Usage_and_abort(); + print_usage = 1; + goto out; } fname = argv[optind]; - file_set = 1; - if (!flag_set || !file_set) { + if (!flag_set) { fprintf(stderr, "Missing flag or file-name\n"); - exit(-1); + save_errno = -1; + goto out; } @@ -164,14 +167,21 @@ int main(int argc, char** argv) printf(", mode=%o", mode); printf(")\n"); close(fd); - return 0; + } else { + fprintf(stderr, "Error in opening file \"%s\"(flags=%s", + fname, cloned_flags); } - fprintf(stderr, "Error in opening file \"%s\"(flags=%s", - fname, cloned_flags); if (mode_set) fprintf(stderr, ", mode=%o", mode); fprintf(stderr, ") %d: %s\n", save_errno, strerror(save_errno)); +out: + if (cloned_flags) + free(cloned_flags); + if (print_usage) + Usage_and_abort(); + return save_errno; } + diff --git a/lustre/utils/lfs.c b/lustre/utils/lfs.c index aaba0b2..92eefaf 100644 --- a/lustre/utils/lfs.c +++ b/lustre/utils/lfs.c @@ -869,7 +869,7 @@ static int lfs_df(int argc, char **argv) FILE *fp; char *path = NULL; struct mntent *mnt = NULL; - char mntdir[PATH_MAX] = {'\0'}; + char *mntdir = NULL; int ishow = 0, cooked = 0; int c, rc = 0; @@ -896,10 +896,19 @@ static int lfs_df(int argc, char **argv) argv[0], MOUNTED, strerror(errno)); return rc; } + + if ((mntdir = malloc(PATH_MAX)) == NULL) { + fprintf(stderr, "error: cannot allocate %d bytes\n", + PATH_MAX); + return -ENOMEM; + } + memset(mntdir, 0, PATH_MAX); + if (path) { - rc = path2mnt(path, fp, mntdir, sizeof(mntdir)); + rc = path2mnt(path, fp, mntdir, PATH_MAX); if (rc) { endmntent(fp); + free(mntdir); return rc; } @@ -920,6 +929,7 @@ static int lfs_df(int argc, char **argv) endmntent(fp); } + free(mntdir); return rc; }