]> sourceware.org Git - lvm2.git/log
lvm2.git
14 years agoSet return value 0 for 'dmsetup -c -o help'
Zdenek Kabelac [Thu, 8 Jul 2010 13:31:03 +0000 (13:31 +0000)]
Set return value 0 for 'dmsetup -c -o help'

14 years agoSmall update of memlock debug messages.
Zdenek Kabelac [Thu, 8 Jul 2010 13:05:27 +0000 (13:05 +0000)]
Small update of memlock debug messages.
Gives slightly better alligned lines for reading.

14 years agoDo not log backtrace in valid _lv_resume() code path
Zdenek Kabelac [Thu, 8 Jul 2010 12:24:04 +0000 (12:24 +0000)]
Do not log backtrace in valid _lv_resume() code path

14 years agoMinor optimalization of _test_word.
Zdenek Kabelac [Thu, 8 Jul 2010 12:16:16 +0000 (12:16 +0000)]
Minor optimalization of _test_word.
Skip ffs() if  (test >> bit) is 0.

14 years agoCleanups for configure:
Zdenek Kabelac [Thu, 8 Jul 2010 12:02:48 +0000 (12:02 +0000)]
Cleanups for configure:
 Indent updates.
 Use AC_HELP_STRING for help string.
 Start help string with lower letter.
 Add [] around some default values i.e. [TYPE=internal].
 Skip some "" around shell assigment when not needed.
 Fix typo --with-device-gid=UID string.

14 years agoShorten prompt for pvchange and vgextend.
Dave Wysochanski [Wed, 7 Jul 2010 21:30:07 +0000 (21:30 +0000)]
Shorten prompt for pvchange and vgextend.

14 years agoAdd --force to pvchange, and allow override of prompt involving metadataignore.
Dave Wysochanski [Wed, 7 Jul 2010 19:14:57 +0000 (19:14 +0000)]
Add --force to pvchange, and allow override of prompt involving metadataignore.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoAdd prompt if using --metadataignore argument with vgmetadatacopies.
Dave Wysochanski [Wed, 7 Jul 2010 19:02:50 +0000 (19:02 +0000)]
Add prompt if using --metadataignore argument with vgmetadatacopies.

When using vgmetadatacopies value other than "umanaged" (0), prompt
the user if the usage of --metadataignore would change the value of
vgmetadatacopies.  The main 2 cases are:
1) pvchange --metadataignore
2) vgextend --metadataignore

We leave the prompt check in the tools, and do not change anything
if the user says 'n'.

Examples:
vgextend --metadataignore y vgtest /dev/loop0
Setting metadataignore will override preferred number of copies of VG vgtest metadata.
Are you sure? [y/n]: y
  No physical volume label read from /dev/loop0
  Physical volume "/dev/loop0" successfully created
  Volume group "vgtest" successfully extended

pvchange --metadataignore y /dev/loop3
Setting metadataignore on /dev/loop3 will override preferred number of copies of VG vgtest metadata.
Are you sure? [y/n]: y
  WARNING: Changing preferred number of copies of VG vgtest metadata from 3 to 2
  Physical volume "/dev/loop3" changed
  1 physical volume changed / 0 physical volumes not changed

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoAdd warning to vgextend and pvchange if metadataignore given on cmdline.
Dave Wysochanski [Wed, 7 Jul 2010 18:59:45 +0000 (18:59 +0000)]
Add warning to vgextend and pvchange if metadataignore given on cmdline.

Warn the user then change the value of vg_mda_copies.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoTest failed commit of mda on new pv - failed vgextend.
Dave Wysochanski [Wed, 7 Jul 2010 14:43:57 +0000 (14:43 +0000)]
Test failed commit of mda on new pv - failed vgextend.

Test the auto-repair capability when we fail committing to an mda
on a new pv adding to a vg.  This test should fail until we fix
the auto-repair in this case.

14 years agoUse "nowatch" udev rule for known inappropriate devices.
Peter Rajnoha [Wed, 7 Jul 2010 11:22:46 +0000 (11:22 +0000)]
Use "nowatch" udev rule for known inappropriate devices.

For now, this is just a precaution. Normally, all the other (non-dm) rules
should check DM_UDEV_DISABLE_OTHER_RULES_FLAG and therefore avoid setting
any inotify watches as well. But let's make sure.

Support for final assignment of the "nowatch" rule (the use of ":=") will
appear in next udev release, v160. This should also work in previous udev
versions but the setting won't be sealed so any further OPTIONS="watch" will
always prevail there.

We may want to add more specific "nowatch" rules later if needed.

14 years agoAdjust auto-metadata repair and caching logic to try to cope with empty mdas.
Alasdair Kergon [Wed, 7 Jul 2010 02:53:16 +0000 (02:53 +0000)]
Adjust auto-metadata repair and caching logic to try to cope with empty mdas.

- If a PV contained empty mdas, the auto-recovery code was not kicking in.
- The 'inconsistent' state was getting lost when metadata was cached so
  recovery didn't kick in.  But leave the behaviour alone when using
  precommitted metadata because of a warning in a confusing FIXME.

In my testing, pvs and vgs didn't repair inconsistent metadata like they
used to do.  (How many other tools fail similarly now?)

And there should be no need to cache inconsistent metadata because it is
supposed to get repaired under the protection of a write lock immediately it is
discovered.

