Matthew Booth
2009-Aug-18 13:58 UTC
[Libguestfs] [PATCH] guestfs_modprobe: explicitly load a kernel module in the appliance
--- daemon/Makefile.am | 1 + daemon/modprobe.c | 43 +++++++++++++++++++++++++++++++++++++++++++ po/POTFILES.in | 1 + src/MAX_PROC_NR | 2 +- src/generator.ml | 7 +++++++ 5 files changed, 53 insertions(+), 1 deletions(-) create mode 100644 daemon/modprobe.c diff --git a/daemon/Makefile.am b/daemon/Makefile.am index 097d89d..83ee408 100644 --- a/daemon/Makefile.am +++ b/daemon/Makefile.am @@ -54,6 +54,7 @@ guestfsd_SOURCES = \ lvm.c \ mkfs.c \ mknod.c \ + modprobe.c \ mount.c \ names.c \ ntfs.c \ diff --git a/daemon/modprobe.c b/daemon/modprobe.c new file mode 100644 index 0000000..8f92eca --- /dev/null +++ b/daemon/modprobe.c @@ -0,0 +1,43 @@ +/* libguestfs - the guestfsd daemon + * Copyright (C) 2009 Red Hat Inc. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + */ + +#include "daemon.h" + +int +do_modprobe (const char *module) +{ + const char *argv[] = { + "/sbin/modprobe", + NULL, + NULL + }; + + argv[1] = module; + + char *out, *err; + int r = commandv (&out, &err, (char **) argv); + + if (r == -1) { + reply_with_error ("%s", err); + } + + free (out); + free (err); + + return r; +} diff --git a/po/POTFILES.in b/po/POTFILES.in index 33bf6e6..19eef99 100644 --- a/po/POTFILES.in +++ b/po/POTFILES.in @@ -30,6 +30,7 @@ daemon/ls.c daemon/lvm.c daemon/mkfs.c daemon/mknod.c +daemon/modprobe.c daemon/mount.c daemon/names.c daemon/ntfs.c diff --git a/src/MAX_PROC_NR b/src/MAX_PROC_NR index 2455a46..205a12b 100644 --- a/src/MAX_PROC_NR +++ b/src/MAX_PROC_NR @@ -1 +1 @@ -193 +194 diff --git a/src/generator.ml b/src/generator.ml index cc97dd5..41a78fe 100755 --- a/src/generator.ml +++ b/src/generator.ml @@ -3560,6 +3560,13 @@ an external journal on the journal with UUID C<uuid>. See also C<guestfs_mke2journal_U>."); + ("modprobe", (RErr, [String "module"]), 194, [], + [InitNone, Always, TestRun [["modprobe"; "ext2"]]], + "load a kernel module", + "\ +This loads a kernel module in the appliance. The kernel module must be available +in the appliance."); + ] let all_functions = non_daemon_functions @ daemon_functions -- 1.6.2.5
Richard W.M. Jones
2009-Aug-18 14:08 UTC
[Libguestfs] [PATCH] guestfs_modprobe: explicitly load a kernel module in the appliance
Try this updated patch: - compiles without warnings - improved the documentation a bit - use 'command' instead of 'commandv' to simplify the code ACK to this updated patch ... Rich. -- Richard Jones, Emerging Technologies, Red Hat http://et.redhat.com/~rjones virt-p2v converts physical machines to virtual machines. Boot with a live CD or over the network (PXE) and turn machines into Xen guests. http://et.redhat.com/~rjones/virt-p2v -------------- next part -------------->From c8c3b2acd2e538179a752bd236e1a690f01ca86f Mon Sep 17 00:00:00 2001From: Matthew Booth <mbooth at redhat.com> Date: Tue, 18 Aug 2009 15:06:20 +0100 Subject: [PATCH] New 'modprobe' command. Allow kernel modules to be loaded into the appliance. --- daemon/Makefile.am | 1 + daemon/modprobe.c | 40 ++++++++++++++++++++++++++++++++++++++++ po/POTFILES.in | 1 + src/MAX_PROC_NR | 2 +- src/generator.ml | 9 +++++++++ 5 files changed, 52 insertions(+), 1 deletions(-) create mode 100644 daemon/modprobe.c diff --git a/daemon/Makefile.am b/daemon/Makefile.am index 097d89d..83ee408 100644 --- a/daemon/Makefile.am +++ b/daemon/Makefile.am @@ -54,6 +54,7 @@ guestfsd_SOURCES = \ lvm.c \ mkfs.c \ mknod.c \ + modprobe.c \ mount.c \ names.c \ ntfs.c \ diff --git a/daemon/modprobe.c b/daemon/modprobe.c new file mode 100644 index 0000000..7e3d1b7 --- /dev/null +++ b/daemon/modprobe.c @@ -0,0 +1,40 @@ +/* libguestfs - the guestfsd daemon + * Copyright (C) 2009 Red Hat Inc. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + */ + +#include <config.h> + +#include <stdio.h> +#include <stdlib.h> + +#include "daemon.h" +#include "actions.h" + +int +do_modprobe (const char *module) +{ + char *err; + int r = command (NULL, &err, "/sbin/modprobe", module, NULL); + + if (r == -1) { + reply_with_error ("%s", err); + } + + free (err); + + return r; +} diff --git a/po/POTFILES.in b/po/POTFILES.in index 33bf6e6..19eef99 100644 --- a/po/POTFILES.in +++ b/po/POTFILES.in @@ -30,6 +30,7 @@ daemon/ls.c daemon/lvm.c daemon/mkfs.c daemon/mknod.c +daemon/modprobe.c daemon/mount.c daemon/names.c daemon/ntfs.c diff --git a/src/MAX_PROC_NR b/src/MAX_PROC_NR index 2455a46..205a12b 100644 --- a/src/MAX_PROC_NR +++ b/src/MAX_PROC_NR @@ -1 +1 @@ -193 +194 diff --git a/src/generator.ml b/src/generator.ml index cc97dd5..18504d5 100755 --- a/src/generator.ml +++ b/src/generator.ml @@ -3560,6 +3560,15 @@ an external journal on the journal with UUID C<uuid>. See also C<guestfs_mke2journal_U>."); + ("modprobe", (RErr, [String "module"]), 194, [], + [InitNone, Always, TestRun [["modprobe"; "ext2"]]], + "load a kernel module", + "\ +This loads a kernel module in the appliance. + +The kernel module must have been whitelisted when libguestfs +was built (see C<appliance/kmod.whitelist.in> in the source)."); + ] let all_functions = non_daemon_functions @ daemon_functions -- 1.6.2.5