lvm2-2.03.23-1.fc40
List of Defects
Error: GCC_ANALYZER_WARNING (CWE-775): [#def1]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/dmeventd/dmeventd.c: scope_hint: In function ‘_daemonize’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/dmeventd/dmeventd.c:2014:12: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘open("/dev/null", 0)’
# 2012|
# 2013| /* coverity[leaked_handle] dont't care */
# 2014|-> if ((open("/dev/null", O_RDONLY) < 0) ||
# 2015| (open("/dev/null", O_WRONLY) < 0) ||
# 2016| (open("/dev/null", O_WRONLY) < 0))
Error: GCC_ANALYZER_WARNING (CWE-775): [#def2]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/dmeventd/dmeventd.c:2014:47: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘open("/dev/null", 1)’
# 2012|
# 2013| /* coverity[leaked_handle] dont't care */
# 2014|-> if ((open("/dev/null", O_RDONLY) < 0) ||
# 2015| (open("/dev/null", O_WRONLY) < 0) ||
# 2016| (open("/dev/null", O_WRONLY) < 0))
Error: GCC_ANALYZER_WARNING (CWE-775): [#def3]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/dmeventd/dmeventd.c:2015:47: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘open("/dev/null", 1)’
# 2013| /* coverity[leaked_handle] dont't care */
# 2014| if ((open("/dev/null", O_RDONLY) < 0) ||
# 2015|-> (open("/dev/null", O_WRONLY) < 0) ||
# 2016| (open("/dev/null", O_WRONLY) < 0))
# 2017| exit(EXIT_DESC_OPEN_FAILURE);
Error: GCC_ANALYZER_WARNING (CWE-1341): [#def4]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/dmeventd/libdevmapper-event.c: scope_hint: In function ‘fini_fifos’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/dmeventd/libdevmapper-event.c:545:35: warning[-Wanalyzer-fd-double-close]: double ‘close’ of file descriptor ‘fifos.client’
/usr/include/time.h:29: included_from: Included from here.
/usr/include/pthread.h:23: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/daemons/dmeventd/libdevmapper-event.c:28: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/libdm/libdevmapper.h:23: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/libdm/misc/dm-logging.h:19: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/daemons/dmeventd/libdevmapper-event.c:17: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/libdm/misc/dm-logging.h:26:27: note: in expansion of macro ‘LOG_MESG’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:88:25: note: in expansion of macro ‘LOG_LINE’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:110:15: note: in expansion of macro ‘log_debug’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:135:30: note: in expansion of macro ‘stack’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/dmeventd/libdevmapper-event.c:629:17: note: in expansion of macro ‘goto_out’
# 543| void fini_fifos(struct dm_event_fifos *fifos)
# 544| {
# 545|-> if (fifos->client >= 0 && close(fifos->client))
# 546| log_sys_debug("close", fifos->client_path);
# 547|
Error: GCC_ANALYZER_WARNING: [#def5]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockctl.c: scope_hint: In function ‘_reopen_fd_to_null’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockctl.c:541:13: warning[-Wanalyzer-fd-use-without-check]: ‘dup2’ on possibly invalid file descriptor ‘fd’
# 539| }
# 540|
# 541|-> if (dup2(null_fd, fd) == -1) {
# 542| log_error("dup2 error %d", errno);
# 543| goto out;
Error: GCC_ANALYZER_WARNING: [#def6]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockctl.c: scope_hint: In function ‘_run_command_pipe’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockctl.c:649:26: warning[-Wanalyzer-fd-use-without-check]: ‘dup2’ on possibly invalid file descriptor ‘1’
# 647| else if (close(STDOUT_FILENO))
# 648| log_error("close error STDOUT %d", errno);
# 649|-> else if (dup2(pipefd[1 /*write*/], STDOUT_FILENO) == -1)
# 650| log_error("dup2 error STDOUT %d", errno);
# 651| else if (close(pipefd[1]))
Error: COMPILER_WARNING (CWE-9001): [#def7]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockctl.c:13: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-client.h: scope_hint: In function ‘do_kill’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-client.h:21:29: warning[-Winline]: inlining failed in call to ‘lvmlockd_open.constprop.0’: call is unlikely and code size would grow
# 21 | static inline daemon_handle lvmlockd_open(const char *sock)
# | ^~~~~~~~~~~~~
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockctl.c:853:21: note: called from here
# 853 | _lvmlockd = lvmlockd_open(NULL);
# | ^~~~~~~~~~~~~~~~~~~
# 19| /* Wrappers to open/close connection */
# 20|
# 21|-> static inline daemon_handle lvmlockd_open(const char *sock)
# 22| {
# 23| daemon_info lvmlockd_info = {
Error: COMPILER_WARNING (CWE-9001): [#def8]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-client.h: scope_hint: In function ‘do_kill’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-client.h:21:29: warning[-Winline]: inlining failed in call to ‘lvmlockd_open.constprop’: call is unlikely and code size would grow
# 21 | static inline daemon_handle lvmlockd_open(const char *sock)
# | ^
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockctl.c:853:21: note: called from here
# 853 | _lvmlockd = lvmlockd_open(NULL);
# | ^
# 19| /* Wrappers to open/close connection */
# 20|
# 21|-> static inline daemon_handle lvmlockd_open(const char *sock)
# 22| {
# 23| daemon_info lvmlockd_info = {
Error: CLANG_WARNING: [#def9]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c:1954:2: warning[unix.Malloc]: Use of memory after it is freed
# 1952| */
# 1953|
# 1954|-> list_for_each_entry_safe(act, safe, &r->actions, list) {
# 1955| if (act->flags & LD_AF_PERSISTENT)
# 1956| continue;
Error: CLANG_WARNING: [#def10]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c:1989:2: warning[unix.Malloc]: Use of memory after it is freed
# 1987| */
# 1988|
# 1989|-> list_for_each_entry_safe(act, safe, &r->actions, list) {
# 1990| if (!(act->flags & LD_AF_PERSISTENT))
# 1991| continue;
Error: CLANG_WARNING: [#def11]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c:2035:2: warning[unix.Malloc]: Use of memory after it is freed
# 2033| */
# 2034|
# 2035|-> list_for_each_entry_safe(act, safe, &r->actions, list) {
# 2036| if (act->flags & LD_AF_PERSISTENT)
# 2037| continue;
Error: COMPILER_WARNING: [#def12]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c: scope_hint: In function ‘find_resource_act’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c:2376:17: warning[-Wstringop-truncation]: ‘strncpy’ output may be truncated copying 64 bytes from a string of length 64
# 2376 | strncpy(r->name, act->lv_uuid, MAX_NAME);
# | ^
# 2374| r->use_vb = 1;
# 2375| } else if (r->type == LD_RT_LV) {
# 2376|-> strncpy(r->name, act->lv_uuid, MAX_NAME);
# 2377| r->use_vb = 0;
# 2378| }
Error: COMPILER_WARNING: [#def13]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c: scope_hint: In function ‘vg_ls_name.isra.0’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c:2926:42: warning[-Wformat-truncation=]: ‘__snprintf_chk’ output may be truncated before the last format character
# 2926 | snprintf(ls_name, MAX_NAME, "%s%s", LVM_LS_PREFIX, vg_name);
# | ^
/usr/include/bits/stdio2.h:68:10: note: ‘__snprintf_chk’ output between 5 and 65 bytes into a destination of size 64
# 68 | return __builtin___snprintf_chk (__s, __n, __USE_FORTIFY_LEVEL - 1,
# | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# 69 | __glibc_objsize (__s), __fmt,
# | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# 70 | __va_arg_pack ());
# | ~~~~~~~~~~~~~~~~~
# 2924| }
# 2925|
# 2926|-> snprintf(ls_name, MAX_NAME, "%s%s", LVM_LS_PREFIX, vg_name);
# 2927| return 0;
# 2928| }
Error: COMPILER_WARNING: [#def14]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c: scope_hint: In function ‘add_lockspace_thread’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c:2984:17: warning[-Wstringop-truncation]: ‘strncpy’ specified bound 64 equals destination size
# 2984 | strncpy(ls->vg_uuid, vg_uuid, 64);
# | ^
# 2982| if (vg_uuid)
# 2983| /* coverity[buffer_size_warning] */
# 2984|-> strncpy(ls->vg_uuid, vg_uuid, 64);
# 2985|
# 2986| if (vg_name)
Error: COMPILER_WARNING: [#def15]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c: scope_hint: In function ‘worker_thread_main’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c:3532:33: warning[-Wstringop-truncation]: ‘strncpy’ output may be truncated copying 64 bytes from a string of length 64
# 3532 | strncpy(gl_lsname_sanlock, ls->name, MAX_NAME);
# | ^
# 3530| if (is_enabled) {
# 3531| log_debug("S %s worker found gl_is_enabled", ls->name);
# 3532|-> strncpy(gl_lsname_sanlock, ls->name, MAX_NAME);
# 3533| }
# 3534| }
Error: COMPILER_WARNING: [#def16]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c: scope_hint: In function ‘client_thread_main’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c:4912:17: warning[-Wstringop-truncation]: ‘strncpy’ specified bound 64 equals destination size
# 4912 | strncpy(act->vg_uuid, vg_uuid, 64);
# | ^
# 4910|
# 4911| if (vg_uuid && strcmp(vg_uuid, "none"))
# 4912|-> strncpy(act->vg_uuid, vg_uuid, 64);
# 4913|
# 4914| if (vg_sysid && strcmp(vg_sysid, "none"))
Error: COMPILER_WARNING: [#def17]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c: scope_hint: In function ‘main_loop’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c:5630:17: warning[-Wstringop-truncation]: ‘strncpy’ output may be truncated copying 64 bytes from a string of length 64
# 5630 | strncpy(act->vg_name, ls->vg_name, MAX_NAME);
# | ^
# 5628| act->lm_type = ls->lm_type;
# 5629| act->client_id = INTERNAL_CLIENT_ID;
# 5630|-> strncpy(act->vg_name, ls->vg_name, MAX_NAME);
# 5631| memcpy(act->vg_uuid, ls->vg_uuid, 64);
# 5632| memcpy(act->vg_args, ls->vg_args, MAX_ARGS);
Error: COMPILER_WARNING: [#def18]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c:5722:25: warning[-Wstringop-truncation]: ‘strncpy’ output may be truncated copying 64 bytes from a string of length 64
# 5722 | strncpy(act->vg_name, ls->vg_name, MAX_NAME);
# | ^
# 5720| act->client_id = INTERNAL_CLIENT_ID;
# 5721| act->lm_type = ls->lm_type;
# 5722|-> strncpy(act->vg_name, ls->vg_name, MAX_NAME);
# 5723| strncpy(act->lv_uuid, r->name, MAX_NAME);
# 5724| strncpy(act->lv_args, r->lv_args, MAX_ARGS);
Error: COMPILER_WARNING: [#def19]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c:5723:25: warning[-Wstringop-truncation]: ‘strncpy’ output may be truncated copying 64 bytes from a string of length 64
# 5723 | strncpy(act->lv_uuid, r->name, MAX_NAME);
# | ^
# 5721| act->lm_type = ls->lm_type;
# 5722| strncpy(act->vg_name, ls->vg_name, MAX_NAME);
# 5723|-> strncpy(act->lv_uuid, r->name, MAX_NAME);
# 5724| strncpy(act->lv_args, r->lv_args, MAX_ARGS);
# 5725|
Error: COMPILER_WARNING: [#def20]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c:5724:25: warning[-Wstringop-truncation]: ‘strncpy’ output may be truncated copying 64 bytes from a string of length 64
# 5724 | strncpy(act->lv_args, r->lv_args, MAX_ARGS);
# | ^
# 5722| strncpy(act->vg_name, ls->vg_name, MAX_NAME);
# 5723| strncpy(act->lv_uuid, r->name, MAX_NAME);
# 5724|-> strncpy(act->lv_args, r->lv_args, MAX_ARGS);
# 5725|
# 5726| log_debug("adopt lock for lv %s %s", act->vg_name, act->lv_uuid);
Error: COMPILER_WARNING: [#def21]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-core.c:5750:17: warning[-Wstringop-truncation]: ‘strncpy’ output may be truncated copying 64 bytes from a string of length 64
# 5750 | strncpy(act->vg_name, ls->vg_name, MAX_NAME);
# | ^
# 5748| act->client_id = INTERNAL_CLIENT_ID;
# 5749| act->lm_type = ls->lm_type;
# 5750|-> strncpy(act->vg_name, ls->vg_name, MAX_NAME);
# 5751|
# 5752| log_debug("adopt lock for vg %s", act->vg_name);
Error: COMPILER_WARNING: [#def22]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-dlm.c: scope_hint: In function ‘lm_get_lockspaces_dlm’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-dlm.c:849:17: warning[-Wstringop-truncation]: ‘strncpy’ output may be truncated copying 64 bytes from a string of length 255
# 849 | strncpy(ls->name, de->d_name, MAX_NAME);
# | ^
# 847|
# 848| ls->lm_type = LD_LM_DLM;
# 849|-> strncpy(ls->name, de->d_name, MAX_NAME);
# 850| strncpy(ls->vg_name, ls->name + strlen(LVM_LS_PREFIX), MAX_NAME);
# 851| list_add_tail(&ls->list, ls_rejoin);
Error: GCC_ANALYZER_WARNING: [#def23]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-dlm.c: scope_hint: In function ‘lm_get_lockspaces_dlm’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-dlm.c:850:17: warning[-Wanalyzer-overlapping-buffers]: overlapping buffers passed as arguments to ‘strncpy’
lvm2-2.03.23-build/LVM2.2.03.23/device_mapper/all.h:34: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/tools/tool.h:22: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-dlm.c:14: included_from: Included from here.
/usr/include/string.h:144:14: note: the behavior of ‘strncpy’ is undefined for overlapping buffers
# 848| ls->lm_type = LD_LM_DLM;
# 849| strncpy(ls->name, de->d_name, MAX_NAME);
# 850|-> strncpy(ls->vg_name, ls->name + strlen(LVM_LS_PREFIX), MAX_NAME);
# 851| list_add_tail(&ls->list, ls_rejoin);
# 852| }
Error: CLANG_WARNING: [#def24]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c:683:4: warning[deadcode.DeadStores]: Value stored to 'rv' is never read
# 681| if (rv == -EMSGSIZE || rv == -ENOSPC) {
# 682| /* This indicates the end of the device is reached. */
# 683|-> rv = -EMSGSIZE;
# 684| break;
# 685| }
Error: CLANG_WARNING: [#def25]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c:987:4: warning[deadcode.DeadStores]: Value stored to 'rv' is never read
# 985| if (rv == -EMSGSIZE || rv == -ENOSPC) {
# 986| /* This indicates the end of the device is reached. */
# 987|-> rv = -EMSGSIZE;
# 988| break;
# 989| }
Error: COMPILER_WARNING: [#def26]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c: scope_hint: In function ‘lm_able_gl_sanlock’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c:1147:17: warning[-Wstringop-truncation]: ‘strncpy’ output may be truncated copying 64 bytes from a string of length 64
# 1147 | strncpy(gl_lsname_sanlock, ls->name, MAX_NAME);
# | ^
# 1145|
# 1146| if (enable)
# 1147|-> strncpy(gl_lsname_sanlock, ls->name, MAX_NAME);
# 1148|
# 1149| if (!enable && !strcmp(gl_lsname_sanlock, ls->name))
Error: COMPILER_WARNING: [#def27]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c: scope_hint: In function ‘lm_prepare_lockspace_sanlock’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c:1420:9: warning[-Wstringop-truncation]: ‘strncpy’ output may be truncated copying 48 bytes from a string of length 64
# 1420 | strncpy(lsname, ls->name, SANLK_NAME_LEN);
# | ^
# 1418|
# 1419| memset(lsname, 0, sizeof(lsname));
# 1420|-> strncpy(lsname, ls->name, SANLK_NAME_LEN);
# 1421|
# 1422| memcpy(lms->ss.name, lsname, SANLK_NAME_LEN);
Error: GCC_ANALYZER_WARNING (CWE-126): [#def28]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c: scope_hint: In function ‘lm_prepare_lockspace_sanlock’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c:1429:25: warning[-Wanalyzer-out-of-bounds]: stack-based buffer over-read
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c: scope_hint: In function ‘lm_prepare_lockspace_sanlock’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c: scope_hint: In function ‘lm_prepare_lockspace_sanlock’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c:1429:25: note: read of 15 bytes from after the end of ‘lsname’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c:1429:25: note: valid subscripts for ‘lsname’ are ‘[0]’ to ‘[48]’
# └──────────────────────────────────────────────────────────────────────┘
# ^ ^ ^ ^
# 1427| if (daemon_test) {
# 1428| if (!gl_lsname_sanlock[0]) {
# 1429|-> strncpy(gl_lsname_sanlock, lsname, MAX_NAME);
# 1430| log_debug("S %s prepare_lockspace_san use global lock", lsname);
# 1431| }
Error: GCC_ANALYZER_WARNING (CWE-126): [#def29]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c:1503:25: warning[-Wanalyzer-out-of-bounds]: stack-based buffer over-read
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c: scope_hint: In function ‘lm_prepare_lockspace_sanlock’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c: scope_hint: In function ‘lm_prepare_lockspace_sanlock’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c:19: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c:1443:9: note: in expansion of macro ‘log_debug’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c:1479:9: note: in expansion of macro ‘log_debug’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c:1503:25: note: read of 15 bytes from after the end of ‘lsname’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c:1503:25: note: valid subscripts for ‘lsname’ are ‘[0]’ to ‘[48]’
# └──────────────────────────────────────────────────────────────────────┘
# ^ ^ ^ ^
# 1501| lsname, gl_lsname_sanlock);
# 1502| } else {
# 1503|-> strncpy(gl_lsname_sanlock, lsname, MAX_NAME);
# 1504| log_debug("S %s prepare_lockspace_san use global lock %s",
# 1505| lsname, gl_lsname_sanlock);
Error: CLANG_WARNING: [#def30]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmlockd/lvmlockd-sanlock.c:1904:4: warning[deadcode.DeadStores]: Value stored to 'rv' is never read
# 1902| */
# 1903| if (rv == -ENOSPC)
# 1904|-> rv = -ELOCKIO;
# 1905|
# 1906| /*
Error: GCC_ANALYZER_WARNING (CWE-775): [#def31]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmpolld/lvmpolld-core.c: scope_hint: In function ‘fork_and_poll’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmpolld/lvmpolld-core.c:409:20: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘dup2(outfd, 1)’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmpolld/lvmpolld-core.c:19: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmpolld/lvmpolld-core.c:393:9: note: in expansion of macro ‘DEBUGLOG’
# 407| /* !!! Do not touch any posix thread primitives !!! */
# 408|
# 409|-> if ((dup2(outfd, STDOUT_FILENO ) != STDOUT_FILENO) ||
# 410| (dup2(errfd, STDERR_FILENO ) != STDERR_FILENO))
# 411| _exit(LVMPD_RET_DUP_FAILED);
Error: GCC_ANALYZER_WARNING (CWE-775): [#def32]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmpolld/lvmpolld-core.c:409:68: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘dup2(errfd, 2)’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmpolld/lvmpolld-core.c:393:9: note: in expansion of macro ‘DEBUGLOG’
# 407| /* !!! Do not touch any posix thread primitives !!! */
# 408|
# 409|-> if ((dup2(outfd, STDOUT_FILENO ) != STDOUT_FILENO) ||
# 410| (dup2(errfd, STDERR_FILENO ) != STDERR_FILENO))
# 411| _exit(LVMPD_RET_DUP_FAILED);
Error: CLANG_WARNING: [#def33]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmpolld/lvmpolld-core.c:413:3: warning[core.NonNullParamChecker]: Null pointer passed to 1st parameter expecting 'nonnull'
# 411| _exit(LVMPD_RET_DUP_FAILED);
# 412|
# 413|-> execve(*(pdlv->cmdargv), (char *const *)pdlv->cmdargv, (char *const *)pdlv->cmdenvp);
# 414|
# 415| _exit(LVMPD_RET_EXC_FAILED);
Error: GCC_ANALYZER_WARNING (CWE-775): [#def34]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmpolld/lvmpolld-data-utils.c: scope_hint: In function ‘lvmpolld_thread_data_destroy’
lvm2-2.03.23-build/LVM2.2.03.23/daemons/lvmpolld/lvmpolld-data-utils.c:397:9: warning[-Wanalyzer-fd-leak]: leak of file descriptor
# 395| (void) close(data->errpipe[1]);
# 396|
# 397|-> free(data);
# 398| }
Error: COMPILER_WARNING: [#def35]
lvm2-2.03.23-build/LVM2.2.03.23/device_mapper/ioctl/libdm-iface.c: scope_hint: In function ‘dm_task_run’
lvm2-2.03.23-build/LVM2.2.03.23/device_mapper/ioctl/libdm-iface.c:1259:25: warning[-Wstringop-truncation]: ‘__strncpy_chk’ specified bound 128 equals destination size
# 1259 | strncpy(buf, names->name, len);
# | ^
# 1257| names = (struct dm_names *)((char *) names + next);
# 1258| if (names->dev == dev) {
# 1259|-> strncpy(buf, names->name, len);
# 1260| r = 1;
# 1261| break;
Error: COMPILER_WARNING: [#def36]
lvm2-2.03.23-build/LVM2.2.03.23/device_mapper/ioctl/libdm-iface.c:1429:17: warning[-Wstringop-truncation]: ‘__strncpy_chk’ specified bound 128 equals destination size
# 1429 | strncpy(dmi->name, DEV_NAME(dmt), sizeof(dmi->name));
# | ^
# 1427| dmt->major < 0))
# 1428| /* coverity[buffer_size_warning] */
# 1429|-> strncpy(dmi->name, DEV_NAME(dmt), sizeof(dmi->name));
# 1430|
# 1431| if (DEV_UUID(dmt))
Error: COMPILER_WARNING: [#def37]
lvm2-2.03.23-build/LVM2.2.03.23/device_mapper/ioctl/libdm-iface.c:1433:17: warning[-Wstringop-truncation]: ‘__strncpy_chk’ specified bound 129 equals destination size
# 1433 | strncpy(dmi->uuid, DEV_UUID(dmt), sizeof(dmi->uuid));
# | ^
# 1431| if (DEV_UUID(dmt))
# 1432| /* coverity[buffer_size_warning] */
# 1433|-> strncpy(dmi->uuid, DEV_UUID(dmt), sizeof(dmi->uuid));
# 1434|
# 1435| if (dmt->type == DM_DEVICE_SUSPEND)
Error: COMPILER_WARNING: [#def38]
lvm2-2.03.23-build/LVM2.2.03.23/device_mapper/libdm-deptree.c: scope_hint: In function ‘dm_tree_find_node_by_uuid’
lvm2-2.03.23-build/LVM2.2.03.23/device_mapper/libdm-deptree.c:617:32: warning[-Wstringop-truncation]: ‘strncpy’ specified bound 129 equals destination size
# 617 | (void) strncpy(uuid_without_suffix, uuid, sizeof(uuid_without_suffix));
# | ^
# 615| continue;
# 616|
# 617|-> (void) strncpy(uuid_without_suffix, uuid, sizeof(uuid_without_suffix));
# 618| uuid_without_suffix[suffix_position - uuid] = '\0';
# 619|
Error: CLANG_WARNING: [#def39]
lvm2-2.03.23-build/LVM2.2.03.23/device_mapper/libdm-report.c:592:3: warning[core.CallAndMessage]: 2nd function call argument is an uninitialized value
# 590| arr[i].item.pos = pos;
# 591|
# 592|-> memcpy(repstr + pos, arr[i].str, arr[i].item.len);
# 593| memcpy(repstr_extra + i + 1, &arr[i].item, sizeof(struct pos_len));
# 594|
Error: CLANG_WARNING: [#def40]
lvm2-2.03.23-build/LVM2.2.03.23/device_mapper/regex/ttree.c:99:13: warning[core.NullDereference]: Access to field 'data' results in a dereference of a null pointer
# 97| }
# 98| }
# 99|-> (*c)->data = data;
# 100|
# 101| return 1;
Error: GCC_ANALYZER_WARNING (CWE-401): [#def41]
lvm2-2.03.23-build/LVM2.2.03.23/daemons/dmeventd/plugins/vdo/dmeventd_vdo.c:26: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/device_mapper/vdo/status.c: scope_hint: In function ‘dm_vdo_status_parse’
lvm2-2.03.23-build/LVM2.2.03.23/device_mapper/vdo/status.c:247:12: warning[-Wanalyzer-malloc-leak]: leak of ‘<unknown>’
lvm2-2.03.23-build/LVM2.2.03.23/device_mapper/vdo/status.c: scope_hint: In function ‘dm_vdo_status_parse’
# 245|
# 246| bad:
# 247|-> if (s && !mem) {
# 248| free(s->device);
# 249| free(s);
Error: CLANG_WARNING: [#def42]
lvm2-2.03.23-build/LVM2.2.03.23/lib/activate/dev_manager.c:4133:2: warning[deadcode.DeadStores]: Value stored to 'next' is never read
# 4131| }
# 4132|
# 4133|-> next = dm_get_next_target(dmt, next, &start, &length, &target_type, ¶ms);
# 4134|
# 4135| if (!target_type || !params || strcmp(target_type, "crypt")) {
Error: CLANG_WARNING: [#def43]
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.c:1384:7: warning[deadcode.DeadStores]: Although the value stored to 'vginfo' is used in the enclosing expression, the value is never actually read from 'vginfo'
# 1382|
# 1383| /* Dropping the last info struct is supposed to drop vginfo. */
# 1384|-> if ((vginfo = lvmcache_vginfo_from_vgname(vgname, vgid)))
# 1385| log_warn("VG info not dropped before rescan of %s", vgname);
# 1386|
Error: CLANG_WARNING: [#def44]
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.c:1397:8: warning[deadcode.DeadStores]: Although the value stored to 'vginfo' is used in the enclosing expression, the value is never actually read from 'vginfo'
# 1395| }
# 1396|
# 1397|-> if (!(vginfo = lvmcache_vginfo_from_vgname(vgname, vgid))) {
# 1398| log_warn("VG info not found after rescan of %s", vgname);
# 1399| return 0;
Error: GCC_ANALYZER_WARNING (CWE-688): [#def45]
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.c: scope_hint: In function ‘_lvmcache_update_vgname’
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.c:1968:30: warning[-Wanalyzer-null-argument]: use of NULL ‘vgid’ where non-null expected
lvm2-2.03.23-build/LVM2.2.03.23/lib/misc/lib.h:30: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.c:17: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:95:31: note: in expansion of macro ‘LOG_LINE_WITH_CLASS’
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.c:1941:17: note: in expansion of macro ‘log_debug_cache’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:95:31: note: in expansion of macro ‘LOG_LINE_WITH_CLASS’
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.c:1957:25: note: in expansion of macro ‘log_debug_cache’
lvm2-2.03.23-build/LVM2.2.03.23/device_mapper/all.h:34: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/lib/misc/lib.h:22: included_from: Included from here.
/usr/include/string.h:64:12: note: argument 2 of ‘memcmp’ must be non-null
# 1966| */
# 1967|
# 1968|-> if (!memcmp(other->vgid, vgid, ID_LEN)) {
# 1969| /* shouldn't happen since we looked up by vgid above */
# 1970| log_error(INTERNAL_ERROR "lvmcache_update_vgname %s %s %s %s",
Error: GCC_ANALYZER_WARNING (CWE-401): [#def46]
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.c: scope_hint: In function ‘_lvmcache_update_vgstatus’
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.c:2069:12: warning[-Wanalyzer-malloc-leak]: leak of ‘strdup(lock_type)’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:95:31: note: in expansion of macro ‘LOG_LINE_WITH_CLASS’
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.c:2056:9: note: in expansion of macro ‘log_debug_cache’
# 2067| free(info->vginfo->lock_type);
# 2068|
# 2069|-> if (!(info->vginfo->lock_type = strdup(lock_type))) {
# 2070| log_error("cache lock_type alloc failed for %s", lock_type);
# 2071| return 0;
Error: GCC_ANALYZER_WARNING (CWE-401): [#def47]
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.c:2087:12: warning[-Wanalyzer-malloc-leak]: leak of ‘strdup(system_id)’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:95:31: note: in expansion of macro ‘LOG_LINE_WITH_CLASS’
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.c:2074:9: note: in expansion of macro ‘log_debug_cache’
# 2085| free(info->vginfo->system_id);
# 2086|
# 2087|-> if (!(info->vginfo->system_id = strdup(system_id))) {
# 2088| log_error("cache system_id alloc failed for %s", system_id);
# 2089| return 0;
Error: CLANG_WARNING: [#def48]
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.c:2343:57: warning[unix.Malloc]: Use of memory after it is freed
# 2341|
# 2342| log_warn("WARNING: outdated PV %s seqno %u has been removed in current VG %s seqno %u.",
# 2343|-> dev_name(info->dev), info->summary_seqno, vg->name, vginfo->seqno);
# 2344|
# 2345| if (!_outdated_warning++)
Error: GCC_ANALYZER_WARNING (CWE-401): [#def49]
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.c: scope_hint: In function ‘lvmcache_add’
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.c:2549:33: warning[-Wanalyzer-malloc-leak]: leak of ‘calloc(1, 24)’
/usr/include/bits/types/struct_iovec.h:23: included_from: Included from here.
/usr/include/bits/fcntl-linux.h:38: included_from: Included from here.
/usr/include/bits/fcntl.h:61: included_from: Included from here.
/usr/include/fcntl.h:35: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/device.h:21: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/dev-cache.h:19: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.h:19: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.c:18: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:95:31: note: in expansion of macro ‘LOG_LINE_WITH_CLASS’
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.c:2526:25: note: in expansion of macro ‘log_debug_cache’
lvm2-2.03.23-build/LVM2.2.03.23/lib/cache/lvmcache.c: scope_hint: In function ‘lvmcache_add’
# 2547| devl->dev = dev;
# 2548|
# 2549|-> dm_list_add(&_initial_duplicates, &devl->list);
# 2550| }
# 2551|
Error: GCC_ANALYZER_WARNING (CWE-835): [#def50]
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/dev-type.c: scope_hint: In function ‘create_dev_types’
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/dev-type.c:268:28: warning[-Wanalyzer-infinite-loop]: infinite loop
# 266|
# 267| /* Find the start of the device major name */
# 268|-> while (line[i] != ' ' && line[i] != '\0')
# 269| i++;
# 270| while (line[i] == ' ')
Error: GCC_ANALYZER_WARNING (CWE-835): [#def51]
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/dev-type.c:270:28: warning[-Wanalyzer-infinite-loop]: infinite loop
# 268| while (line[i] != ' ' && line[i] != '\0')
# 269| i++;
# 270|-> while (line[i] == ' ')
# 271| i++;
# 272|
Error: CLANG_WARNING: [#def52]
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/dev-type.c:641:8: warning[deadcode.DeadStores]: Although the value stored to 'value' is used in the enclosing expression, the value is never actually read from 'value'
# 639|
# 640| device = (struct udev_device *) ext->handle;
# 641|-> if (!(value = udev_device_get_property_value(device, DEV_EXT_UDEV_BLKID_PART_TABLE_TYPE)))
# 642| return 0;
# 643|
Error: COMPILER_WARNING: [#def53]
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/device_id.c:1211:33: warning[-Wstringop-truncation]: ‘strncpy’ output may be truncated copying 4095 bytes from a string of length 4095
# 1211 | strncpy(devices_file_hostname_orig, check_id, PATH_MAX-1);
# | ^
# 1209| /* Save original for lvmdevices output. */
# 1210| if (!strcmp(cmd->name, "lvmdevices"))
# 1211|-> strncpy(devices_file_hostname_orig, check_id, PATH_MAX-1);
# 1212|
# 1213| if (!cmd->device_ids_check_hostname)
Error: COMPILER_WARNING: [#def54]
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/device_id.c: scope_hint: In function ‘device_ids_read’
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/device_id.c:1231:33: warning[-Wstringop-truncation]: ‘strncpy’ output may be truncated copying 4095 bytes from a string of length 4095
# 1231 | strncpy(devices_file_product_uuid_orig, check_id, PATH_MAX-1);
# | ^
# 1229| /* Save original for lvmdevices output. */
# 1230| if (!strcmp(cmd->name, "lvmdevices"))
# 1231|-> strncpy(devices_file_product_uuid_orig, check_id, PATH_MAX-1);
# 1232|
# 1233| if (!cmd->device_ids_check_product_uuid)
Error: GCC_ANALYZER_WARNING (CWE-401): [#def55]
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/online.c: scope_hint: In function ‘get_pvs_online’
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/online.c:189:17: warning[-Wanalyzer-malloc-leak]: leak of ‘calloc(1, 328)’
lvm2-2.03.23-build/LVM2.2.03.23/lib/misc/lib.h:30: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/online.c:16: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:103:24: note: in expansion of macro ‘LOG_LINE’
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/online.c:97:25: note: in expansion of macro ‘log_warn’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:88:25: note: in expansion of macro ‘LOG_LINE’
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/online.c:112:25: note: in expansion of macro ‘log_debug’
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/online.c: scope_hint: In function ‘get_pvs_online’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:88:25: note: in expansion of macro ‘LOG_LINE’
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/online.c:188:17: note: in expansion of macro ‘log_debug’
# 187|
# 188| log_debug("Found PV online %s for VG %s %s", path, vgname, file_devname);
# 189|-> dm_list_add(pvs_online, &po->list);
# 190| }
# 191|
Error: COMPILER_WARNING: [#def56]
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/online.c: scope_hint: In function ‘get_pvs_lookup’
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/online.c:435:25: warning[-Wstringop-truncation]: ‘strncpy’ output may be truncated copying 127 bytes from a string of length 127
# 435 | strncpy(po->vgname, file_vgname, NAME_LEN-1);
# | ^
# 433| po->devno = MKDEV(file_major, file_minor);
# 434| if (file_vgname[0])
# 435|-> strncpy(po->vgname, file_vgname, NAME_LEN-1);
# 436| if (file_devname[0])
# 437| strncpy(po->devname, file_devname, NAME_LEN-1);
Error: COMPILER_WARNING: [#def57]
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/online.c:437:25: warning[-Wstringop-truncation]: ‘strncpy’ output may be truncated copying 127 bytes from a string of length 127
# 437 | strncpy(po->devname, file_devname, NAME_LEN-1);
# | ^
# 435| strncpy(po->vgname, file_vgname, NAME_LEN-1);
# 436| if (file_devname[0])
# 437|-> strncpy(po->devname, file_devname, NAME_LEN-1);
# 438|
# 439| log_debug("Found PV online lookup %s for VG %s on %s.", path, vgname, file_devname);
Error: GCC_ANALYZER_WARNING (CWE-401): [#def58]
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/online.c: scope_hint: In function ‘get_pvs_lookup’
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/online.c:440:17: warning[-Wanalyzer-malloc-leak]: leak of ‘calloc(1, 328)’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:88:25: note: in expansion of macro ‘LOG_LINE’
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/online.c:91:25: note: in expansion of macro ‘log_debug’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:88:25: note: in expansion of macro ‘LOG_LINE’
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/online.c:112:25: note: in expansion of macro ‘log_debug’
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/online.c: scope_hint: In function ‘get_pvs_lookup’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:88:25: note: in expansion of macro ‘LOG_LINE’
lvm2-2.03.23-build/LVM2.2.03.23/lib/device/online.c:439:17: note: in expansion of macro ‘log_debug’
# 438|
# 439| log_debug("Found PV online lookup %s for VG %s on %s.", path, vgname, file_devname);
# 440|-> dm_list_add(pvs_online, &po->list);
# 441| }
# 442|
Error: CLANG_WARNING: [#def59]
lvm2-2.03.23-build/LVM2.2.03.23/lib/display/display.c:978:33: warning[core.UndefinedBinaryOperatorResult]: The right operand of '==' is a garbage value due to array index out of bounds
# 976| c = tolower(c);
# 977|
# 978|-> if ((ret > 0) && answer && (c == answer[0]))
# 979| answer++; /* Matching, next char */
# 980| else if (c == '\n') {
Error: GCC_ANALYZER_WARNING (CWE-465): [#def60]
lvm2-2.03.23-build/LVM2.2.03.23/lib/format_text/flags.c: scope_hint: In function ‘read_flags’
lvm2-2.03.23-build/LVM2.2.03.23/lib/format_text/flags.c:195:16: warning[-Wanalyzer-deref-before-check]: check of ‘cv’ for NULL after already dereferencing it
# 193| goto out;
# 194|
# 195|-> while (cv) {
# 196| if (cv->type != DM_CFG_STRING) {
# 197| log_error("Status value is not a string.");
Error: GCC_ANALYZER_WARNING (CWE-465): [#def61]
lvm2-2.03.23-build/LVM2.2.03.23/lib/format_text/import_vsn1.c: scope_hint: In function ‘_read_str_list’
lvm2-2.03.23-build/LVM2.2.03.23/lib/format_text/import_vsn1.c:162:16: warning[-Wanalyzer-deref-before-check]: check of ‘cv’ for NULL after already dereferencing it
lvm2-2.03.23-build/LVM2.2.03.23/lib/format_text/import_vsn1.c:396:14: note: in expansion of macro ‘_read_int32’
lvm2-2.03.23-build/LVM2.2.03.23/lib/format_text/import_vsn1.c:402:14: note: in expansion of macro ‘_read_int32’
lvm2-2.03.23-build/LVM2.2.03.23/lib/format_text/import_vsn1.c:408:14: note: in expansion of macro ‘_read_int32’
# 160| return 1;
# 161|
# 162|-> while (cv) {
# 163| if (cv->type != DM_CFG_STRING) {
# 164| log_error("Found an item that is not a string");
Error: GCC_ANALYZER_WARNING (CWE-401): [#def62]
lvm2-2.03.23-build/LVM2.2.03.23/lib/label/hints.c: scope_hint: In function ‘_read_hint_file’
lvm2-2.03.23-build/LVM2.2.03.23/lib/label/hints.c:861:17: warning[-Wanalyzer-malloc-leak]: leak of ‘calloc(1, 4288)’
lvm2-2.03.23-build/LVM2.2.03.23/lib/misc/lib.h:30: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/lib/label/hints.c:138: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:88:25: note: in expansion of macro ‘LOG_LINE’
lvm2-2.03.23-build/LVM2.2.03.23/lib/label/hints.c:717:9: note: in expansion of macro ‘log_debug’
lvm2-2.03.23-build/LVM2.2.03.23/lib/label/hints.c: scope_hint: In function ‘_read_hint_file’
# 859|
# 860| log_debug("add hint %s %s %d:%d %s", hint.name, hint.pvid, major, minor, vgname);
# 861|-> dm_list_add(hints, &alloc_hint->list);
# 862| found++;
# 863| }
Error: COMPILER_WARNING: [#def63]
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.c: scope_hint: In function ‘reopen_standard_stream’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.c:209:9: warning[-Wuse-after-free]: pointer ‘old_stream_40’ may be used after ‘fclose’
# 209 | _check_and_replace_standard_log_streams(old_stream, new_stream);
# | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.c:193:13: note: call to ‘fclose’ here
# 193 | if (fclose(old_stream))
# | ^~~~~~~~~~~~~~~~~~
# 207| }
# 208|
# 209|-> _check_and_replace_standard_log_streams(old_stream, new_stream);
# 210|
# 211| *stream = new_stream;
Error: CLANG_WARNING: [#def64]
lvm2-2.03.23-build/LVM2.2.03.23/lib/metadata/merge.c:705:5: warning[core.NullDereference]: Access to field 'n' results in a dereference of a null pointer
# 703| */
# 704| seg_found = 0;
# 705|-> dm_list_iterate_items(sl, &seg_lv(seg, s)->segs_using_this_lv)
# 706| if (sl->seg == seg)
# 707| seg_found++;
Error: CLANG_WARNING: [#def65]
lvm2-2.03.23-build/LVM2.2.03.23/lib/metadata/vdo_manip.c:286:3: warning[deadcode.DeadStores]: Value stored to 'buf_pos' is never read
# 284| argv[++args] = buf_pos;
# 285| if (vtp->index_memory_size_mb >= 1024)
# 286|-> buf_pos += 1 + dm_snprintf(buf_pos, 30, "--uds-memory-size=%u",
# 287| vtp->index_memory_size_mb / 1024);
# 288| else
Error: CLANG_WARNING: [#def66]
lvm2-2.03.23-build/LVM2.2.03.23/lib/metadata/vdo_manip.c:289:3: warning[deadcode.DeadStores]: Value stored to 'buf_pos' is never read
# 287| vtp->index_memory_size_mb / 1024);
# 288| else
# 289|-> buf_pos += 1 + dm_snprintf(buf_pos, 30, "--uds-memory-size=0.%2u",
# 290| (vtp->index_memory_size_mb < 512) ? 25 :
# 291| (vtp->index_memory_size_mb < 768) ? 50 : 75);
Error: GCC_ANALYZER_WARNING: [#def67]
lvm2-2.03.23-build/LVM2.2.03.23/lib/misc/lvm-exec.c: scope_hint: In function ‘_reopen_fd_to_null’
lvm2-2.03.23-build/LVM2.2.03.23/lib/misc/lvm-exec.c:131:13: warning[-Wanalyzer-fd-use-without-check]: ‘dup2’ on possibly invalid file descriptor ‘fd’
# 129| }
# 130|
# 131|-> if (dup2(null_fd, fd) == -1) {
# 132| log_sys_error("dup2", "");
# 133| goto out;
Error: GCC_ANALYZER_WARNING (CWE-775): [#def68]
lvm2-2.03.23-build/LVM2.2.03.23/lib/misc/lvm-exec.c:156:32: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘pipefd[0]’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:102:26: note: in expansion of macro ‘LOG_LINE’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:112:30: note: in expansion of macro ‘log_notice’
lvm2-2.03.23-build/LVM2.2.03.23/lib/misc/lvm-exec.c:164:9: note: in expansion of macro ‘log_verbose’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/lvm-logging.h:33:45: note: in definition of macro ‘LOG_LINE_WITH_ERRNO’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:122:17: note: in expansion of macro ‘log_err’
lvm2-2.03.23-build/LVM2.2.03.23/lib/misc/lvm-exec.c:167:17: note: in expansion of macro ‘log_sys_error’
# 154| if (!sync_local_dev_names(cmd)) {
# 155| log_error("Failed to sync local device names before forking.");
# 156|-> return 0;
# 157| }
# 158|
Error: GCC_ANALYZER_WARNING (CWE-775): [#def69]
lvm2-2.03.23-build/LVM2.2.03.23/lib/misc/lvm-exec.c: scope_hint: In function ‘pipe_open’
lvm2-2.03.23-build/LVM2.2.03.23/lib/misc/lvm-exec.c:156:32: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘pipefd[1]’
lvm2-2.03.23-build/LVM2.2.03.23/lib/misc/lib.h:30: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/lib/misc/lvm-exec.c:16: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:102:26: note: in expansion of macro ‘LOG_LINE’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:112:30: note: in expansion of macro ‘log_notice’
lvm2-2.03.23-build/LVM2.2.03.23/lib/misc/lvm-exec.c:164:9: note: in expansion of macro ‘log_verbose’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/lvm-logging.h:33:45: note: in definition of macro ‘LOG_LINE_WITH_ERRNO’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:122:17: note: in expansion of macro ‘log_err’
lvm2-2.03.23-build/LVM2.2.03.23/lib/misc/lvm-exec.c:167:17: note: in expansion of macro ‘log_sys_error’
# 154| if (!sync_local_dev_names(cmd)) {
# 155| log_error("Failed to sync local device names before forking.");
# 156|-> return 0;
# 157| }
# 158|
Error: GCC_ANALYZER_WARNING: [#def70]
lvm2-2.03.23-build/LVM2.2.03.23/lib/misc/lvm-exec.c:179:26: warning[-Wanalyzer-fd-use-without-check]: ‘dup2’ on possibly invalid file descriptor ‘1’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:102:26: note: in expansion of macro ‘LOG_LINE’
lvm2-2.03.23-build/LVM2.2.03.23/lib/log/log.h:112:30: note: in expansion of macro ‘log_notice’
lvm2-2.03.23-build/LVM2.2.03.23/lib/misc/lvm-exec.c:164:9: note: in expansion of macro ‘log_verbose’
# 177| else if (close(STDOUT_FILENO))
# 178| log_sys_error("close", "STDOUT");
# 179|-> else if (dup2(pipefd[1 /*write*/], STDOUT_FILENO) == -1)
# 180| log_sys_error("dup2", "STDOUT");
# 181| else if (close(pipefd[1]))
Error: GCC_ANALYZER_WARNING (CWE-775): [#def71]
lvm2-2.03.23-build/LVM2.2.03.23/libdaemon/server/daemon-server.c: scope_hint: In function ‘_daemonise’
lvm2-2.03.23-build/LVM2.2.03.23/libdaemon/server/daemon-server.c:341:12: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘open("/dev/null", 2)’
# 339|
# 340| sigemptyset(&my_sigset);
# 341|-> if (sigprocmask(SIG_SETMASK, &my_sigset, NULL) < 0) {
# 342| fprintf(stderr, "Unable to restore signals.\n");
# 343| exit(EXIT_FAILURE);
Error: GCC_ANALYZER_WARNING (CWE-775): [#def72]
lvm2-2.03.23-build/LVM2.2.03.23/libdaemon/server/daemon-server.c:347:9: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘open("/dev/null", 2)’
# 345| signal(SIGTERM, &_exit_handler);
# 346|
# 347|-> switch (pid = fork()) {
# 348| case -1:
# 349| perror("fork failed:");
Error: GCC_ANALYZER_WARNING (CWE-775): [#def73]
lvm2-2.03.23-build/LVM2.2.03.23/libdaemon/server/daemon-server.c:378:12: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘open("/dev/null", 2)’
# 376| }
# 377|
# 378|-> if (chdir("/")) {
# 379| perror("Cannot chdir to /");
# 380| exit(1);
Error: GCC_ANALYZER_WARNING (CWE-775): [#def74]
lvm2-2.03.23-build/LVM2.2.03.23/libdaemon/server/daemon-server.c:383:12: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘dup2(open("/dev/null", 2), 0)’
# 381| }
# 382|
# 383|-> if ((dup2(fd, STDIN_FILENO) == -1) ||
# 384| (dup2(fd, STDOUT_FILENO) == -1) ||
# 385| (dup2(fd, STDERR_FILENO) == -1)) {
Error: GCC_ANALYZER_WARNING (CWE-775): [#def75]
lvm2-2.03.23-build/LVM2.2.03.23/libdaemon/server/daemon-server.c:383:12: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘open("/dev/null", 2)’
# 381| }
# 382|
# 383|-> if ((dup2(fd, STDIN_FILENO) == -1) ||
# 384| (dup2(fd, STDOUT_FILENO) == -1) ||
# 385| (dup2(fd, STDERR_FILENO) == -1)) {
Error: GCC_ANALYZER_WARNING (CWE-775): [#def76]
lvm2-2.03.23-build/LVM2.2.03.23/libdaemon/server/daemon-server.c:383:44: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘dup2(open("/dev/null", 2), 1)’
# 381| }
# 382|
# 383|-> if ((dup2(fd, STDIN_FILENO) == -1) ||
# 384| (dup2(fd, STDOUT_FILENO) == -1) ||
# 385| (dup2(fd, STDERR_FILENO) == -1)) {
Error: GCC_ANALYZER_WARNING (CWE-775): [#def77]
lvm2-2.03.23-build/LVM2.2.03.23/libdaemon/server/daemon-server.c:383:44: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘open("/dev/null", 2)’
# 381| }
# 382|
# 383|-> if ((dup2(fd, STDIN_FILENO) == -1) ||
# 384| (dup2(fd, STDOUT_FILENO) == -1) ||
# 385| (dup2(fd, STDERR_FILENO) == -1)) {
Error: GCC_ANALYZER_WARNING (CWE-775): [#def78]
lvm2-2.03.23-build/LVM2.2.03.23/libdaemon/server/daemon-server.c:384:45: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘dup2(open("/dev/null", 2), 2)’
# 382|
# 383| if ((dup2(fd, STDIN_FILENO) == -1) ||
# 384|-> (dup2(fd, STDOUT_FILENO) == -1) ||
# 385| (dup2(fd, STDERR_FILENO) == -1)) {
# 386| perror("Error setting terminal FDs to /dev/null");
Error: GCC_ANALYZER_WARNING (CWE-775): [#def79]
lvm2-2.03.23-build/LVM2.2.03.23/libdaemon/server/daemon-server.c:384:45: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘open("/dev/null", 2)’
# 382|
# 383| if ((dup2(fd, STDIN_FILENO) == -1) ||
# 384|-> (dup2(fd, STDOUT_FILENO) == -1) ||
# 385| (dup2(fd, STDERR_FILENO) == -1)) {
# 386| perror("Error setting terminal FDs to /dev/null");
Error: GCC_ANALYZER_WARNING (CWE-775): [#def80]
lvm2-2.03.23-build/LVM2.2.03.23/libdaemon/server/daemon-server.c:390:12: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘open("/dev/null", 2)’
# 388| }
# 389|
# 390|-> if ((fd > STDERR_FILENO) && close(fd)) {
# 391| perror("Failed to close /dev/null descriptor");
# 392| exit(3);
Error: GCC_ANALYZER_WARNING (CWE-775): [#def81]
lvm2-2.03.23-build/LVM2.2.03.23/libdm/dm-tools/dmfilemapd.c: scope_hint: In function ‘_daemonise’
lvm2-2.03.23-build/LVM2.2.03.23/libdm/dm-tools/dmfilemapd.c:661:20: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘dup2(open("/dev/null", 2), 0)’
# 659| }
# 660|
# 661|-> if ((dup2(fd, STDIN_FILENO) == -1) ||
# 662| (dup2(fd, STDOUT_FILENO) == -1) ||
# 663| (dup2(fd, STDERR_FILENO) == -1)) {
Error: GCC_ANALYZER_WARNING (CWE-775): [#def82]
lvm2-2.03.23-build/LVM2.2.03.23/libdm/dm-tools/dmfilemapd.c:661:52: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘dup2(open("/dev/null", 2), 1)’
# 659| }
# 660|
# 661|-> if ((dup2(fd, STDIN_FILENO) == -1) ||
# 662| (dup2(fd, STDOUT_FILENO) == -1) ||
# 663| (dup2(fd, STDERR_FILENO) == -1)) {
Error: GCC_ANALYZER_WARNING (CWE-775): [#def83]
lvm2-2.03.23-build/LVM2.2.03.23/libdm/dm-tools/dmfilemapd.c:662:53: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘dup2(open("/dev/null", 2), 2)’
# 660|
# 661| if ((dup2(fd, STDIN_FILENO) == -1) ||
# 662|-> (dup2(fd, STDOUT_FILENO) == -1) ||
# 663| (dup2(fd, STDERR_FILENO) == -1)) {
# 664| if (fd > STDERR_FILENO)
Error: GCC_ANALYZER_WARNING (CWE-775): [#def84]
lvm2-2.03.23-build/LVM2.2.03.23/libdm/dm-tools/dmfilemapd.c:664:28: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘open("/dev/null", 2)’
# 662| (dup2(fd, STDOUT_FILENO) == -1) ||
# 663| (dup2(fd, STDERR_FILENO) == -1)) {
# 664|-> if (fd > STDERR_FILENO)
# 665| (void) close(fd);
# 666| _early_log("Error redirecting stdin/out/err to null.");
Error: GCC_ANALYZER_WARNING (CWE-775): [#def85]
lvm2-2.03.23-build/LVM2.2.03.23/libdm/dm-tools/dmfilemapd.c:670:20: warning[-Wanalyzer-fd-leak]: leak of file descriptor ‘open("/dev/null", 2)’
# 668| return 0;
# 669| }
# 670|-> if (fd > STDERR_FILENO)
# 671| (void) close(fd);
# 672| }
Error: CLANG_WARNING: [#def86]
lvm2-2.03.23-build/LVM2.2.03.23/libdm/dm-tools/dmsetup.c:566:3: warning[unix.Malloc]: Argument to free() is the address of a global variable, which is not memory allocated by malloc()
# 564| */
# 565| if (!strcmp(split_name->subsystem, "LVM"))
# 566|-> free(split_name->vg_name);
# 567|
# 568| free(split_name->subsystem);
Error: GCC_ANALYZER_WARNING (CWE-590): [#def87]
lvm2-2.03.23-build/LVM2.2.03.23/libdm/dm-tools/dmsetup.c: scope_hint: In function ‘_destroy_split_name’
lvm2-2.03.23-build/LVM2.2.03.23/libdm/dm-tools/dmsetup.c:566:17: warning[-Wanalyzer-free-of-non-heap]: ‘free’ of ‘""’ which points to memory not on the heap
# 564| */
# 565| if (!strcmp(split_name->subsystem, "LVM"))
# 566|-> free(split_name->vg_name);
# 567|
# 568| free(split_name->subsystem);
Error: CLANG_WARNING: [#def88]
lvm2-2.03.23-build/LVM2.2.03.23/libdm/dm-tools/dmsetup.c:5506:2: warning[deadcode.DeadStores]: Value stored to 'fd' is never read
# 5504| log_sys_debug("close", abspath);
# 5505|
# 5506|-> fd = -1;
# 5507|
# 5508| for (region = regions; *region != DM_STATS_REGIONS_ALL; region++)
Error: COMPILER_WARNING: [#def89]
lvm2-2.03.23-build/LVM2.2.03.23/libdm/ioctl/libdm-iface.c: scope_hint: In function ‘dm_task_run_v1_02_197’
lvm2-2.03.23-build/LVM2.2.03.23/libdm/ioctl/libdm-iface.c:1131:25: warning[-Wstringop-truncation]: ‘strncpy’ specified bound 128 equals destination size
# 1131 | strncpy(buf, names->name, len);
# | ^
# 1129| names = (struct dm_names *)((char *) names + next);
# 1130| if (names->dev == dev) {
# 1131|-> strncpy(buf, names->name, len);
# 1132| r = 1;
# 1133| break;
Error: COMPILER_WARNING: [#def90]
lvm2-2.03.23-build/LVM2.2.03.23/libdm/ioctl/libdm-iface.c:1286:17: warning[-Wstringop-truncation]: ‘strncpy’ specified bound 128 equals destination size
# 1286 | strncpy(dmi->name, DEV_NAME(dmt), sizeof(dmi->name));
# | ^
# 1284| * passed dev_name is useful for better error/debug messages */
# 1285| /* coverity[buffer_size_warning] */
# 1286|-> strncpy(dmi->name, DEV_NAME(dmt), sizeof(dmi->name));
# 1287|
# 1288| if (DEV_UUID(dmt))
Error: COMPILER_WARNING: [#def91]
lvm2-2.03.23-build/LVM2.2.03.23/libdm/ioctl/libdm-iface.c:1290:17: warning[-Wstringop-truncation]: ‘strncpy’ specified bound 129 equals destination size
# 1290 | strncpy(dmi->uuid, DEV_UUID(dmt), sizeof(dmi->uuid));
# | ^
# 1288| if (DEV_UUID(dmt))
# 1289| /* coverity[buffer_size_warning] */
# 1290|-> strncpy(dmi->uuid, DEV_UUID(dmt), sizeof(dmi->uuid));
# 1291|
# 1292| if (dmt->type == DM_DEVICE_SUSPEND)
Error: COMPILER_WARNING: [#def92]
lvm2-2.03.23-build/LVM2.2.03.23/libdm/libdm-deptree.c: scope_hint: In function ‘dm_tree_find_node_by_uuid’
lvm2-2.03.23-build/LVM2.2.03.23/libdm/libdm-deptree.c:577:32: warning[-Wstringop-truncation]: ‘strncpy’ specified bound 129 equals destination size
# 577 | (void) strncpy(uuid_without_suffix, uuid, sizeof(uuid_without_suffix));
# | ^
# 575| continue;
# 576|
# 577|-> (void) strncpy(uuid_without_suffix, uuid, sizeof(uuid_without_suffix));
# 578| uuid_without_suffix[suffix_position - uuid] = '\0';
# 579|
Error: CLANG_WARNING: [#def93]
lvm2-2.03.23-build/LVM2.2.03.23/libdm/libdm-stats.c:3429:3: warning[deadcode.DeadStores]: Value stored to 'area_id' is never read
# 3427| /* group aggregation */
# 3428| group_id = region_id;
# 3429|-> area_id = DM_STATS_WALK_GROUP;
# 3430| if (!_stats_group_id_present(dms, group_id))
# 3431| return_NULL;
Error: CLANG_WARNING: [#def94]
lvm2-2.03.23-build/LVM2.2.03.23/libdm/libdm-stats.c:4439:4: warning[deadcode.DeadStores]: Value stored to 'expected' is never read
# 4437| ext_copy(fm_pending, fm_ext + i);
# 4438| } else {
# 4439|-> expected = 0;
# 4440| /* Begin a new pending extent for extent 0. If there is
# 4441| * a hole at the start of the file, the first allocated
Error: CLANG_WARNING: [#def95]
lvm2-2.03.23-build/LVM2.2.03.23/libdm/libdm-stats.c:4784:11: warning[core.NullDereference]: Dereference of null pointer
# 4782| if ((old_ext = _find_extent((uint64_t) nr_kept,
# 4783| old_extents,
# 4784|-> extents[i].start,
# 4785| extents[i].len))) {
# 4786| regions[i] = old_ext->id;
Error: CLANG_WARNING: [#def96]
lvm2-2.03.23-build/LVM2.2.03.23/libdm/regex/ttree.c:99:13: warning[core.NullDereference]: Access to field 'data' results in a dereference of a null pointer
# 97| }
# 98| }
# 99|-> (*c)->data = data;
# 100|
# 101| return 1;
Error: COMPILER_WARNING (CWE-9001): [#def97]
lvm2-2.03.23-build/LVM2.2.03.23/test/lib/brick-shelltest.h:888:8: warning[-Winline]: inlining failed in call to ‘brick::shelltest::TestCase::TestCase(brick::shelltest::TestCase const&)’: --param max-inline-insns-single limit reached
# 888 | struct TestCase {
# | ^~~~~~~~
/usr/include/c++/14/x86_64-redhat-linux/bits/c++allocator.h:33: included_from: Included from here.
/usr/include/c++/14/bits/allocator.h:46: included_from: Included from here.
/usr/include/c++/14/vector:63: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/test/lib/brick-shelltest.h:56: included_from: Included from here.
/usr/include/c++/14/bits/new_allocator.h:191:11: note: called from here
# 191 | { ::new((void *)__p) _Up(std::forward<_Args>(__args)...); }
# | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# 886| };
# 887|
# 888|-> struct TestCase {
# 889| TestProcess child;
# 890| std::string name, flavour;
Error: CLANG_WARNING: [#def98]
lvm2-2.03.23-build/LVM2.2.03.23/tools/command.c:2607:5: warning[deadcode.DeadStores]: Value stored to 'need_ro_indent_end' is never read
# 2605| if ((cmd->ro_count > 2) && (sep == 2)) {
# 2606| printf("\n.RS 5\n");
# 2607|-> need_ro_indent_end = 1;
# 2608| }
# 2609|
Error: CLANG_WARNING: [#def99]
lvm2-2.03.23-build/LVM2.2.03.23/tools/lvconvert.c:4395:9: warning[deadcode.DeadStores]: Although the value stored to 'dev_fast' is used in the enclosing expression, the value is never actually read from 'dev_fast'
# 4393| }
# 4394|
# 4395|-> if (!(dev_fast = dev_cache_get(cmd, device_name, cmd->filter))) {
# 4396| log_error("Device %s not found.", device_name);
# 4397| return 0;
Error: CLANG_WARNING: [#def100]
lvm2-2.03.23-build/LVM2.2.03.23/tools/lvconvert.c:6366:8: warning[deadcode.DeadStores]: Although the value stored to 'lv_wcorig' is used in the enclosing expression, the value is never actually read from 'lv_wcorig'
# 6364| */
# 6365|
# 6366|-> if (!(lv_wcorig = _lv_writecache_create(cmd, lv_update, lv_fast, block_size_sectors, &settings)))
# 6367| goto_bad;
# 6368|
Error: CLANG_WARNING: [#def101]
lvm2-2.03.23-build/LVM2.2.03.23/tools/pvck.c:530:3: warning[deadcode.DeadStores]: Value stored to 'p' is never read
# 528| memset(line, 0, sizeof(line));
# 529| _copy_line(p, line, &len, sizeof(line)-1);
# 530|-> p += len;
# 531|
# 532| if (strncmp(line, "seqno = ", 8)) {
Error: GCC_ANALYZER_WARNING (CWE-122): [#def102]
lvm2-2.03.23-build/LVM2.2.03.23/tools/pvck.c: scope_hint: In function ‘_check_metadata_file’
lvm2-2.03.23-build/LVM2.2.03.23/tools/pvck.c:2921:21: warning[-Wanalyzer-out-of-bounds]: heap-based buffer over-read
lvm2-2.03.23-build/LVM2.2.03.23/device_mapper/all.h:27: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/tools/tool.h:22: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/tools/tools.h:19: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/tools/pvck.c:17: included_from: Included from here.
lvm2-2.03.23-build/LVM2.2.03.23/tools/tools.h:54: included_from: Included from here.
# └─────────────────┘
# ^
# 2919| if (text_buf[text_size-1] != '\0' ||
# 2920| text_buf[text_size-2] != '\n' ||
# 2921|-> text_buf[text_size-3] != '\n')
# 2922| log_warn("WARNING: unexpected final bytes of raw metadata, expected \\n\\n\\0.");
# 2923|
Error: CLANG_WARNING: [#def103]
lvm2-2.03.23-build/LVM2.2.03.23/tools/pvscan.c:977:25: warning[core.NonNullParamChecker]: Null pointer passed to 1st parameter expecting 'nonnull'
# 975| online_pvid_file_read(path, &major, &minor, file_vgname, file_devname);
# 976|
# 977|-> if (file_vgname[0] && strcmp(vg->name, file_vgname)) {
# 978| log_warn("WARNING: VG %s PV %s wrong vgname in online file %s",
# 979| vg->name, pvid, file_vgname);
Error: CLANG_WARNING: [#def104]
lvm2-2.03.23-build/LVM2.2.03.23/tools/pvscan.c:1167:4: warning[deadcode.DeadStores]: Value stored to 'vg_complete' is never read
# 1165| pvs_offline = 0;
# 1166| pvs_unknown = 0;
# 1167|-> vg_complete = 0;
# 1168|
# 1169| if (vg) {
Error: CLANG_WARNING: [#def105]
lvm2-2.03.23-build/LVM2.2.03.23/tools/toollib.c:4386:20: warning[core.NullDereference]: Access to field 'name' results in a dereference of a null pointer (loaded from variable 'vg')
# 4384| }
# 4385|
# 4386|-> if (!is_orphan_vg(vg->name))
# 4387| log_set_report_object_group_and_group_id(vg->name, vg_uuid);
# 4388|
Error: GCC_ANALYZER_WARNING (CWE-401): [#def106]
lvm2-2.03.23-build/LVM2.2.03.23/tools/vgcfgbackup.c: scope_hint: In function ‘_vg_backup_single’
lvm2-2.03.23-build/LVM2.2.03.23/tools/vgcfgbackup.c:67:20: warning[-Wanalyzer-malloc-leak]: leak of ‘_expand_filename(arg_value(cmd, 192), *vg.name, last_filename)’
# 65| return_ECMD_FAILED;
# 66|
# 67|-> if (!backup_to_file(filename, vg->cmd->cmd_line, vg))
# 68| return_ECMD_FAILED;
# 69| } else {
Error: CLANG_WARNING: [#def107]
lvm2-2.03.23-build/LVM2.2.03.23/tools/vgchange.c:1130:10: warning[core.NonNullParamChecker]: Null pointer passed to 1st parameter expecting 'nonnull'
# 1128| lv_lock_count++;
# 1129|
# 1130|-> if (!strcmp(lock_type, "dlm"))
# 1131| lv->lock_args = "dlm";
# 1132| }
Error: CLANG_WARNING: [#def108]
lvm2-2.03.23-build/LVM2.2.03.23/tools/vgchange.c:1140:8: warning[core.NonNullParamChecker]: Null pointer passed to 1st parameter expecting 'nonnull'
# 1138| * the lock_args during stage 1.
# 1139| */
# 1140|-> if (!strcmp(lock_type, "sanlock"))
# 1141| vg->skip_validate_lock_args = 1;
# 1142|
Error: GCC_ANALYZER_WARNING (CWE-401): [#def109]
lvm2-2.03.23-build/LVM2.2.03.23/tools/vgimportclone.c: scope_hint: In function ‘_get_other_devs’
lvm2-2.03.23-build/LVM2.2.03.23/tools/vgimportclone.c:191:17: warning[-Wanalyzer-malloc-leak]: leak of ‘calloc(1, 24)’
lvm2-2.03.23-build/LVM2.2.03.23/tools/vgimportclone.c: scope_hint: In function ‘_get_other_devs’
# 189| }
# 190| devl->dev = dev;
# 191|-> dm_list_add(other_devs, &devl->list);
# 192| }
# 193| bad:
Error: GCC_ANALYZER_WARNING (CWE-401): [#def110]
lvm2-2.03.23-build/LVM2.2.03.23/tools/vgimportclone.c: scope_hint: In function ‘vgimportclone’
lvm2-2.03.23-build/LVM2.2.03.23/tools/vgimportclone.c:274:17: warning[-Wanalyzer-malloc-leak]: leak of ‘calloc(1, 24)’
lvm2-2.03.23-build/LVM2.2.03.23/tools/vgimportclone.c: scope_hint: In function ‘vgimportclone’
# 272|
# 273| devl->dev = dev;
# 274|-> dm_list_add(&vp.new_devs, &devl->list);
# 275| }
# 276|
Error: CLANG_WARNING: [#def111]
lvm2-2.03.23-build/LVM2.2.03.23/tools/vgsplit.c:565:8: warning[deadcode.DeadStores]: Although the value stored to 'vginfo_to' is used in the enclosing expression, the value is never actually read from 'vginfo_to'
# 563| return_ECMD_FAILED;
# 564|
# 565|-> if (!(vginfo_to = lvmcache_vginfo_from_vgname(vg_name_to, NULL))) {
# 566| if (!validate_name(vg_name_to)) {
# 567| log_error("Invalid vg name %s.", vg_name_to);
Scan Properties
analyzer-version-clang | 18.1.7 |
analyzer-version-cppcheck | 2.14.2 |
analyzer-version-gcc | 14.1.1 |
analyzer-version-gcc-analyzer | 14.1.1 |
analyzer-version-shellcheck | 0.10.0 |
enabled-plugins | clang, cppcheck, gcc, shellcheck |
exit-code | 0 |
host | ip-172-16-1-213.us-west-2.compute.internal |
mock-config | fedora-41-x86_64 |
project-name | lvm2-2.03.23-1.fc40 |
store-results-to | /tmp/tmpovaqkw0p/lvm2-2.03.23-1.fc40.tar.xz |
time-created | 2024-07-03 16:07:54 |
time-finished | 2024-07-03 16:13:29 |
tool | csmock |
tool-args | '/usr/bin/csmock' '-r' 'fedora-41-x86_64' '-t' 'cppcheck,gcc,clang,shellcheck' '-o' '/tmp/tmpovaqkw0p/lvm2-2.03.23-1.fc40.tar.xz' '--gcc-analyze' '/tmp/tmpovaqkw0p/lvm2-2.03.23-1.fc40.src.rpm' |
tool-version | csmock-3.5.3-1.el9 |