X-Git-Url: http://git.annexia.org/?p=libguestfs.git;a=blobdiff_plain;f=daemon%2Flvm.c;h=55b41f02b6118e23193c53614db3ffdda0fb4be4;hp=bc38547449208654e9f2611f67275f609f7f7c9c;hb=170f262f0413de843af62b968f6d12c1c476ae7f;hpb=6085137e65cb63aaf725207f2929a571d1149420 diff --git a/daemon/lvm.c b/daemon/lvm.c index bc38547..55b41f0 100644 --- a/daemon/lvm.c +++ b/daemon/lvm.c @@ -37,6 +37,7 @@ convert_lvm_output (char *out, char *prefix) char *p, *pend; char **r = NULL; int size = 0, alloc = 0; + int len; char buf[256]; char *str; @@ -51,6 +52,11 @@ convert_lvm_output (char *out, char *prefix) while (*p && isspace (*p)) /* Skip any leading whitespace. */ p++; + /* Sigh, skip trailing whitespace too. "pvs", I'm looking at you. */ + len = strlen (p)-1; + while (*p && isspace (p[len])) + p[len--] = '\0'; + if (!*p) { /* Empty line? Skip it. */ p = pend; continue; @@ -163,3 +169,134 @@ do_lvs_full (void) { return parse_command_line_lvs (); } + +int +do_pvcreate (const char *device) +{ + char *err; + int r; + + r = command (NULL, &err, + "/sbin/lvm", "pvcreate", device, NULL); + if (r == -1) { + reply_with_error ("%s", err); + free (err); + return -1; + } + + free (err); + return 0; +} + +int +do_vgcreate (const char *volgroup, char * const* const physvols) +{ + char *err; + int r, argc, i; + const char **argv; + + argc = count_strings (physvols) + 3; + argv = malloc (sizeof (char *) * (argc + 1)); + argv[0] = "/sbin/lvm"; + argv[1] = "vgcreate"; + argv[2] = volgroup; + for (i = 3; i <= argc; ++i) + argv[i] = physvols[i-3]; + + r = commandv (NULL, &err, argv); + if (r == -1) { + reply_with_error ("%s", err); + free (err); + return -1; + } + + free (err); + return 0; +} + +int +do_lvcreate (const char *logvol, const char *volgroup, int mbytes) +{ + char *err; + int r; + char size[64]; + + snprintf (size, sizeof size, "%d", mbytes); + + r = command (NULL, &err, + "/sbin/lvm", "lvcreate", + "-L", size, "-n", logvol, volgroup, NULL); + if (r == -1) { + reply_with_error ("%s", err); + free (err); + return -1; + } + + free (err); + return 0; +} + +/* Super-dangerous command used for testing. It removes all + * LVs, VGs and PVs permanently. + */ +int +do_lvm_remove_all (void) +{ + char **xs; + int i, r; + char *err; + + /* Remove LVs. */ + xs = do_lvs (); + if (xs == NULL) + return -1; + + for (i = 0; xs[i] != NULL; ++i) { + r = command (NULL, &err, "/sbin/lvm", "lvremove", "-f", xs[i], NULL); + if (r == -1) { + reply_with_error ("lvremove: %s: %s", xs[i], err); + free (err); + free_strings (xs); + return -1; + } + free (err); + } + free_strings (xs); + + /* Remove VGs. */ + xs = do_vgs (); + if (xs == NULL) + return -1; + + for (i = 0; xs[i] != NULL; ++i) { + r = command (NULL, &err, "/sbin/lvm", "vgremove", "-f", xs[i], NULL); + if (r == -1) { + reply_with_error ("vgremove: %s: %s", xs[i], err); + free (err); + free_strings (xs); + return -1; + } + free (err); + } + free_strings (xs); + + /* Remove PVs. */ + xs = do_pvs (); + if (xs == NULL) + return -1; + + for (i = 0; xs[i] != NULL; ++i) { + r = command (NULL, &err, "/sbin/lvm", "pvremove", "-f", xs[i], NULL); + if (r == -1) { + reply_with_error ("pvremove: %s: %s", xs[i], err); + free (err); + free_strings (xs); + return -1; + } + free (err); + } + free_strings (xs); + + /* There, that was easy, sorry about your data. */ + return 0; +}