This code is in need of a redesign based on first principles.
I still see bugs in this code and this commit is risky.

14 years agopost-release
Alasdair Kergon [Wed, 7 Jul 2010 02:37:28 +0000 (02:37 +0000)]
post-release

14 years ago.
Alasdair Kergon [Wed, 7 Jul 2010 02:24:05 +0000 (02:24 +0000)]
.

14 years agofix code in 2nd mda unignore loop to match 1st loop
Alasdair Kergon [Tue, 6 Jul 2010 20:09:38 +0000 (20:09 +0000)]
fix code in 2nd mda unignore loop to match 1st loop

14 years agos/flags/mda/
Alasdair Kergon [Tue, 6 Jul 2010 17:29:50 +0000 (17:29 +0000)]
s/flags/mda/

14 years agoshorten mesg
Alasdair Kergon [Tue, 6 Jul 2010 17:27:32 +0000 (17:27 +0000)]
shorten mesg

14 years agofix jumbled args in 'Adjusting' message
Alasdair Kergon [Tue, 6 Jul 2010 17:26:08 +0000 (17:26 +0000)]
fix jumbled args in 'Adjusting' message

14 years agoFix for bug 607347: failing both redundant mirror log legs...
Jonathan Earl Brassow [Tue, 6 Jul 2010 17:02:03 +0000 (17:02 +0000)]
Fix for bug 607347: failing both redundant mirror log legs...

Rather than attempting to remove all the images of a mirrored
log volume via remove_mirror_images, simply remove the log
if all its devices have failed.

Taka was the first to report that there is still an outstanding
issue with handling this case.  I've managed to reproduce it
only very rarely, and am still working on identifying the problem.
Failing to handle the problem rarely is better than not handling
the scenario at all, so I'm checking this in.

14 years agopre-release
Alasdair Kergon [Tue, 6 Jul 2010 16:49:38 +0000 (16:49 +0000)]
pre-release

14 years agoFix dmlosetup snprintf %llu compiler warning.
Alasdair Kergon [Mon, 5 Jul 2010 22:56:31 +0000 (22:56 +0000)]
Fix dmlosetup snprintf %llu compiler warning.

14 years agoRandomly select which mdas to use or ignore.
Alasdair Kergon [Mon, 5 Jul 2010 22:23:15 +0000 (22:23 +0000)]
Randomly select which mdas to use or ignore.
Add some missing standard configure.in checks.

14 years agoAdd parentheses to some libdevmapper.h macro arguments.
Alasdair Kergon [Mon, 5 Jul 2010 22:22:43 +0000 (22:22 +0000)]
Add parentheses to some libdevmapper.h macro arguments.

14 years agoAdd printf format attributes to yes_no_prompt & dm_{sn,as}printf and fix a calle
Alasdair Kergon [Fri, 2 Jul 2010 21:16:50 +0000 (21:16 +0000)]
Add printf format attributes to yes_no_prompt & dm_{sn,as}printf and fix a calle

14 years ago.
Petr Rockai [Fri, 2 Jul 2010 17:44:17 +0000 (17:44 +0000)]
.

14 years agoMinor changes to man pages for --metadataignore.
Dave Wysochanski [Fri, 2 Jul 2010 17:05:22 +0000 (17:05 +0000)]
Minor changes to man pages for --metadataignore.

Move the definition from pvchange to pvcreate - the location of
other metadata options.

14 years agoremove unneeded header
Alasdair Kergon [Fri, 2 Jul 2010 10:25:16 +0000 (10:25 +0000)]
remove unneeded header

14 years agoAlways pass unsuspended dm devices through persistent filter to other filters.
Alasdair Kergon [Fri, 2 Jul 2010 02:09:57 +0000 (02:09 +0000)]
Always pass unsuspended dm devices through persistent filter to other filters.
Move test for suspended dm devices ahead of other filters.

14 years agoFix another segfault in clvmd -R if no response from daemon received.
Milan Broz [Thu, 1 Jul 2010 21:46:09 +0000 (21:46 +0000)]
Fix another segfault in clvmd -R if no response from daemon received.

Missed the same problem in another function...

14 years agoRemove superfluous suspended device counter from clvmd.
Milan Broz [Thu, 1 Jul 2010 21:23:47 +0000 (21:23 +0000)]
Remove superfluous suspended device counter from clvmd.

Moreover, in current mirror handling, when it calls activate
on removed but suspended detached log this counter drops below zero
and confuses debug log.

14 years agoFix lvm shell crash when input is entirely whitespace. (Xinwei Hu)
Alasdair Kergon [Thu, 1 Jul 2010 11:04:58 +0000 (11:04 +0000)]
Fix lvm shell crash when input is entirely whitespace.  (Xinwei Hu)

14 years agoMove dmeventd man page from install_lvm2 to install_device-mapper. (1.02.50)
Alasdair Kergon [Thu, 1 Jul 2010 10:57:03 +0000 (10:57 +0000)]
Move dmeventd man page from install_lvm2 to install_device-mapper. (1.02.50)

14 years agoRestore the "removemissing" behaviour of lvconvert --repair --use-policies.
Petr Rockai [Thu, 1 Jul 2010 10:10:52 +0000 (10:10 +0000)]
Restore the "removemissing" behaviour of lvconvert --repair --use-policies.

