1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-03 05:18:29 +03:00

Add some missing close() and fclose() return code checks.

Fix exit statuses of reporting tools (2.02.19).
This commit is contained in:
Alasdair Kergon 2007-01-25 14:37:48 +00:00
parent 232da7ecc7
commit 2e1b92e3ea
15 changed files with 70 additions and 39 deletions

View File

@ -1,5 +1,7 @@
Version 2.02.20 - Version 2.02.20 -
=================================== ===================================
Add some missing close() and fclose() return code checks.
Fix exit statuses of reporting tools (2.02.19).
Add init script for dmeventd monitoring. Add init script for dmeventd monitoring.
lvm.static no longer interacts with dmeventd unless explicitly asked to. lvm.static no longer interacts with dmeventd unless explicitly asked to.
Add field definitions to report help text. Add field definitions to report help text.

View File

@ -473,7 +473,8 @@ static void drop_vg_locks()
sync_unlock(vg, LCK_EXCL); sync_unlock(vg, LCK_EXCL);
} }
fclose(vgs); if (fclose(vgs))
DEBUGLOG("vgs fclose failed: %s\n", strerror(errno));
} }
/* /*
@ -523,7 +524,8 @@ static void *get_initial_state()
} }
} }
} }
fclose(lvs); if (fclose(lvs))
DEBUGLOG("lvs fclose failed: %s\n", strerror(errno));
return NULL; return NULL;
} }

View File

@ -59,8 +59,6 @@
# include <malloc.h> # include <malloc.h>
#endif #endif
static FILE *_log;
static int _get_env_vars(struct cmd_context *cmd) static int _get_env_vars(struct cmd_context *cmd)
{ {
const char *e; const char *e;
@ -1114,8 +1112,4 @@ void destroy_toolcontext(struct cmd_context *cmd)
activation_exit(); activation_exit();
fin_log(); fin_log();
fin_syslog(); fin_syslog();
if (_log)
fclose(_log);
} }

View File

@ -435,13 +435,13 @@ int write_config_file(struct config_tree *cft, const char *file,
log_verbose("Dumping configuration to %s", file); log_verbose("Dumping configuration to %s", file);
if (!argc) { if (!argc) {
if (!_write_config(cft->root, 0, fp, 0)) { if (!_write_config(cft->root, 0, fp, 0)) {
log_error("Failure while writing configuration"); log_error("Failure while writing to %s", file);
r = 0; r = 0;
} }
} else while (argc--) { } else while (argc--) {
if ((cn = find_config_node(cft->root, *argv))) { if ((cn = find_config_node(cft->root, *argv))) {
if (!_write_config(cn, 1, fp, 0)) { if (!_write_config(cn, 1, fp, 0)) {
log_error("Failure while writing configuration"); log_error("Failure while writing to %s", file);
r = 0; r = 0;
} }
} else { } else {
@ -451,8 +451,10 @@ int write_config_file(struct config_tree *cft, const char *file,
argv++; argv++;
} }
if (fp != stdout) if ((fp != stdout) && fclose(fp)) {
fclose(fp); log_sys_error("fclose", file);
r = 0;
}
return r; return r;
} }

View File

@ -292,11 +292,14 @@ int dev_get_sectsize(struct device *dev, uint32_t *size)
if (ioctl(fd, BLKSSZGET, &s) < 0) { if (ioctl(fd, BLKSSZGET, &s) < 0) {
log_sys_error("ioctl BLKSSZGET", name); log_sys_error("ioctl BLKSSZGET", name);
close(fd); if (close(fd))
log_sys_error("close", name);
return 0; return 0;
} }
close(fd); if (close(fd))
log_sys_error("close", name);
*size = (uint32_t) s; *size = (uint32_t) s;
log_very_verbose("%s: sector size is %" PRIu32 " bytes", name, *size); log_very_verbose("%s: sector size is %" PRIu32 " bytes", name, *size);

View File

@ -239,7 +239,10 @@ int persistent_filter_dump(struct dev_filter *f)
/* _write_array(pf, fp, "invalid_devices", PF_BAD_DEVICE); */ /* _write_array(pf, fp, "invalid_devices", PF_BAD_DEVICE); */
fprintf(fp, "}\n"); fprintf(fp, "}\n");
fclose(fp); if (fclose(fp)) {
log_sys_error("fclose", tmp_file);
goto out;
}
if (rename(tmp_file, pf->file)) if (rename(tmp_file, pf->file))
log_error("%s: rename to %s failed: %s", tmp_file, pf->file, log_error("%s: rename to %s failed: %s", tmp_file, pf->file,

View File

@ -54,7 +54,9 @@ static int _locate_sysfs_blocks(const char *proc, char *path, size_t len)
} }
} }
fclose(fp); if (fclose(fp))
log_sys_error("fclose", proc_mounts);
return r; return r;
} }
@ -156,7 +158,9 @@ static int _read_dev(const char *file, dev_t *result)
} }
r = _parse_dev(file, fp, result); r = _parse_dev(file, fp, result);
fclose(fp);
if (fclose(fp))
log_sys_error("fclose", file);
return r; return r;
} }

