]> sourceware.org Git - lvm2.git/log
lvm2.git
8 years agoreport: add full_descendants field to display descendants with history
Peter Rajnoha [Tue, 1 Mar 2016 14:24:48 +0000 (15:24 +0100)]
report: add full_descendants field to display descendants with history

Same as lv_full_ancestors, but the other way round in the ancestry chain.

8 years agoreport: add full_ancestors field to display ancestors with history
Peter Rajnoha [Tue, 1 Mar 2016 14:24:40 +0000 (15:24 +0100)]
report: add full_ancestors field to display ancestors with history

The lv_full_ancestors reporting field is just like the existing
lv_ancestors field but it also takes into account any history and
indirect relations recorded.

8 years agoreport: report historical LV names with '-' prefix
Peter Rajnoha [Tue, 1 Mar 2016 14:24:07 +0000 (15:24 +0100)]
report: report historical LV names with '-' prefix

All names for historical LVs are prefixed with '-' character to make clear
difference between live and historical LVs. The '-' can't be set by users
for live LV names during lvcreate hence we never get into a conflict with
the names that user defines for live LVs.

8 years agoreport: display (h)istorical state in lv_attr field
Peter Rajnoha [Tue, 1 Mar 2016 14:23:58 +0000 (15:23 +0100)]
report: display (h)istorical state in lv_attr field

The 'historical' state is displayed as 5th bit ("state") in the lv_attr
field and denoted by new 'h' character.

8 years agoreport: add lv_historical field to identify historical LVs
Peter Rajnoha [Tue, 1 Mar 2016 14:23:43 +0000 (15:23 +0100)]
report: add lv_historical field to identify historical LVs

The lv_historical reporting field is a simple binary field that reports
whether an LV is historical one ("historical" value or value of "1" displayed)
or not (blank string "" or value of "0" displayed).

8 years agocommands: lvs: recognize -H|--history switch
Peter Rajnoha [Tue, 1 Mar 2016 14:23:34 +0000 (15:23 +0100)]
commands: lvs: recognize -H|--history switch

When lvs command is used together with the -H|--history switch,
all historical LVs are reported as well.

8 years agoreport: display lv_name,lv_uuid,vg_name,lv_time and new lv_time_removed for historica...
Peter Rajnoha [Tue, 1 Mar 2016 14:23:23 +0000 (15:23 +0100)]
report: display lv_name,lv_uuid,vg_name,lv_time and new lv_time_removed for historical LVs

8 years agotoollib: honour '-H|--history' switch while executing process_each_lv_in_vg
Peter Rajnoha [Tue, 1 Mar 2016 14:23:05 +0000 (15:23 +0100)]
toollib: honour '-H|--history' switch while executing process_each_lv_in_vg

When processing LVs in a VG and when the -H|--history switch is used,
make process_each_lv_in_vg to iterate over historical volumes too.

For each historical LV, we use dummy struct logical_volume instance with
the "this_glv" reference set to a wrapper over proper struct
historical_logical_volume representation. This makes it possible to process
historical LVs just like normal live LVs (though a dummy one without any
segments and all the other fields zeroed and blank) and it also allows
for using all historical LV related information via lv->this_glv->historical
reference.

One can use a simple call to lv_is_historical to make a difference between
live and historical LV in all the code that is called by process_each_* fns.

8 years agocmd: add '-H|--history' switch and wire it up in cmd_context and processing_handle
Peter Rajnoha [Tue, 1 Mar 2016 14:22:48 +0000 (15:22 +0100)]
cmd: add '-H|--history' switch and wire it up in cmd_context and processing_handle

This patch adds "include_historical_lvs" field to struct cmd_context to
make it possible for the command to switch between original funcionality
where no historical LVs are processed and functionality where historical
LVs are taken into account (and reported or processed further). The switch
between these modes is done using the '-H|--history' switch on command
line.

The include_historical_lvs state is then passed to process_each_* fns
using the "include_historical_lvs" field within struct processing_handle.

8 years agometadata: add lv_is_historical fn to test if the LV is historical one
Peter Rajnoha [Tue, 1 Mar 2016 14:22:36 +0000 (15:22 +0100)]
metadata: add lv_is_historical fn to test if the LV is historical one

8 years agometadata: format_text: interconnect historical LVs among each other and also with...
Peter Rajnoha [Tue, 1 Mar 2016 14:22:28 +0000 (15:22 +0100)]
metadata: format_text: interconnect historical LVs among each other and also with live LVs

Interconnect historical LVs in an ancestry chain and also connect the first/last
one with its live ancestor/descendant if it exists.