14 years agoUpdate metadata-balance test for --vgmetadatacopies 0.
Dave Wysochanski [Wed, 30 Jun 2010 22:22:00 +0000 (22:22 +0000)]
Update metadata-balance test for --vgmetadatacopies 0.

Should be equivalent to "unmanaged".

14 years ago.
Petr Rockai [Wed, 30 Jun 2010 21:58:13 +0000 (21:58 +0000)]
.

14 years agoMaintain memlock balance in clvmd.
Petr Rockai [Wed, 30 Jun 2010 21:40:27 +0000 (21:40 +0000)]
Maintain memlock balance in clvmd.

When a mirror is being downconverted in a cluster, a series of suspends and
resumes is executed.

With the change to using UUIDs in dev_manager instead of names, the behaviour
has changed with regards to including an _mlog in the deptree of a logical
volume. In the old (pre-UUID-enabled) code, the _mlog would appear in a deptree
of any volume purely based on a name match: a linear volume foo would include
foo_mlog in its dependencies if that happened to exist. This behaviour was
fixed and the mlog is now only included for mirrors.

By a coincidence, this mlog bug had been hiding a different bug in clvmd. When
a mirror is being dismantled (and converted to a linear volume), it is first
suspended as a whole, then later resumed in parts. Nevertheless, the overall
memlock balance is maintained in this operation. The problem kicks in, because
even though the mirror log was suspended as part of the mirror, when the
dismantled mirror is resumed again, it is no longer a mirror and therefore the
mirror log stays suspended. This would not be a problem in itself, since
_delete_lv (from metadata/mirror.c) is called on it subsequently, which does an
activate/deactivate cycle and removes the LV. The activate/deactivate cycle
correctly prompts clvmd to resume the device: however, in doing this, it will
issue an unpaired resume operation (the suspend that caused the mirror log to
be suspended is paired with resuming the dismantled mirror later). We have
concluded that the path in clvmd should never affect memlock_count, since there
should never be an unmatched explicit suspend preceding this resume.

14 years agoFix --[vg]metadatacopies arg processing
Alasdair Kergon [Wed, 30 Jun 2010 20:21:03 +0000 (20:21 +0000)]
Fix --[vg]metadatacopies arg processing

14 years agoimprove vgmetadatacopies unmanaged message
Alasdair Kergon [Wed, 30 Jun 2010 20:03:52 +0000 (20:03 +0000)]
improve vgmetadatacopies unmanaged message

14 years agoCheck for missing_pv in vg_remove loop.
Dave Wysochanski [Wed, 30 Jun 2010 19:55:43 +0000 (19:55 +0000)]
Check for missing_pv in vg_remove loop.

If a pv is missing, we should just skip it rather than checking the
device size and failing the vgremove.

14 years agomore mda ignore cleanups
Alasdair Kergon [Wed, 30 Jun 2010 19:28:35 +0000 (19:28 +0000)]
more mda ignore cleanups

14 years agoRefactor vg_remove_check to place pv removal into separate function.
Dave Wysochanski [Wed, 30 Jun 2010 18:03:52 +0000 (18:03 +0000)]
Refactor vg_remove_check to place pv removal into separate function.

14 years agomore metadataignore message/code cleanup
Alasdair Kergon [Wed, 30 Jun 2010 17:13:05 +0000 (17:13 +0000)]
more metadataignore message/code cleanup

14 years ago Update partial mode warning message.
Alasdair Kergon [Wed, 30 Jun 2010 16:43:09 +0000 (16:43 +0000)]
  Update partial mode warning message.

14 years agorevert that
Alasdair Kergon [Wed, 30 Jun 2010 14:54:29 +0000 (14:54 +0000)]
revert that

14 years agosuppress useless compiler warning
Alasdair Kergon [Wed, 30 Jun 2010 14:52:29 +0000 (14:52 +0000)]
suppress useless compiler warning

14 years agopost-release
Alasdair Kergon [Wed, 30 Jun 2010 14:50:32 +0000 (14:50 +0000)]
post-release

14 years agoOnly attempt to guarantee 1 mda ignored if there's at least one mda in the vg.
Dave Wysochanski [Wed, 30 Jun 2010 14:48:07 +0000 (14:48 +0000)]
Only attempt to guarantee 1 mda ignored if there's at least one mda in the vg.

14 years ago Only attempt to guarantee 1 mda ignored if there's at least one mda in the vg.
Alasdair Kergon [Wed, 30 Jun 2010 14:27:40 +0000 (14:27 +0000)]
 Only attempt to guarantee 1 mda ignored if there's at least one mda in the vg.

14 years agopre-release
Alasdair Kergon [Wed, 30 Jun 2010 14:04:15 +0000 (14:04 +0000)]
pre-release

14 years agoFix vgremove to allow removal of VG with missing PVs. (2.02.52)
Milan Broz [Wed, 30 Jun 2010 14:01:39 +0000 (14:01 +0000)]
Fix vgremove to allow removal of VG with missing PVs. (2.02.52)

14 years agoImprove various log messages.
Alasdair Kergon [Wed, 30 Jun 2010 13:51:11 +0000 (13:51 +0000)]
Improve various log messages.

