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

report: define reserved values/synonyms for some attribute fields

All binary attr fields have synonyms so selection criteria can use
either 0/1 or words to match against the field value (base type
for these binary fields is numeric one - DM_REPORT_FIELD_TYPE_NUMBER
so words are registered as reserved values):

pv_allocatable          - "allocatable"
pv_exported             - "exported"
pv_missing              - "missing"

vg_extendable           - "extendable"
vg_exported             - "exported"
vg_partial              - "partial"
vg_clustered            - "clustered"

lv_initial_image_sync   - "initial image sync", "sync"
lv_image_synced_names   - "image synced", "synced"
lv_merging_names        - "merging"
lv_converting_names     - "converting"
lv_allocation_locked    - "allocation locked", "locked"
lv_fixed_minor          - "fixed minor", "fixed"
lv_merge_failed         - "merge failed", "failed"

For example, these three are all equivalent:

$ lvs -o name,fixed_minor -S 'fixed_minor=fixed'
  LV    FixMin
  lvol8 fixed minor

$ lvs -o name,fixed_minor -S 'fixed_minor="fixed minor"'
  LV    FixMin
  lvol8 fixed minor

$ lvs -o name,fixed_minor -S 'fixed_minor=1'
  LV    FixMin
  lvol8 fixed minor

The same with binary output - it has no effect on this functionality:

$ lvs -o name,fixed_minor --binary -S 'fixed_minor=fixed'
  LV    FixMin
  lvol8          1

$ lvs -o name,fixed_minor --binary -S 'fixed_minor="fixed
minor"'
  LV    FixMin
  lvol8          1

[1] f20/~ # lvs -o name,fixed_minor --binary -S 'fixed_minor=1'
  LV    FixMin
  lvol8          1
This commit is contained in:
Peter Rajnoha 2014-07-04 12:08:52 +02:00
parent 0956fd230f
commit 7021c8f1a4

View File

@ -41,15 +41,27 @@ struct lvm_report_object {
struct label *label; struct label *label;
}; };
/* Enum for field_num index to use in per-field reserved value definition. */
#define FIELD(type, strct, sorttype, head, field_name, width, func, id, desc, writeable) field_ ## id,
enum {
#include "columns.h"
};
#undef FIELD
static const uint64_t _zero64 = UINT64_C(0); static const uint64_t _zero64 = UINT64_C(0);
static const uint64_t _one64 = UINT64_C(1); static const uint64_t _one64 = UINT64_C(1);
static const char * const _str_zero = "0"; static const char * const _str_zero = "0";
static const char * const _str_one = "1"; static const char * const _str_one = "1";
static const uint64_t _reserved_number_undef_64 = UINT64_C(-1); /*
static const uint64_t _reserved_number_unmanaged_64 = UINT64_C(-2); * TODO: try to automate reserved value definition and declare reserved values
static const uint64_t _reserved_size_auto_64 = UINT64_C(-1); * using FIELD macro directly. The FIELD macro should be able to define
* proper structures automatically then.
*/
/* Per-type reserved values. */
static const uint64_t _reserved_number_undef_64 = UINT64_C(-1);
/* /*
* 32 bit signed is casted to 64 bit unsigned in dm_report_field internally! * 32 bit signed is casted to 64 bit unsigned in dm_report_field internally!
* So when stored in the struct, the _reserved_number_undef_32 is actually * So when stored in the struct, the _reserved_number_undef_32 is actually
@ -57,17 +69,125 @@ static const uint64_t _reserved_size_auto_64 = UINT64_C(-1);
*/ */
static const int32_t _reserved_number_undef_32 = INT32_C(-1); static const int32_t _reserved_number_undef_32 = INT32_C(-1);
static const char const *_reserved_number_undef_64_names[]={"-1", "undefined", "undef", "unknown", NULL}; /* Per-field reserved values. */
static const char const *_reserved_number_unmanaged_64_names[]={"unmanaged", NULL}; static const struct dm_report_field_reserved_value _reserved_pv_allocatable = {field_pv_allocatable, &_one64};
static const char const *_reserved_size_auto_64_names[]={"auto", NULL}; static const struct dm_report_field_reserved_value _reserved_pv_exported = {field_pv_exported, &_one64};
static const struct dm_report_field_reserved_value _reserved_pv_missing = {field_pv_missing, &_one64};
static const struct dm_report_field_reserved_value _reserved_vg_extendable = {field_vg_extendable, &_one64};
static const struct dm_report_field_reserved_value _reserved_vg_exported = {field_vg_exported, &_one64};
static const struct dm_report_field_reserved_value _reserved_vg_partial = {field_vg_partial, &_one64};
static const struct dm_report_field_reserved_value _reserved_vg_clustered = {field_vg_clustered, &_one64};
static const struct dm_report_field_reserved_value _reserved_vg_permissions_rw = {field_vg_permissions, "writeable"};
static const struct dm_report_field_reserved_value _reserved_vg_permissions_r = {field_vg_permissions, "read-only"};
static const struct dm_report_field_reserved_value _reserved_vg_mda_copies = {field_vg_mda_copies, &_reserved_number_undef_64};
static const struct dm_report_field_reserved_value _reserved_lv_initial_image_sync = {field_lv_initial_image_sync, &_one64};
static const struct dm_report_field_reserved_value _reserved_lv_image_synced = {field_lv_image_synced, &_one64};
static const struct dm_report_field_reserved_value _reserved_lv_merging = {field_lv_merging, &_one64};
static const struct dm_report_field_reserved_value _reserved_lv_converting = {field_lv_converting, &_one64};
static const struct dm_report_field_reserved_value _reserved_lv_allocation_locked = {field_lv_allocation_locked, &_one64};
static const struct dm_report_field_reserved_value _reserved_lv_fixed_minor = {field_lv_fixed_minor, &_one64};
static const struct dm_report_field_reserved_value _reserved_lv_merge_failed = {field_lv_merge_failed, &_one64};
static const struct dm_report_field_reserved_value _reserved_lv_snapshot_invalid = {field_lv_snapshot_invalid, &_one64};
static const struct dm_report_field_reserved_value _reserved_lv_suspended = {field_lv_suspended, &_one64};
static const struct dm_report_field_reserved_value _reserved_lv_live_table = {field_lv_live_table, &_one64};
static const struct dm_report_field_reserved_value _reserved_lv_inactive_table = {field_lv_inactive_table, &_one64};
static const struct dm_report_field_reserved_value _reserved_lv_device_open = {field_lv_device_open, &_one64};
static const struct dm_report_field_reserved_value _reserved_lv_skip_activation = {field_lv_skip_activation, &_one64};
static const struct dm_report_field_reserved_value _reserved_lv_permissions_rw = {field_lv_permissions, "writeable"};
static const struct dm_report_field_reserved_value _reserved_lv_permissions_r = {field_lv_permissions, "read-only"};
static const struct dm_report_field_reserved_value _reserved_lv_permissions_r_override = {field_lv_permissions, "read-only-override"};
static const struct dm_report_field_reserved_value _reserved_lv_read_ahead = {field_lv_read_ahead, &_reserved_number_undef_64};
/* Per-type reserved names. */
static const char const *_reserved_number_undef_64_names[]={"-1", "undefined", "undef", "unknown", NULL};
/* Per-field reserved names. */
static const char *_reserved_pv_allocatable_names[]={"allocatable", NULL};
static const char *_reserved_pv_exported_names[]={"exported", NULL};
static const char *_reserved_pv_missing_names[]={"missing", NULL};
static const char *_reserved_vg_extendable_names[]={"extendable", NULL};
static const char *_reserved_vg_exported_names[]={"exported", NULL};
static const char *_reserved_vg_partial_names[]={"partial", NULL};
static const char *_reserved_vg_clustered_names[]={"clustered", NULL};
static const char *_reserved_vg_permissions_rw_names[]={"writeable", "rw", "read-write", NULL};
static const char *_reserved_vg_permissions_r_names[]={"read-only", "r", "ro", NULL};
static const char *_reserved_vg_mda_copies_names[]={"unmanaged", NULL};
static const char *_reserved_lv_initial_image_sync_names[]={"initial image sync", "sync", NULL};
static const char *_reserved_lv_image_synced_names[]={"image synced", "synced", NULL};
static const char *_reserved_lv_merging_names[]={"merging", NULL};
static const char *_reserved_lv_converting_names[]={"converting", NULL};
static const char *_reserved_lv_allocation_locked_names[]={"allocation locked", "locked", NULL};
static const char *_reserved_lv_fixed_minor_names[]={"fixed minor", "fixed", NULL};
static const char *_reserved_lv_merge_failed_names[]={"merge failed", "failed", NULL};
static const char *_reserved_lv_snapshot_invalid_names[]={"snapsot invalid", "invalid", NULL};
static const char *_reserved_lv_suspended_names[]={"suspended", NULL};
static const char *_reserved_lv_live_table_names[]={"live table present", "live table", "live", NULL};
static const char *_reserved_lv_inactive_table_names[]={"inactive table present", "inactive table", "inactive", NULL};
static const char *_reserved_lv_device_open_names[]={"open", NULL};
static const char *_reserved_lv_skip_activation_names[]={"skip activation", "skip", NULL};
static const char *_reserved_lv_permissions_rw_names[]={"writeable", "rw", "read-write", NULL};
static const char *_reserved_lv_permissions_r_names[]={"read-only", "r", "ro", NULL};
static const char *_reserved_lv_permissions_r_override_names[]={"read-only-override", "ro-override", "r-override", "R", NULL};
static const char *_reserved_lv_read_ahead_names[]={"auto", NULL};
/* Put together arrays of reserved names with their reserved values. */
static const struct dm_report_reserved_value _report_reserved_values[] = { static const struct dm_report_reserved_value _report_reserved_values[] = {
{DM_REPORT_FIELD_TYPE_NUMBER, &_reserved_number_undef_64, _reserved_number_undef_64_names, {DM_REPORT_FIELD_TYPE_NUMBER, &_reserved_number_undef_64, _reserved_number_undef_64_names,
"Reserved value for undefined numeric value."}, "Reserved value for undefined numeric value."},
{DM_REPORT_FIELD_TYPE_NUMBER, &_reserved_number_unmanaged_64, _reserved_number_unmanaged_64_names, {DM_REPORT_FIELD_TYPE_NONE, &_reserved_pv_allocatable, _reserved_pv_allocatable_names,
"Reserved value for unmanaged number of metadata copies in VG."}, "pv_allocatable reserved values"},
{DM_REPORT_FIELD_TYPE_SIZE, &_reserved_size_auto_64, _reserved_size_auto_64_names, {DM_REPORT_FIELD_TYPE_NONE, &_reserved_pv_exported, _reserved_pv_exported_names,
"Reserved value for size that is automatically calculated."}, "pv_exported reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_pv_missing, _reserved_pv_missing_names,
"pv_missing reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_vg_extendable, _reserved_vg_extendable_names,
"vg_extendable reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_vg_exported, _reserved_vg_exported_names,
"vg_exported reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_vg_partial, _reserved_vg_partial_names,
"vg_partial reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_vg_clustered, _reserved_vg_clustered_names,
"vg_clustered reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_vg_permissions_rw, _reserved_vg_permissions_rw_names,
"vg_permissions reserved values (writeable)"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_vg_permissions_r, _reserved_vg_permissions_r_names,
"vg_permissions reserved values (read-only)"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_vg_mda_copies, _reserved_vg_mda_copies_names,
"vg_mda_copies reserved values (unmanaged)"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_lv_initial_image_sync, _reserved_lv_initial_image_sync_names,
"lv_initial_image_sync reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_lv_image_synced, _reserved_lv_image_synced_names,
"lv_image_synced reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_lv_merging, _reserved_lv_merging_names,
"lv_merging reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_lv_converting, _reserved_lv_converting_names,
"lv_converting reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_lv_allocation_locked, _reserved_lv_allocation_locked_names,
"lv_allocation_locked reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_lv_fixed_minor, _reserved_lv_fixed_minor_names,
"lv_fixed_minor reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_lv_merge_failed, _reserved_lv_merge_failed_names,
"lv_merge_failed reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_lv_snapshot_invalid, _reserved_lv_snapshot_invalid_names,
"lv_snapshot_invalid reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_lv_suspended, _reserved_lv_suspended_names,
"lv_suspended reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_lv_live_table, _reserved_lv_live_table_names,
"lv_live_table reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_lv_inactive_table, _reserved_lv_inactive_table_names,
"lv_inactive_table reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_lv_device_open, _reserved_lv_device_open_names,
"lv_device_open reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_lv_skip_activation, _reserved_lv_skip_activation_names,
"lv_inactive_table reserved values"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_lv_permissions_rw, _reserved_lv_permissions_rw_names,
"lv_permissions reserved values (writeable)"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_lv_permissions_r, _reserved_lv_permissions_r_names,
"lv_permissions reserved values (read-only)"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_lv_permissions_r_override, _reserved_lv_permissions_r_override_names,
"lv_permissions reserved values (read-only-override)"},
{DM_REPORT_FIELD_TYPE_NONE, &_reserved_lv_read_ahead, _reserved_lv_read_ahead_names,
"lv_read_ahead reserved values (auto)"},
{0, NULL, NULL} {0, NULL, NULL}
}; };
@ -542,7 +662,7 @@ static int _lvreadahead_disp(struct dm_report *rh, struct dm_pool *mem,
const struct logical_volume *lv = (const struct logical_volume *) data; const struct logical_volume *lv = (const struct logical_volume *) data;
if (lv->read_ahead == DM_READ_AHEAD_AUTO) if (lv->read_ahead == DM_READ_AHEAD_AUTO)
return _field_set_value(field, "auto", &_reserved_size_auto_64); return _field_set_value(field, "auto", &_reserved_number_undef_64);
return _size32_disp(rh, mem, field, &lv->read_ahead, private); return _size32_disp(rh, mem, field, &lv->read_ahead, private);
} }
@ -833,7 +953,7 @@ static int _vgmdacopies_disp(struct dm_report *rh, struct dm_pool *mem,
uint32_t count = vg_mda_copies(vg); uint32_t count = vg_mda_copies(vg);
if (count == VGMETADATACOPIES_UNMANAGED) if (count == VGMETADATACOPIES_UNMANAGED)
return _field_set_value(field, "unmanaged", &_reserved_number_unmanaged_64); return _field_set_value(field, "unmanaged", &_reserved_number_undef_64);
return _uint32_disp(rh, mem, field, &count, private); return _uint32_disp(rh, mem, field, &count, private);
} }