1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-04 09:18:36 +03:00

activation: _lv_active returns 0 on error

We have only 2 users of _lv_active() - one was already checking for ==1
while the other use (_lv_is_active()) could have take '-1' as a sign of having
an LV active. So return 0 and log_debug also the reason while detection
has failed (i.e. in case  --driverload n  - it's kind of expectable,
but might have confused user seeing just <backtrace>).
This commit is contained in:
Zdenek Kabelac 2016-06-22 23:04:53 +02:00
parent af36f5ad36
commit eb51be4fbe
2 changed files with 5 additions and 2 deletions

View File

@ -1,5 +1,6 @@
Version 2.02.158 - Version 2.02.158 -
================================= =================================
Rerurn 0 (inactive) when status cannot be queried in _lv_active().
Switch to log_warn() for failing activation status query. Switch to log_warn() for failing activation status query.
Refactor lvconvert argument handling code. Refactor lvconvert argument handling code.
Add --logonly option to report only cmd log for a command, not other reports. Add --logonly option to report only cmd log for a command, not other reports.

View File

@ -1266,8 +1266,10 @@ static int _lv_active(struct cmd_context *cmd, const struct logical_volume *lv)
struct lvinfo info; struct lvinfo info;
if (!lv_info(cmd, lv, 0, &info, 0, 0)) { if (!lv_info(cmd, lv, 0, &info, 0, 0)) {
stack; log_debug("Cannot determine activation status of %s%s.",
return -1; display_lvname(lv),
activation() ? "" : " (no device driver)");
return 0;
} }
return info.exists; return info.exists;