14 years agoUpdate nightly tests for vgextend --metadataignore.
Dave Wysochanski [Wed, 30 Jun 2010 13:11:12 +0000 (13:11 +0000)]
Update nightly tests for vgextend --metadataignore.

14 years agoUpdate nightly tests for vgextend --metadataignore.
Dave Wysochanski [Wed, 30 Jun 2010 13:04:59 +0000 (13:04 +0000)]
Update nightly tests for vgextend --metadataignore.

14 years agoAdd --metadataignore to vgextend and man pages.
Dave Wysochanski [Wed, 30 Jun 2010 13:03:48 +0000 (13:03 +0000)]
Add --metadataignore to vgextend and man pages.

14 years agoAdd pvmetadatacopies to lvm.conf and pvcreate man pages.
Dave Wysochanski [Wed, 30 Jun 2010 12:49:28 +0000 (12:49 +0000)]
Add pvmetadatacopies to lvm.conf and pvcreate man pages.

14 years agoUpdate pvcreate tests for --metadataignore.
Dave Wysochanski [Wed, 30 Jun 2010 12:17:55 +0000 (12:17 +0000)]
Update pvcreate tests for --metadataignore.

14 years agoAdd --metadataignore to pvcreate.
Dave Wysochanski [Wed, 30 Jun 2010 12:17:24 +0000 (12:17 +0000)]
Add --metadataignore to pvcreate.

Allow metadataignore flag to be passed in to pvcreate.
Ideally, more refactoring of the mda allocation / initialization
is warranted, but for now, we just add another parameter to 'add_mda'
to take an existing mda ignored flag.  We need to do this or pv_write
loses the state of the mda 'ignored' flag before copying and writing
to disk.

14 years agoImprove logging for setting --vgmetadatacopies.
Dave Wysochanski [Tue, 29 Jun 2010 22:41:28 +0000 (22:41 +0000)]
Improve logging for setting --vgmetadatacopies.

Example of logging:
metadata/metadata.c:1127     Setting mda_copies = 3 on vg vgtest
metadata/pv_manip.c:296         /dev/loop2 0:      0     25: NULL(0:0)
metadata/pv_manip.c:296         /dev/loop3 0:      0     25: NULL(0:0)
metadata/pv_manip.c:296         /dev/loop4 0:      0     25: NULL(0:0)
metadata/metadata.c:1072     Adjusting ignored mdas on vg vgtest, vg_mda_used_count=5, vg_mda_copies=3
metadata/metadata.c:1015     Setting ignore flag for 2 mdas on vg vgtest
metadata/metadata.c:4151     Setting mda ignored flag for metadata_locn /dev/loop2.
metadata/metadata.c:4151     Setting mda ignored flag for metadata_locn /dev/loop3.

14 years agoImprove logging for metadata ignore by printing device name.
Dave Wysochanski [Tue, 29 Jun 2010 22:37:32 +0000 (22:37 +0000)]
Improve logging for metadata ignore by printing device name.

Print device name when setting or clearing metadata ignore bit.
Example:
label/label.c:160       /dev/loop2: lvm2 label detected
cache/lvmcache.c:1136         lvmcache: /dev/loop2: now in VG #orphans_lvm2 (#orphans_lvm2)
metadata/metadata.c:4142     Setting mda ignored flag for metadata_locn /dev/loop2.
format_text/text_label.c:318     Skipping mda with ignored flag on device /dev/loop2 at offset 4096

14 years agoAdd some log_verbose debug statements related to metadataignore.
Dave Wysochanski [Tue, 29 Jun 2010 22:25:58 +0000 (22:25 +0000)]
Add some log_verbose debug statements related to metadataignore.

Logging isn't ideal, especially for mda_set_ignore.  Ideally we'd
like to display the device name and offset in this case but this
requires a bit more work and a per-format 'mda_description' function
pointer definition (we don't have access to mda_context in
metadata.c).

14 years agoMove code into pv_change_metadataignore library function.
Dave Wysochanski [Tue, 29 Jun 2010 21:32:44 +0000 (21:32 +0000)]
Move code into pv_change_metadataignore library function.

In preparation to call this from both pvcreate as well as pvchange,
move the guts of metadataignore into a library function.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoAdd error message if backup_to_file fails because of empty in_use mdas list.
Dave Wysochanski [Tue, 29 Jun 2010 15:03:59 +0000 (15:03 +0000)]
Add error message if backup_to_file fails because of empty in_use mdas list.

14 years agoAdd more initializations of 'mda->flags' field.
Dave Wysochanski [Tue, 29 Jun 2010 14:52:56 +0000 (14:52 +0000)]
Add more initializations of 'mda->flags' field.

Mda allocation needs refactored into a single function but as an
interim step, ensure mda->flags is initialized properly.

14 years agoAttempt to fix intermittent failure with non-debug configured vgcfgbackup.
Dave Wysochanski [Tue, 29 Jun 2010 13:29:53 +0000 (13:29 +0000)]
Attempt to fix intermittent failure with non-debug configured vgcfgbackup.

There's an intermittent failure with vgcfgbackup that seems to have been
introduced with the metadataignore / vgmetadatacopies patchset.
Intermittent failures are often the result of uninitialized data,
so this patch calls zalloc in a few places it might matter.

14 years agoUpdate WHATS_NEW for --metadataignore and --vgmetadatacopies changes.
Dave Wysochanski [Tue, 29 Jun 2010 12:06:14 +0000 (12:06 +0000)]
Update WHATS_NEW for --metadataignore and --vgmetadatacopies changes.

14 years agoUpdate t-covercmd pvck to take proper device argument.
Dave Wysochanski [Mon, 28 Jun 2010 21:49:31 +0000 (21:49 +0000)]
Update t-covercmd pvck to take proper device argument.

14 years agoFix compile warning in vgchange.c regarding mda_copies initialization.
Dave Wysochanski [Mon, 28 Jun 2010 21:35:00 +0000 (21:35 +0000)]
Fix compile warning in vgchange.c regarding mda_copies initialization.

14 years agoUpdate tests to handle phase 2 (vg based) metadata balance.
Dave Wysochanski [Mon, 28 Jun 2010 20:40:27 +0000 (20:40 +0000)]
Update tests to handle phase 2 (vg based) metadata balance.

Test vgcreate/vgchange --vgmetadatacopies, vgextend, vgreduce,
vgsplit, vgmerge.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoUpdate example.conf.in to describe vgmetadatacopies.
Dave Wysochanski [Mon, 28 Jun 2010 20:40:15 +0000 (20:40 +0000)]
Update example.conf.in to describe vgmetadatacopies.

Update example.conf to describe vgmetadatacopies.  Provide an
explanation for the '0' ("unmanaged") value.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoAllow 'all' and 'unmanaged' values for --vgmetadatacopies.
Dave Wysochanski [Mon, 28 Jun 2010 20:40:01 +0000 (20:40 +0000)]
Allow 'all' and 'unmanaged' values for --vgmetadatacopies.

Allowing an 'all' and 'unmanaged' value is more intuitive, and
provides a simple way for users to get back to original LVM behavior
of metadata written to all PVs in the volume group.

If the user requests "--vgmetadatacopies unmanaged", this instructs
LVM not to manage the ignore bits to achieve a specific number of
metadata copies in the volume group.  The user is free to use
"pvchange --metadataignore" to control the mdas on a per-PV basis.
If the user requests "--vgmetadatacopies all", this instructs LVM
to do 2 things: 1) clear all ignore bits, and 2) set the "unmanaged"
policy going forward.

Internally, we use the special MAX_UINT32 value to indicate 'all'.
This 'just' works since it's the largest value possible for the
field and so all 'ignore' bits on all mdas in the VG will get
cleared inside _vg_metadata_balance().  However, after we've
called the _vg_metadata_balance function, we check for the special
'all' value, and if set, we write the "unmanaged" value into the
metadata.  As such, the 'all' value is never written to disk.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoEnsure --metadatacopies parameter gets interpreted based on command.
Dave Wysochanski [Mon, 28 Jun 2010 20:39:39 +0000 (20:39 +0000)]
Ensure --metadatacopies parameter gets interpreted based on command.

Now that we have both --pvmetadatacopies and --vgmetadatacopies,
we need to make sure --metadatacopies gets interpreted correctly.

For pv commands, --metadatacopies should imply --pvmetadatacopies,
and for vg commands, --vgmetadatacopies.

Note: this will change the behavior of vgcreate with --metadatacopies
to be a synonym for --vgmetadatacopies.  Previously, --metadatacopies
would apply to any PVs given with vgcreate that needed an implicit
pvcreate.  As a result, one small change is needed to one of the nightly
tests - t-vgcreate-usage.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoAdd --vgmetadatacopies to vgsplit man page and command.
Dave Wysochanski [Mon, 28 Jun 2010 20:39:24 +0000 (20:39 +0000)]
Add --vgmetadatacopies to vgsplit man page and command.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoUpdate _vgmerge_single() to move fid->metadata_areas_ignored.
Dave Wysochanski [Mon, 28 Jun 2010 20:39:08 +0000 (20:39 +0000)]
Update _vgmerge_single() to move fid->metadata_areas_ignored.

When vgmerge is called we move the mdas from the source to the
destination.  With metadata balancing we now have another mda
list, fid->metadata_areas_ignored, so move the mdas on this list
as well.

This patch should not matter as the code is written today.  However
we include it for completeness in the case that _vgmerge_single()
is refactored and/or moved into a library function.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoUpdate check in vg_split_mdas to account for ignored mdas list.
Dave Wysochanski [Mon, 28 Jun 2010 20:38:56 +0000 (20:38 +0000)]
Update check in vg_split_mdas to account for ignored mdas list.

The check in vg_split_mdas will trigger an error if the 'from' vg
list is empty.  However, this might be ok in some instances now
that we have ignored mdas.  Relax this check so an error is triggered
only in the case where there's truly no more mdas in the 'from'
vg.

One example of where this makes a difference is with vgreduce.
If we try to vgreduce a PV with un-ignored mdas, this should trigger
the balancing function to un-ignore mdas on another PV in the VG.
However, we don't get to vg_write() before we fail because this
list size check fails, and we see an error message indicating:
"Cannot remove final metadata area ..."

Another example is with vgsplit into a new VG, where the PVs
being moved contain all ignored mdas.  We must move the mdas on
fid->metadata_areas_ignored from 'vg_from' to 'vg_to'.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoEnsure fid mda lists are populated correctly during vgextend.
Dave Wysochanski [Mon, 28 Jun 2010 20:38:39 +0000 (20:38 +0000)]
Ensure fid mda lists are populated correctly during vgextend.