8 years agometadata: add support for interconnection of thin pool LV segment with indirect origin
Peter Rajnoha [Tue, 1 Mar 2016 14:21:36 +0000 (15:21 +0100)]
metadata: add support for interconnection of thin pool LV segment with indirect origin

Add support for making an interconnection between thin LV segment and
its indirect origin (which may be historical or live LV) - add a new
"indirect_origin" argument to attach_pool_lv function.

8 years agometadata: add find_historical_glv fn
Peter Rajnoha [Tue, 1 Mar 2016 14:21:21 +0000 (15:21 +0100)]
metadata: add find_historical_glv fn

The find_historical_glv is helper function that looks up historical
LV in struct volume_group's historical_lvs list and returns it if
found.

8 years agometadata: format_text: import historical LVs
Peter Rajnoha [Tue, 1 Mar 2016 14:54:02 +0000 (15:54 +0100)]
metadata: format_text: import historical LVs

Import historical LV list from metadata and add it to struct
volume_group's historical_lvs list.

8 years agometadata: format_text: reuse _print_timestamp fn
Peter Rajnoha [Tue, 1 Mar 2016 14:21:05 +0000 (15:21 +0100)]
metadata: format_text: reuse _print_timestamp fn

8 years agometadata: format_text: also export historical LVs
Peter Rajnoha [Tue, 1 Mar 2016 14:20:49 +0000 (15:20 +0100)]
metadata: format_text: also export historical LVs

Also export historical LVs when exporting LVM2 metadata.
This is list of all historical LVs listed in
"historical_logical_volumes" metadata section with all
the properties exported for each historical LV.

For example, we have this thin snapshot sequence:

  lvol1 --> lvol2 --> lvol3
                 \
                  --> lvol4

We end up with these metadata:

logical_volume {
  ...
  (lvol1, lvol3 and lvol4 listed here as usual - no change here)
  ...
}

historical_logical_volumes {
  lvol2 {
    id = "S0Dw1U-v5sF-LwAb-W9SI-pNOF-Madd-5dxSv5"
    creation_time = 1456919613      # 2016-03-02 12:53:33 +0100
    removal_time = 1456919620       # 2016-03-02 12:53:40 +0100
    origin = "lvol1"
    descendants = ["lvol3", "lvol4"]
  }
}

By removing lvol1 further, we end up with:

historical_logical_volumes {
  lvol2 {
    id = "S0Dw1U-v5sF-LwAb-W9SI-pNOF-Madd-5dxSv5"
    creation_time = 1456919613      # 2016-03-02 12:53:33 +0100
    removal_time = 1456919620       # 2016-03-02 12:53:40 +0100
    origin = "-lvol1"
    descendants = ["lvol3", "lvol4"]
  }

  lvol1 {
    id = "me0mes-aYnK-nRfT-vNlV-UiR1-GP7r-ojbROr"
    creation_time = 1456919608      # 2016-03-02 12:53:28 +0100
    removal_time = 1456919767       # 2016-03-02 12:56:07 +0100
  }
}

8 years agometadata: create historical LVs when LVs are removed and interconnect with live LVs
Peter Rajnoha [Tue, 1 Mar 2016 14:20:09 +0000 (15:20 +0100)]
metadata: create historical LVs when LVs are removed and interconnect with live LVs

When an LV is being removed, we create an instance of
"struct historical_logical_volume" wrapped up in
"struct generic_logical_volume".

All instances of "struct historical_logical_volume" are then recorded in
"historical_lvs" list which is part of "struct volume_group".

The "historical LV" is then interconnected with "live LVs" to
connect a history chain for the live LV.

8 years agometadata: add add_glv_to_indirect_glvs and remove_glv_from_indirect_glvs
Peter Rajnoha [Tue, 1 Mar 2016 14:19:57 +0000 (15:19 +0100)]
metadata: add add_glv_to_indirect_glvs and remove_glv_from_indirect_glvs

The add_glv_to_indirect_glvs is a helper function that registers a
volume represented by struct generic_logical_volume instance ("glv")
as an indirect user of another volume ("origin_glv") and vice versa -
it also registers the other volume ("origin_glv") as indirect_origin
of user volume ("glv").

The remove_glv_from_indirect_glvs does the opposite.

8 years agometadata: add get_or_create_glv and get_or_create_glvl
Peter Rajnoha [Tue, 1 Mar 2016 14:19:23 +0000 (15:19 +0100)]
metadata: add get_or_create_glv and get_or_create_glvl