View File

@ -204,7 +204,8 @@ static int _scan_proc_dev(const char *proc, const struct config_node *cn)
if (cv->type != CFG_STRING) { if (cv->type != CFG_STRING) {
log_error("Expecting string in devices/types " log_error("Expecting string in devices/types "
"in config file"); "in config file");
fclose(pd); if (fclose(pd))
log_sys_error("fclose", proc_devices);
return 0; return 0;
} }
dev_len = strlen(cv->v.str); dev_len = strlen(cv->v.str);
@ -214,14 +215,16 @@ static int _scan_proc_dev(const char *proc, const struct config_node *cn)
log_error("Max partition count missing for %s " log_error("Max partition count missing for %s "
"in devices/types in config file", "in devices/types in config file",
name); name);
fclose(pd); if (fclose(pd))
log_sys_error("fclose", proc_devices);
return 0; return 0;
} }
if (!cv->v.i) { if (!cv->v.i) {
log_error("Zero partition count invalid for " log_error("Zero partition count invalid for "
"%s in devices/types in config file", "%s in devices/types in config file",
name); name);
fclose(pd); if (fclose(pd))
log_sys_error("fclose", proc_devices);
return 0; return 0;
} }
if (dev_len <= strlen(line + i) && if (dev_len <= strlen(line + i) &&
@ -232,7 +235,10 @@ static int _scan_proc_dev(const char *proc, const struct config_node *cn)
} }
} }
} }
fclose(pd);
if (fclose(pd))
log_sys_error("fclose", proc_devices);
return 1; return 1;
} }

View File