The vgextend path calls add_pv_to_vg().  Inside add_pv_to_vg(),
we must ensure we pass the correct mdas list into pv_setup(), as
copies of mdas are placed on the vg->fid list.  If we don't place
the mdas on the correct vg->fid list, the various counts may be
incorrect and the metadata balance algorithm will not work when
called from vg_write() path.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoAdd --vgmetadatacopies to vgcreate man page, command, and lvm.conf.
Dave Wysochanski [Mon, 28 Jun 2010 20:38:23 +0000 (20:38 +0000)]
Add --vgmetadatacopies to vgcreate man page, command, and lvm.conf.

Allow parsing of --vgmetadatacopies for vgcreate.  Accept
--metadatacopies as a synonym for --vgmetadatacopies.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoSet vg_mda_copies when pvchange --metadataignore is given.
Dave Wysochanski [Mon, 28 Jun 2010 20:38:06 +0000 (20:38 +0000)]
Set vg_mda_copies when pvchange --metadataignore is given.

When a user explicitly sets a new mda ignore value for a PV, we
should update vg_mda_copies accordingly.  When the VG is written
out, the user would not want the new ignore state to get lost as
a result of the vg_mda_copies value and logic in the vg_write
path.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoImplement _vg_adjust_ignored_mdas and call from vg_write() path.
Dave Wysochanski [Mon, 28 Jun 2010 20:37:54 +0000 (20:37 +0000)]
Implement _vg_adjust_ignored_mdas and call from vg_write() path.

Compare the value of the newly added vg_mda_copies field
(--vgmetadatacopies parameter) with the current count of
in-use mdas and ignoring or unignoring mdas as necessary to
get to the target count.  Also, as a safety check before
returning, ensure we have at least one mda enabled.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoUpdate vgchange tool to accept --vgmetadatacopies.
Dave Wysochanski [Mon, 28 Jun 2010 20:37:37 +0000 (20:37 +0000)]
Update vgchange tool to accept --vgmetadatacopies.

Update logic in vgchange to handle --vgmetadatacopies, allow
--metadatacopies as a synonym to --vgmetadatacopies,
and add these parameters to args.h and commands.h
Forbit both --vgmetadatacopies and --metadatacopies as only
one allowed.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoAdd vg_mda_copies display field to 'vgs' command.
Dave Wysochanski [Mon, 28 Jun 2010 20:37:23 +0000 (20:37 +0000)]
Add vg_mda_copies display field to 'vgs' command.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoMake vg->mda_copies persistent in on disk vg metadata.
Dave Wysochanski [Mon, 28 Jun 2010 20:37:10 +0000 (20:37 +0000)]
Make vg->mda_copies persistent in on disk vg metadata.

This patch adds the ability to read/write the vg->mda_copies values
from/to the vg metadata.

If we read the VG metadata and this field does not exist, we set
mda_copies to the default value of 0.  Later in the code, we use
this special '0' value to indicate a disable of metadata balancing.
This should preserve existing LVM behavior and ensure metadata balancing
can be turned off should the need arise.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoAdd vg get/set methods for VG metadata copies.
Dave Wysochanski [Mon, 28 Jun 2010 20:36:56 +0000 (20:36 +0000)]
Add vg get/set methods for VG metadata copies.

This patch adds the get and partially implemented set function.
The 'set' function should probably ignore or un-ignore metadata areas
based on new values.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoAdd mda_copies to VG structures and initialization.
Dave Wysochanski [Mon, 28 Jun 2010 20:36:37 +0000 (20:36 +0000)]
Add mda_copies to VG structures and initialization.

Add a field to struct volume_group to later implement metadata
balancing:
- mda_copies: target # of non-ignored mdas in the VG; default 0 (do
not control pv 'ignore mdas' bit.

This patch just adds the parameter to the structures with the default
values but does not modify any commands.  Should be no functional change.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoDefine vgmetadatacopies in vgchange man page.
Dave Wysochanski [Mon, 28 Jun 2010 20:36:18 +0000 (20:36 +0000)]
Define vgmetadatacopies in vgchange man page.

This patch adds a vgmetadatacopies parameter for metadata balancing.
This parameter provides a simple way for users to create a policy for
placing metadata on PVs automatically by LVM.  The behavior is implemented
inside LVM by managing the 'ignore' mda bits.  We chose the name
'vgmetadatacopies' as this is a natural extension to the existing parameter
'pvmetadatacopies' / 'metadatacopies' in pvcreate.

This is a first step at VG parameter based metadata balancing.  Most users
will probably want to state that they want a certain number of PVs to contain
metadata, and they may be less concerned about a specific number of metadata
copies in the volume group.  However, for default values (pvmetadatacopies
is 1 by default), the number of metadatacopies in the volume group, and the
number of PVs with metadata are the same.  In the future we could add
vgmetadatacopiespvs to define more specifically the number of pvs in the
VG that contain metadata, but for now we start with this parameter.

Another possible future extension would be to define a specific pv tag
to mark the set of PVs that should be used for metadata balancing.  This
tag based approach could be used in conjunction with 'vgmetadatacopies'.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoAdd tests for phase 1 of metadata balance - manage per-PV ignore bit.
Dave Wysochanski [Mon, 28 Jun 2010 20:36:06 +0000 (20:36 +0000)]
Add tests for phase 1 of metadata balance - manage per-PV ignore bit.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoBefore committing each mda, arrange mdas so ignored mdas get committed first.
Dave Wysochanski [Mon, 28 Jun 2010 20:35:49 +0000 (20:35 +0000)]
Before committing each mda, arrange mdas so ignored mdas get committed first.

Arrange mdas so mdas that are to be ignored come first.  This is an
optimization that ensures consistency on disk for the longest period of time.
This was noted by agk in review of the v4 patchset of pvchange-based mda
balance.

Note the following example for an explanation of the background:
Assume the initial state on disk is as follows:
PV0 (v1, non-ignored)
PV1 (v1, non-ignored)
PV2 (v1, non-ignored)
PV3 (v1, non-ignored)

If we did not sort the list, we would have a commit sequence something like
this:
PV0 (v2, non-ignored)
PV1 (v2, ignored)
PV2 (v2, ignored)
PV3 (v2, non-ignored)

After the commit of PV0's mdas, we'd have an on-disk state like this:
PV0 (v2, non-ignored)
PV1 (v1, non-ignored)
PV2 (v1, non-ignored)
PV3 (v1, non-ignored)

This is an inconsistent state of the disk. If the machine fails, the next
time it was brought back up, the auto-correct mechanism in vg_read would
update the metadata on PV1-PV3.  However, if possible we try to avoid
inconsistent on-disk states.  Clearly, because we did not sort, we have
a greater chance of on-disk inconsistency - from the time the commit of
PV0 is complete until the time PV3 is complete.

We could improve the amount of time the on-disk state is consistent by simply
sorting the commit order as follows:
PV1 (v2, ignored)
PV2 (v2, ignored)
PV0 (v2, non-ignored)
PV3 (v2, non-ignored)

Thus, after the first PV is committed (in this case PV1), on-disk we would
have:
PV0 (v1, non-ignored)
PV1 (v2, ignored)
PV2 (v1, non-ignored)
PV3 (v1, non-ignored)

This is clearly a consistent state.  PV1 will be read but the mda will be
ignored.  All other PVs contain v1 metadata, and no auto-correct will be
required.  In fact, if we commit all PVs with ignored mdas first, we'll
only have an inconsistent state when we start writing non-ignored PVs,
and thus the chances we'll get an inconsistent state on disk is much
less with the sorted method.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoRefactor vg_commit() to add _vg_commit_mdas().
Dave Wysochanski [Mon, 28 Jun 2010 20:35:33 +0000 (20:35 +0000)]
Refactor vg_commit() to add _vg_commit_mdas().

Factor out calling mda->ops->vg_commit() for each mda.
No functional change.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoUpdate _vg_read and _text_create_text_instance to use fid_add_mda[s].
Dave Wysochanski [Mon, 28 Jun 2010 20:35:17 +0000 (20:35 +0000)]
Update _vg_read and _text_create_text_instance to use fid_add_mda[s].

When we are constructing the vg, we may need to adjust the list of
metadata_areas if there are ignored mdas.  At label read time, we
do not read the metadata of ignored mdas, and as a result, they do
not get placed on vg->fid->metadata_areas inside _text_create_text_instance
since lvmcache does not have these areas attached to vginfo->infos.
However, when we're checking the pvids inside _vg_read, after having
read another metadata area from another PV, we do have the opportunity
to update the metadata_area and metadata_areas_ignored lists based
on the read metadata_area.  We need accurate mda lists for the reporting
functions that count the ignored mdas, as well as general correctness
of mda balancing.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoUse mdas_empty_or_ignored() in place of checks for empty mda list.
Dave Wysochanski [Mon, 28 Jun 2010 20:34:58 +0000 (20:34 +0000)]
Use mdas_empty_or_ignored() in place of checks for empty mda list.

With the addition of ignored mdas, we replace all checks for an empty
mda list with a new function to look for either an empty mda list or
ignored mdas.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoAdd mdas_empty_or_ignored() helper function.
Dave Wysochanski [Mon, 28 Jun 2010 20:34:40 +0000 (20:34 +0000)]
Add mdas_empty_or_ignored() helper function.

Add a helper function to consolidate checking for an empty mdas list
or ignored mdas.  Ignored mdas should behave almost identically to
an empty mda list - the metadata areas should not be read or written
to.  This function will make it easier to implement metadata balancing
and easier to track pvs with an empty mda list or ignored mdas.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoImplement ignore of mda if bit set by skipping r/w of metadata.
Dave Wysochanski [Mon, 28 Jun 2010 20:34:24 +0000 (20:34 +0000)]
Implement ignore of mda if bit set by skipping r/w of metadata.

We implement ignore of an mda at label_read time by checking for
the ignore bit, and then skipping the reading of the vgname and
other information in the metadata.  This will have an effect similar
to a PV found with no mdas.  Thus, it will look like an orphan in the
cache until we scan the rest of the system and find a PV with
metadata, and the mda will not be on the vg->fid->metadata_areas
list so no read/writes will be done to the metadata area.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoUpdate pvchange, pvs and vgs man pages for metadata ignore.
Dave Wysochanski [Mon, 28 Jun 2010 20:34:12 +0000 (20:34 +0000)]
Update pvchange, pvs and vgs man pages for metadata ignore.