The get_or_create_glv is helper function that retrieves any existing
generic_logical_volume wrapper for the LV. If the wrapper does not exist
yet, it's created.

The get_org_create_glvl is the same as get_or_create_glv but it creates
the glv_list wrapper in addition so it can be added to a list.

8 years agometadata: add infrastructure to track LV history
Peter Rajnoha [Tue, 1 Mar 2016 14:18:42 +0000 (15:18 +0100)]
metadata: add infrastructure to track LV history

Add new structures and new fields in existing structures to support
tracking history of LVs (the LVs which don't exist - the have been
removed already):

  - new "struct historical_logical_volume"
    This structure keeps information specific to historical LVs
    (historical LV is very reduced form of struct logical_volume +
     it contains a few specific fields to track historical LV
     properties like removal time and connections among other LVs).

  - new "struct generic_logical_volume"
    Wrapper for "struct historical_logical_volume" and
    "struct logical_volume" to make it possible to handle volumes
    in uniform way, no matter if it's live or historical one.

  - new "struct glv_list"
    Wrapper for "struct generic_logical_volume" so it can be
    added to a list.

  - new "indirect_glvs" field in "struct logical_volume"
    List that stores references to all indirect users of this LV - this
    interconnects live LV with historical descendant LVs or even live
    descendant LVs.

  - new "indirect_origin" field in "struct lv_segment"
    Reference to indirect origin of this segment - this interconnects
    live LV (segment) with historical ancestor.

  - new "this_glv" field in "struct logical_volume"
    This references an existing generic_logical_volume wrapper for this
    LV, if used. It can be NULL if not needed - which means we're not
    handling historical LVs at all.

  - new "historical_lvs" field in "struct volume group
    List of all historical LVs read from VG metadata.

8 years agotests: drop check for md5sum
Zdenek Kabelac [Wed, 2 Mar 2016 10:12:00 +0000 (11:12 +0100)]
tests: drop check for md5sum

8 years agotests: check kernel_cache_ funcs
Zdenek Kabelac [Wed, 2 Mar 2016 10:12:14 +0000 (11:12 +0100)]
tests: check kernel_cache_ funcs

8 years agocleanup: use lv_is_partial
Zdenek Kabelac [Wed, 2 Mar 2016 19:59:03 +0000 (20:59 +0100)]
cleanup: use lv_is_partial

Check for PARTIAL_LV flag in standard way.

8 years agocleanup: use _field_string
Zdenek Kabelac [Wed, 2 Mar 2016 10:50:12 +0000 (11:50 +0100)]
cleanup: use _field_string

Make at least some 'advantage' in use local func and do dereference
internally from char pointer and use short list of params.

8 years agoman: minor updates
Zdenek Kabelac [Wed, 2 Mar 2016 22:51:59 +0000 (23:51 +0100)]
man: minor updates

Minor fixes in few pages.

8 years agoman: lvconvert updates
Zdenek Kabelac [Wed, 2 Mar 2016 22:51:16 +0000 (23:51 +0100)]
man: lvconvert updates

Improving style (following lvcreate way).
Sorting options alphabetically.

8 years agocache: add kernel_cache_policy option
Zdenek Kabelac [Wed, 2 Mar 2016 10:12:46 +0000 (11:12 +0100)]
cache: add kernel_cache_policy option

Pair kernel_cache_settings with kernel_cache_policy.
There is very small chance in error case that the value in table
might be differnet from the value stored in metadata
so make it 'checkable'.

8 years agoWHATS_NEW: [unknown] replaces 'unknown device'
David Teigland [Tue, 1 Mar 2016 17:16:35 +0000 (11:16 -0600)]
WHATS_NEW: [unknown] replaces 'unknown device'

8 years agopvs: replace 'unknown device' with [unknown]
David Teigland [Mon, 29 Feb 2016 19:38:31 +0000 (13:38 -0600)]
pvs: replace 'unknown device' with [unknown]

A config setting can restore the old string.

8 years agocleanup: missplaced .
Zdenek Kabelac [Tue, 1 Mar 2016 16:20:47 +0000 (17:20 +0100)]
cleanup: missplaced .

Remove misplaced '.' after '?'
Drop extra   'stack;'  after log_debug().

8 years agomakefile: handle dm-version-expected
Zdenek Kabelac [Tue, 1 Mar 2016 15:03:02 +0000 (16:03 +0100)]
makefile: handle dm-version-expected

8 years agoman: fix mising braces
Zdenek Kabelac [Tue, 1 Mar 2016 12:40:32 +0000 (13:40 +0100)]
man: fix mising braces