@ -249,17 +249,23 @@ int archive_vg(struct volume_group *vg,
if (!(fp = fdopen(fd, "w"))) { if (!(fp = fdopen(fd, "w"))) {
log_err("Couldn't create FILE object for archive."); log_err("Couldn't create FILE object for archive.");
close(fd); if (close(fd))
log_sys_error("close", temp_file);
return 0; return 0;
} }
if (!text_vg_export_file(vg, desc, fp)) { if (!text_vg_export_file(vg, desc, fp)) {
stack; stack;
fclose(fp); if (fclose(fp))
log_sys_error("fclose", temp_file);
return 0; return 0;
} }
fclose(fp); if (fclose(fp)) {
log_sys_error("fclose", temp_file);
/* Leave file behind as evidence of failure */
return 0;
}
/* /*
* Now we want to rename this file to <vg>_index.vg. * Now we want to rename this file to <vg>_index.vg.

View File

@ -710,7 +710,8 @@ static int _vg_write_file(struct format_instance *fid, struct volume_group *vg,
if (!(fp = fdopen(fd, "w"))) { if (!(fp = fdopen(fd, "w"))) {
log_sys_error("fdopen", temp_file); log_sys_error("fdopen", temp_file);
close(fd); if (close(fd))
log_sys_error("fclose", temp_file);
return 0; return 0;
} }
@ -718,13 +719,15 @@ static int _vg_write_file(struct format_instance *fid, struct volume_group *vg,
if (!text_vg_export_file(vg, tc->desc, fp)) { if (!text_vg_export_file(vg, tc->desc, fp)) {
log_error("Failed to write metadata to %s.", temp_file); log_error("Failed to write metadata to %s.", temp_file);
fclose(fp); if (fclose(fp))
log_sys_error("fclose", temp_file);
return 0; return 0;
} }
if (fsync(fd) && (errno != EROFS) && (errno != EINVAL)) { if (fsync(fd) && (errno != EROFS) && (errno != EINVAL)) {
log_sys_error("fsync", tc->path_edit); log_sys_error("fsync", tc->path_edit);
fclose(fp); if (fclose(fp))
log_sys_error("fclose", tc->path_edit);
return 0; return 0;
} }

View File

@ -163,8 +163,8 @@ static int _lock_file(const char *file, int flags)
log_very_verbose("Locking %s %c%c", ll->res, state, log_very_verbose("Locking %s %c%c", ll->res, state,
flags & LCK_NONBLOCK ? ' ' : 'B'); flags & LCK_NONBLOCK ? ' ' : 'B');
do { do {
if (ll->lf > -1) if ((ll->lf > -1) && close(ll->lf))
close(ll->lf); log_sys_error("close", file);
if ((ll->lf = open(file, O_CREAT | O_APPEND | O_RDWR, 0777)) if ((ll->lf = open(file, O_CREAT | O_APPEND | O_RDWR, 0777))
< 0) { < 0) {

View File

@ -120,7 +120,8 @@ void fin_log(void)
} }
if (_log_to_file) { if (_log_to_file) {
fclose(_log_file); if (fclose(_log_file))
fprintf(stderr, "fclose() on log file failed: %s", strerror(errno));
_log_to_file = 0; _log_to_file = 0;
} }
} }

View File

@ -66,7 +66,8 @@ int create_temp_name(const char *dir, char *buffer, size_t len, int *fd)
if (!fcntl(*fd, F_SETLK, &lock)) if (!fcntl(*fd, F_SETLK, &lock))
return 1; return 1;
close(*fd); if (close(*fd))
log_sys_error("close", buffer);
} }
return 0; return 0;
@ -239,7 +240,8 @@ void sync_dir(const char *file)
if (fsync(fd) && (errno != EROFS) && (errno != EINVAL)) if (fsync(fd) && (errno != EROFS) && (errno != EINVAL))
log_sys_error("fsync", dir); log_sys_error("fsync", dir);
close(fd); if (close(fd))
log_sys_error("close", dir);
out: out:
dm_free(dir); dm_free(dir);

View File

@ -1065,8 +1065,9 @@ static int _run_script(struct cmd_context *cmd, int argc, char **argv)
char buffer[CMD_LEN]; char buffer[CMD_LEN];
int ret = 0; int ret = 0;
int magic_number = 0; int magic_number = 0;
char *script_file = argv[0];
if ((script = fopen(argv[0], "r")) == NULL) if ((script = fopen(script_file, "r")) == NULL)
return ENO_SUCH_CMD; return ENO_SUCH_CMD;
while (fgets(buffer, sizeof(buffer), script) != NULL) { while (fgets(buffer, sizeof(buffer), script) != NULL) {
@ -1099,7 +1100,9 @@ static int _run_script(struct cmd_context *cmd, int argc, char **argv)
lvm_run_command(cmd, argc, argv); lvm_run_command(cmd, argc, argv);
} }
fclose(script); if (fclose(script))
log_sys_error("fclose", script_file);
return ret; return ret;
} }

View File

@ -25,7 +25,7 @@ static int _vgs_single(struct cmd_context *cmd __attribute((unused)),
return ECMD_FAILED; return ECMD_FAILED;
} }
if (!report_object(handle, vg, NULL, NULL, NULL, NULL)); if (!report_object(handle, vg, NULL, NULL, NULL, NULL))
return ECMD_FAILED; return ECMD_FAILED;
check_current_backup(vg); check_current_backup(vg);
@ -39,7 +39,7 @@ static int _lvs_single(struct cmd_context *cmd, struct logical_volume *lv,
if (!arg_count(cmd, all_ARG) && !lv_is_visible(lv)) if (!arg_count(cmd, all_ARG) && !lv_is_visible(lv))
return ECMD_PROCESSED; return ECMD_PROCESSED;
if (!report_object(handle, lv->vg, lv, NULL, NULL, NULL)); if (!report_object(handle, lv->vg, lv, NULL, NULL, NULL))
return ECMD_FAILED; return ECMD_FAILED;
return ECMD_PROCESSED; return ECMD_PROCESSED;
@ -48,7 +48,7 @@ static int _lvs_single(struct cmd_context *cmd, struct logical_volume *lv,
static int _segs_single(struct cmd_context *cmd __attribute((unused)), static int _segs_single(struct cmd_context *cmd __attribute((unused)),
struct lv_segment *seg, void *handle) struct lv_segment *seg, void *handle)
{ {
if (!report_object(handle, seg->lv->vg, seg->lv, NULL, seg, NULL)); if (!report_object(handle, seg->lv->vg, seg->lv, NULL, seg, NULL))
return ECMD_FAILED; return ECMD_FAILED;
return ECMD_PROCESSED; return ECMD_PROCESSED;
@ -78,7 +78,7 @@ static int _pvsegs_sub_single(struct cmd_context *cmd, struct volume_group *vg,
goto out; goto out;
} }
if (!report_object(handle, vg, NULL, pv, NULL, pvseg)); if (!report_object(handle, vg, NULL, pv, NULL, pvseg))
ret = ECMD_FAILED; ret = ECMD_FAILED;
out: out:
@ -128,7 +128,7 @@ static int _pvs_single(struct cmd_context *cmd, struct volume_group *vg,
} }
} }
if (!report_object(handle, vg, NULL, pv, NULL, NULL)); if (!report_object(handle, vg, NULL, pv, NULL, NULL))
ret = ECMD_FAILED; ret = ECMD_FAILED;
out: out: