diff options
author | Milan Broz <mbroz@redhat.com> | 2008-08-28 18:41:51 +0000 |
---|---|---|
committer | Milan Broz <mbroz@redhat.com> | 2008-08-28 18:41:51 +0000 |
commit | 9c520b114a6af36d5b0f1afc94f54471d552e165 (patch) | |
tree | 7f2d089faa32078522dc9e5a99cde8c77720bbc6 /lib/uuid | |
parent | 8ed917d2878c4a05c9bada6d2a5b605eefdefb11 (diff) | |
download | lvm2-9c520b114a6af36d5b0f1afc94f54471d552e165.tar.gz |
Fix vgconvert logical volume id metadata validation.
If volume group is downconverted to lvm1 format,
check if lvid has supported format for conversion to lv_num in lvm1.
Diffstat (limited to 'lib/uuid')
-rw-r--r-- | lib/uuid/uuid.c | 18 | ||||
-rw-r--r-- | lib/uuid/uuid.h | 1 |
2 files changed, 19 insertions, 0 deletions
diff --git a/lib/uuid/uuid.c b/lib/uuid/uuid.c index 03fe5c556..da4093f7a 100644 --- a/lib/uuid/uuid.c +++ b/lib/uuid/uuid.c @@ -67,11 +67,29 @@ int lvnum_from_lvid(union lvid *lvid) lv_num *= sizeof(_c) - 1; if ((c = strchr(_c, lvid->id[1].uuid[i]))) lv_num += (int) (c - _c); + if (lv_num < 0) + lv_num = 0; } return lv_num; } +int lvid_in_restricted_range(union lvid *lvid) +{ + int i; + + for (i = 0; i < ID_LEN - 3; i++) + if (lvid->id[1].uuid[i] != '0') + return 0; + + for (i = ID_LEN - 3; i < ID_LEN; i++) + if (!isdigit(lvid->id[1].uuid[i])) + return 0; + + return 1; +} + + int id_create(struct id *id) { int randomfile; diff --git a/lib/uuid/uuid.h b/lib/uuid/uuid.h index d1b03b3bf..00296393c 100644 --- a/lib/uuid/uuid.h +++ b/lib/uuid/uuid.h @@ -34,6 +34,7 @@ union lvid { int lvid_from_lvnum(union lvid *lvid, struct id *vgid, uint32_t lv_num); int lvnum_from_lvid(union lvid *lvid); +int lvid_in_restricted_range(union lvid *lvid); void uuid_from_num(char *uuid, uint32_t num); |