Fixing some reported issued found by:
http://catb.org/~esr/doclifter/bugs.html

Reported-by: Eric S. Raymond <esr at thyrsus.com>
8 years agocleanup: indent and dots
Zdenek Kabelac [Tue, 1 Mar 2016 10:41:09 +0000 (11:41 +0100)]
cleanup: indent and dots

8 years agocoverity: eliminate DEADCODE
Zdenek Kabelac [Tue, 1 Mar 2016 12:58:15 +0000 (13:58 +0100)]
coverity: eliminate DEADCODE

Coverity notice this cannot be NULL: cur = &dms->regions[*cur_r]
so avoid NULL checking and simplify form.

8 years agocoverity: missing error path
Zdenek Kabelac [Tue, 1 Mar 2016 10:40:53 +0000 (11:40 +0100)]
coverity: missing error path

8 years agoupdate WHATS_NEW
David Teigland [Mon, 29 Feb 2016 19:50:02 +0000 (13:50 -0600)]
update WHATS_NEW

including changes not recorded for the previous release.

8 years agotests: check [unknown] in lvmetad-pvscan-cache
David Teigland [Mon, 29 Feb 2016 18:43:07 +0000 (12:43 -0600)]
tests: check [unknown] in lvmetad-pvscan-cache

Update test for new [unknown] VG name from
commit 250b9153.

8 years agopvs: display VG name [unknown] for used PV without metadata
David Teigland [Fri, 26 Feb 2016 21:06:20 +0000 (15:06 -0600)]
pvs: display VG name [unknown] for used PV without metadata

Rather than displaying a blank field for VG name.

8 years agopost-release
Alasdair G Kergon [Fri, 26 Feb 2016 21:14:12 +0000 (21:14 +0000)]
post-release

8 years agopre-release v2_02_144
Alasdair G Kergon [Fri, 26 Feb 2016 21:03:30 +0000 (21:03 +0000)]
pre-release

8 years agoreport: Shift (u)sed pv_attr under (a)llocatable.
Alasdair G Kergon [Fri, 26 Feb 2016 15:46:37 +0000 (15:46 +0000)]
report: Shift (u)sed pv_attr under (a)llocatable.

Showing 'u' in the pv_attr reporting field is mostly unnecessary because
most PVs are allocatable, and being allocatable implies it is (u)sed,
and this is already obvious from other fields in the default 'pvs'
output like the VG name.

So move the new (u)sed pv_attr from character position 4 to 1, and only
show it in those rare cases when the PV is not (a)llocatable or the
relevant metadata is missing.

(Scripts should not be using pv_attr, but rather pv_allocatable,
pv_exported, pv_missing, pv_in_use etc.)

8 years agotests: skip on older version
Zdenek Kabelac [Fri, 26 Feb 2016 07:45:06 +0000 (08:45 +0100)]
tests: skip on older version

Skip with older driver version.
Update address.

8 years agocoverity: helping coverity with NULL pointer
Zdenek Kabelac [Fri, 26 Feb 2016 09:15:24 +0000 (10:15 +0100)]
coverity: helping coverity with NULL pointer

Helping with understanding we will not try to deref NULL pointer,
as if the sizes are initialized to NULL it also means 'mem' would
be NULL, but thats too hard to model so make it obvious.

8 years agomakefiles: add more dirs for lcov output
Zdenek Kabelac [Fri, 26 Feb 2016 09:14:39 +0000 (10:14 +0100)]
makefiles: add more dirs for lcov output

New daemons were missing in generated lcov output.

8 years agodbus: fix the systemd service providing the DBus service
Vratislav Podzimek [Thu, 25 Feb 2016 15:34:41 +0000 (16:34 +0100)]
dbus: fix the systemd service providing the DBus service

Correct name is lvm2-lvmdbusd.service not lvmdbusd.service.
This makes the bus-activation (auto-activation) work.

Signed-off-by: Vratislav Podzimek <vpodzime@redhat.com>
8 years agopvcreate: fix data alignment error check
David Teigland [Thu, 25 Feb 2016 22:57:01 +0000 (16:57 -0600)]
pvcreate: fix data alignment error check

Make the data_alignment variable 64 bits so it
can hold the invalid command line arg used in
pvreate-usage.sh pvcreate --dataalignment 1e.

On 32 bit arches, the smaller variable wouldn't
hold the invalid value so the error would not
trigger as expected by the test.

8 years agolvmdbusd: Do only 1 refresh for Vg.Change()
Tony Asleson [Thu, 25 Feb 2016 22:34:51 +0000 (16:34 -0600)]
lvmdbusd: Do only 1 refresh for Vg.Change()

Signed-off-by: Tony Asleson <tasleson@redhat.com>
8 years agolvmdbusd testing: Add validatestate.py utility
Tony Asleson [Thu, 25 Feb 2016 22:12:53 +0000 (16:12 -0600)]
lvmdbusd testing: Add validatestate.py utility

This simple tool calls the Manager.Refresh method on the dbus service
to check and see if the dbus service has the most up to date state.
This is to be used for testing to ensure that event driven updates are
working as planned.

Signed-off-by: Tony Asleson <tasleson@redhat.com>
8 years agolvmdbustest.py: Move helper code to testlib.py
Tony Asleson [Thu, 25 Feb 2016 22:11:08 +0000 (16:11 -0600)]
lvmdbustest.py: Move helper code to testlib.py

This will allow us to re-use in other client programs for testing.

Signed-off-by: Tony Asleson <tasleson@redhat.com>
8 years agolvmdbusd: Reduce unnecessary state refreshes
Tony Asleson [Thu, 25 Feb 2016 20:57:12 +0000 (14:57 -0600)]
lvmdbusd: Reduce unnecessary state refreshes

When we use udev or have lvm call back into the dbus service when a
change occurs, even if that change originated from the dbus service
we end up refreshing the state of the system twice which is not
needed or wanted.  This change handles this case by removing any
pending refreshes in the worker queue if the state of the system
was just updated.

Signed-off-by: Tony Asleson <tasleson@redhat.com>
8 years agopvcreate: fix error from pv_write
David Teigland [Thu, 25 Feb 2016 22:38:59 +0000 (16:38 -0600)]
pvcreate: fix error from pv_write

After a pv_write() failure, the PV wasn't being skipped.

8 years agotests: lvresize with zero arg
Zdenek Kabelac [Thu, 25 Feb 2016 20:58:43 +0000 (21:58 +0100)]
tests: lvresize with zero arg

8 years agocleanup: drop unneeded test
Zdenek Kabelac [Thu, 25 Feb 2016 15:51:14 +0000 (16:51 +0100)]
cleanup: drop unneeded test

dmfree tests for NULL

8 years agocleanup: indent
Zdenek Kabelac [Thu, 25 Feb 2016 15:50:22 +0000 (16:50 +0100)]
cleanup: indent

Last update missed to indent params.

8 years agocleanup: poll better check for internal errors
Zdenek Kabelac [Thu, 25 Feb 2016 12:31:31 +0000 (13:31 +0100)]
cleanup: poll better check for internal errors

8 years agolvconvert: use lp->repair
Zdenek Kabelac [Thu, 25 Feb 2016 14:12:17 +0000 (15:12 +0100)]
lvconvert: use lp->repair

Set variable for repair testing.

8 years agolvconvert: use more display_lvname
Zdenek Kabelac [Thu, 25 Feb 2016 14:01:12 +0000 (15:01 +0100)]
lvconvert: use more display_lvname

8 years agolvconvert: simplify handler processing
Zdenek Kabelac [Thu, 25 Feb 2016 11:15:26 +0000 (12:15 +0100)]
lvconvert: simplify handler processing

Easier code for handler init.
Drop release of pool mem - not needed, as command pool get dropped just
later.

8 years agolvconvert: fix vg parameter
Zdenek Kabelac [Thu, 25 Feb 2016 19:40:28 +0000 (20:40 +0100)]
lvconvert: fix vg parameter

Since we want to read env LVM_VG_NAME vg names,
we cannot just check LV names which do contain '/'.

So before the patch commands like:

> lvconvert --repair vg

Before:

Please provide a valid volume group name

After:
Path required for Logical Volume "vg".
Please provide a valid volume group name

> LVM_VG_NAME=vg lvconvert --repair vg

Before:
Please provide a valid volume group name

After:
Can't find LV vg in VG vg

8 years agolvresize: fix regression with zero size arg
Zdenek Kabelac [Thu, 25 Feb 2016 21:44:31 +0000 (22:44 +0100)]
lvresize: fix regression with zero size arg

Commit ca878a3426197b629c76e98cfc049948da470cd7 introduced an issue
that zero sized extesion suddenly started to be accepted and
missed to return error.

Properly check invalid input values for sizes.

8 years agoUse a common message for a used PV
David Teigland [Thu, 25 Feb 2016 20:12:08 +0000 (14:12 -0600)]
Use a common message for a used PV

Change some inconsistent messages and adopt
the new wording "PV %s is used by" in place
of "PV %s is marked as belonging to"
or "PV %s belongs to".

8 years agopvcreate: fix setting uuid arg
David Teigland [Thu, 25 Feb 2016 17:56:24 +0000 (11:56 -0600)]
pvcreate: fix setting uuid arg

Commit 4de6caf5 ("redefine pvcreate structs") left
out setting the "idp" pointer to the "id" arg.

8 years agotests: add simple dmstats report tests dev-bmr-dmstats-tests
Bryn M. Reeves [Thu, 18 Feb 2016 16:52:37 +0000 (16:52 +0000)]
tests: add simple dmstats report tests

Add tests for the "dmstats report" command:

  * report
  * report --count
  * report --histogram

So far the tests just check the command runs as expected when a
correctly configured stats region exists: validation of output
can be added later.

8 years agotests: add dmstats create tests
Bryn M. Reeves [Fri, 11 Dec 2015 17:16:23 +0000 (17:16 +0000)]
tests: add dmstats create tests

Add tests for the "dmstats create" command:

  * simple whole-device region
  * region using --start/--len options
  * region using --segments option
  * region with precise timestamps (--precise)
  * region with histogram bounds (--bounds)

8 years agotests: make lib/expected-version-dm a dependency of .tests-stamp
Bryn M. Reeves [Fri, 11 Dec 2015 13:18:40 +0000 (13:18 +0000)]
tests: make lib/expected-version-dm a dependency of .tests-stamp

8 years agotests: install does not depend on lib/version-expected
Bryn M. Reeves [Fri, 11 Dec 2015 13:17:08 +0000 (13:17 +0000)]
tests: install does not depend on lib/version-expected

The install target already depends on .tests-stamp - since this
in turn depends on lib/version-expected there is no need to have
this as a dependency of install.

8 years agotests: add template tests/shell/dmstats-create.sh
Bryn M. Reeves [Fri, 27 Nov 2015 17:57:33 +0000 (17:57 +0000)]
tests: add template tests/shell/dmstats-create.sh

Add a template for testing 'dmstats create' operations.

8 years agotests: add driver_at_least() to aux.sh
Bryn M. Reeves [Fri, 27 Nov 2015 17:55:08 +0000 (17:55 +0000)]
tests: add driver_at_least() to aux.sh

Add a function to test whether the running device-mapper driver
version is at least equal to some given version.

8 years agotests: add basic dmstats tests
Bryn M. Reeves [Thu, 26 Nov 2015 17:11:40 +0000 (17:11 +0000)]
tests: add basic dmstats tests

Add initial dmstats tests to 000-basic.sh. These tests ensure that
the dmsetup binary is built and linked correctly when called as
'dmstats' and that the version of the binary matches the expected
library version used for the build.

8 years agodmstats: create dmstats symlink in test/lib
Bryn M. Reeves [Thu, 26 Nov 2015 12:37:22 +0000 (12:37 +0000)]
dmstats: create dmstats symlink in test/lib

Create a symbolic link in test/lib for 'dmstats', pointing to the
dmsetup binary in the tools/ build directory.

8 years agolvmcache: fix missing free of vginfo->system_id causing mem leak
Peter Rajnoha [Thu, 25 Feb 2016 15:24:48 +0000 (16:24 +0100)]
lvmcache: fix missing free of vginfo->system_id causing mem leak

8 years agoreplace pvcreate_params with pvcreate_each_params
David Teigland [Thu, 18 Feb 2016 21:38:23 +0000 (15:38 -0600)]
replace pvcreate_params with pvcreate_each_params

"pvcreate_each_params" was a temporary name used
to transition from the old "pvcreate_params".

Remove the old pvcreate_params struct and rename the
new pvcreate_each_params struct to pvcreate_params.
Rename various pvcreate_each_params terms to simply
pvcreate_params.

8 years agoredefine pvcreate structs
David Teigland [Thu, 18 Feb 2016 21:31:27 +0000 (15:31 -0600)]
redefine pvcreate structs

New pv_create_args struct contains all the specific
parameters for creating a PV, independent of the
command.

8 years agometadata: add fixme about code used only by liblvm
David Teigland [Tue, 16 Feb 2016 21:33:40 +0000 (15:33 -0600)]
metadata: add fixme about code used only by liblvm

8 years agopvremove: use common toollib processing code
David Teigland [Tue, 16 Feb 2016 21:00:50 +0000 (15:00 -0600)]
pvremove: use common toollib processing code

Use the new pvcreate_each_device() function from
toollib.

8 years agotoollib: remove unsed pvcreate params function
David Teigland [Tue, 26 Jan 2016 18:04:37 +0000 (12:04 -0600)]
toollib: remove unsed pvcreate params function

which has been replaced by an equivalent pvcreate_each params
function.

8 years agoliblvm: replace pvcreate_single with pvcreate_vol
David Teigland [Tue, 26 Jan 2016 17:50:11 +0000 (11:50 -0600)]
liblvm: replace pvcreate_single with pvcreate_vol

And remove the pvcreate_single wrapper.

8 years agovgcreate: use the common toollib pv create
David Teigland [Tue, 26 Jan 2016 17:34:59 +0000 (11:34 -0600)]
vgcreate: use the common toollib pv create

Use the new pvcreate_each_device() function from
toollib, previously added for pvcreate, in place
of the old pvcreate_vol().

This also requires shifting the location where the
lock is acquired for the new VG name.  The lock for
the new VG is supposed to be acquired before pvcreate.
This means splitting the vg_lock_newname() out of
vg_create(), and calling vg_lock_newname() directly
before pvcreate, and then calling the remainder of
vg_create() after pvcreate.

The new function vg_lock_and_create() now does
vg_lock_newname() + vg_create(), like the previous
version of vg_create().

The lock on the new VG name is released before the
pvcreate and reacquired after the pvcreate because
pvcreate needs to reset lvmcache, which doesn't work
when locks are held.  An exception could likely be
made for the new VG name lock, which would allow
vgcreate to hold the new VG name lock across the
pvcreate step.

8 years agovgextend: use the common toollib pv create
David Teigland [Mon, 15 Feb 2016 20:28:09 +0000 (14:28 -0600)]
vgextend: use the common toollib pv create

8 years agopvcreate: use the common toollib pv create
David Teigland [Mon, 15 Feb 2016 20:09:42 +0000 (14:09 -0600)]
pvcreate: use the common toollib pv create

8 years agotoollib: add two phase pv processing code
David Teigland [Tue, 16 Feb 2016 20:15:24 +0000 (14:15 -0600)]
toollib: add two phase pv processing code

This is common code for handling PV create/remove
that can be shared by pvcreate/vgcreate/vgextend/pvremove.
This does not change any commands to use the new code.

- Pull out the hidden equivalent of process_each_pv
  into an actual top level process_each_pv.

- Pull the prompts to the top level, and do not
  run any prompts while locks are held.
  The orphan lock is reacquired after any prompts are
  done, and the devices being created are checked for
  any change made while the lock was not held.

Previously, pvcreate_vol() was the shared function for
creating a PV for pvcreate, vgcreate, vgextend.
Now, it will be toollib function pvcreate_each_device().

pvcreate_vol() was called effectively as a helper, from
within vgcreate and vgextend code paths.
pvcreate_each_device() will be called at the same level
as other process_each functions.

One of the main problems with pvcreate_vol() is that
it included a hidden equivalent of process_each_pv for
each device being created:

  pvcreate_vol() -> _pvcreate_check() ->

   find_pv_by_name() -> get_pvs() ->

     get_pvs_internal() -> _get_pvs() -> get_vgids() ->

       /* equivalent to process_each_pv */
       dm_list_iterate_items(vgids)
         vg = vg_read_internal()
         dm_list_iterate_items(&vg->pvs)

pvcreate_each_device() reorganizes the code so that
each-VG-each-PV loop is done once, and uses the standard
process_each_pv function at the top level of the function.

8 years agovgconvert: refactor to avoid pvcreate code
David Teigland [Tue, 16 Feb 2016 19:22:50 +0000 (13:22 -0600)]
vgconvert: refactor to avoid pvcreate code

This uses the vg->pv_write_list in place of the
vg->pvs_to_write list, and eliminates the use of
pvcreate_params.  The label remove and zeroing
steps are shifted out of vg_write() to the higher
level like pvcreate will do.

8 years agometadata: use pv_write_list for _check_old_pv_ext_for_vg
David Teigland [Tue, 16 Feb 2016 19:02:00 +0000 (13:02 -0600)]
metadata: use pv_write_list for _check_old_pv_ext_for_vg

The _check_old_pv_ext_for_vg() function only needs to
do pv_write(), so it can use the simpler pv_list structs
on the pv_write_list.

8 years agometadata: refactor part of add_pv_to_vg
David Teigland [Tue, 16 Feb 2016 18:49:57 +0000 (12:49 -0600)]
metadata: refactor part of add_pv_to_vg