Explain --metadataignore argument to pvchange, add new fields to pvs / vgs.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoAdd --metadataignore to pvchange, allowing for ignoring of metadata areas.
Dave Wysochanski [Mon, 28 Jun 2010 20:33:58 +0000 (20:33 +0000)]
Add --metadataignore to pvchange, allowing for ignoring of metadata areas.

This patch just modifies pvchange to call the underlying ignore
functions for mdas.  Ensure special cases do not reflect changes
in metadata (PVs with 0 mdas, setting ignored when already ignored,
clearing ignored when not ignored).

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoDefine new functions and vgs/pvs fields related to mda ignore.
Dave Wysochanski [Mon, 28 Jun 2010 20:33:44 +0000 (20:33 +0000)]
Define new functions and vgs/pvs fields related to mda ignore.

Define a new pvs field, pv_mda_used_count, and a new vgs field,
vg_mda_used_count to match the existing pv_mda_count and vg_mda_count.
These new fields count the number of mdas that have the 'ignored' bit
clear (they are in use on the PV / VG).  Also define various supporting
functions to implement the counting as well as setting the ignored
flag and determining if an mda is ignored.  These high level functions
call into the lower level location independent mda ignore functions
defined by earlier patches.

Note that counting ignored mdas in a vg requires traversing both lists
and checking for the ignored bit on the mda.  The count of 'ignored'
mdas then is defined by having the bit set, not by which list the mda
is on.  The list does determine whether LVM actually does read/write to
the mda, though we must count the bits in order to return accurate numbers
for the various counts.  Also, pv_mda_set_ignored must search both vg
lists for ignored mda.  If the state changes and needs to be committed
to disk, the ignored mda will be on the non-ignored list.

Note also in pv_mda_set_ignored(), we must properly manage the mda lists.
If we change the ignored state of an mda, we must change any mdas on
vg->fid->metadata_areas that correspond to this pv.  Also, we may
need to allocate a copy of the mda, as is done when fid->metadata_areas
is populated from _vg_read(), if we are un-ignoring an ignored mda.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoAdd metadata_areas_ignored list and functions to manage ignored mdas.
Dave Wysochanski [Mon, 28 Jun 2010 20:33:22 +0000 (20:33 +0000)]
Add metadata_areas_ignored list and functions to manage ignored mdas.

Add a second mda list, metadata_areas_ignored to fid, and a couple
functions, fid_add_mda() and fid_add_mdas() to help manage the lists.

These functions are needed to properly count the ignored mdas and
manage the lists attached to the 'fid' and ultimately the 'vg'.

Ensure metadata_areas_ignored is initialized in other formats, even
if the list is never used.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoRename fid->metadata_areas to fid->metadata_areas_in_use.
Dave Wysochanski [Mon, 28 Jun 2010 20:32:44 +0000 (20:32 +0000)]
Rename fid->metadata_areas to fid->metadata_areas_in_use.

Rename the metadata_areas list to an 'in_use' list to prepare for
future 'ignored' list.

14 years agoUse vg_mda_count() in vgdisplay.
Dave Wysochanski [Mon, 28 Jun 2010 20:32:21 +0000 (20:32 +0000)]
Use vg_mda_count() in vgdisplay.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
14 years agoAdd mda location specific mda_copy constructor.
Dave Wysochanski [Mon, 28 Jun 2010 20:31:59 +0000 (20:31 +0000)]
Add mda location specific mda_copy constructor.

Because of the way mdas are handled internally, where a PV in a VG
has mdas on both info->mdas and vg->fid->metadata_areas list, we
need a location independent copy constructor for struct
metadata_area.  Break up the existing format-text specific copy
constructor into a format independent piece and a format dependent
piece.

This function is necessary to properly implement pv_set_mda_ignored().

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
Reviewed-by: Alasdair G Kergon <agk@redhat.com>
14 years agoAdd mda_locns_match() internal library function for mapping pv/device to VG mda.
Dave Wysochanski [Mon, 28 Jun 2010 20:31:38 +0000 (20:31 +0000)]
Add mda_locns_match() internal library function for mapping pv/device to VG mda.

A metadata_area is defined independent of the location.  One downside
is that there is no obvious mapping from a pv to an mda.  For a PV in
a VG, we need a way to start with a PV and end up with an MDA, if we
are to manage mdas starting with a device/pv.  This function provides
us a way to go down the list of PVs on a VG, and identify which ones
match a particular PV.

I'm not entirely happy with this approach, but it does fit into the
existing structures in a reasonable way.

An alternative solution might be to refactor the VG - PV interface such
that mdas are a list tied to a PV.  However, this seemed a bit tricky since
a PV does not come into existence until after the list of mdas is
constructed (see _vg_read() - we create a 'fid' and attach mdas to it,
then we go through them and attach pvs).

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
Reviewed-by: Alasdair G Kergon <agk@redhat.com>
14 years agoEnsure in-memory state matches on-disk state of mda ignore bit.
Dave Wysochanski [Mon, 28 Jun 2010 20:31:18 +0000 (20:31 +0000)]
Ensure in-memory state matches on-disk state of mda ignore bit.

Signed-off-by: Dave Wysochanski <dwysocha@redhat.com>
This page took 0.079449 seconds and 5 git commands to generate.