This shifts the use of the 'pv_to_write' struct
and the 'pvcreate_params' struct to the one
caller of add_pv_to_vg, which is made static.

8 years agovg_write: add list of pvs to write
David Teigland [Tue, 16 Feb 2016 18:43:24 +0000 (12:43 -0600)]
vg_write: add list of pvs to write

The vg->pv_write_list contains pv_list structs for which
vg_write() should call pv_write().

The new list will replace vg->pvs_to_write that contains
vg_to_create structs which are used to perform higher-level
pvcreate-related operations. The higher level pvcreate
operations will be moved out of vg_write() to higher levels.

8 years agoconfigure
Alasdair G Kergon [Thu, 25 Feb 2016 13:58:48 +0000 (13:58 +0000)]
configure

8 years agoconfigure: require sanlock 3.3.0
David Teigland [Wed, 24 Feb 2016 19:22:23 +0000 (13:22 -0600)]
configure: require sanlock 3.3.0

For a sanlock flag added in that version.

8 years agolvmlockd: use new sanlock flag to avoid blocking
David Teigland [Wed, 24 Feb 2016 16:10:59 +0000 (10:10 -0600)]
lvmlockd: use new sanlock flag to avoid blocking

This flag allows sanlock requests to avoid all blocking.

8 years agotests: include lvmlockd in default make check
David Teigland [Tue, 23 Feb 2016 22:34:46 +0000 (16:34 -0600)]
tests: include lvmlockd in default make check

8 years agolvmlockd: fix sparse snapshot case
David Teigland [Tue, 23 Feb 2016 21:44:14 +0000 (15:44 -0600)]
lvmlockd: fix sparse snapshot case

A snapshot can be created without a real origin LV
in this case, so there's no lock to use.

8 years agocleanup: use sizeof instead of macro.
Zdenek Kabelac [Tue, 23 Feb 2016 19:19:50 +0000 (20:19 +0100)]
cleanup: use sizeof instead of macro.

Keep the buffer size defined at a single place and then use
its sizeof.

8 years agocleanup: use braces around macro params
Zdenek Kabelac [Tue, 23 Feb 2016 18:51:45 +0000 (19:51 +0100)]
cleanup: use braces around macro params

8 years agocoverity: ensure thin_pool_seg is not NULL
Zdenek Kabelac [Tue, 23 Feb 2016 20:36:51 +0000 (21:36 +0100)]
coverity: ensure thin_pool_seg is not NULL

thin_pool_seg being NULL would be an internal error.

8 years agocoverity: use same arithmetic for both major and minor
Zdenek Kabelac [Tue, 23 Feb 2016 20:16:08 +0000 (21:16 +0100)]
coverity: use same arithmetic for both major and minor

Run all arithmetic in the same 'dev_t' type.

8 years agocoverity: check for dm_snprintf
Zdenek Kabelac [Tue, 23 Feb 2016 20:03:50 +0000 (21:03 +0100)]
coverity: check for dm_snprintf

Check return state like everywhere else.

8 years agocoverity: check cmd pointer exists
Zdenek Kabelac [Tue, 23 Feb 2016 20:02:36 +0000 (21:02 +0100)]
coverity: check cmd pointer exists

Since in _report_init() we check few times for cmd != NULL
keep it consistent and Coverity happier.

8 years agocoverity: ensure non-null pointers are used
Zdenek Kabelac [Tue, 23 Feb 2016 19:16:06 +0000 (20:16 +0100)]
coverity: ensure non-null pointers are used

Here is too complex for Coverity to guess
those pointers cannot be NULL, but it's
very easy to add little checks here.

8 years agocoverity: drop unused assignments
Zdenek Kabelac [Tue, 23 Feb 2016 18:57:56 +0000 (19:57 +0100)]
coverity: drop unused assignments

8 years agocoverity: check for zero length buffer
Zdenek Kabelac [Tue, 23 Feb 2016 18:54:19 +0000 (19:54 +0100)]
coverity: check for zero length buffer

When get_shared_library_path() would got zero length buffer,
it could have underflow in size calc later.
So just put extra small check for this case.

8 years agocoverity: check for info pointer existance
Zdenek Kabelac [Tue, 23 Feb 2016 18:48:01 +0000 (19:48 +0100)]
coverity: check for info pointer existance

Since we already check in few other places  'info' is not NULL,
do the same for others - however when info would be NULL
it more or less looks like internal error.

This page took 0.070256 seconds and 5 git commands to generate.