Roger Pau Monne
2012-Aug-14 18:15 UTC
[PATCH] libxl: fix usage of backend parameter and run_hotplug_scripts
vif interfaces allows the user to specify the domain that should run
the backend (also known as driver domain) using the ''backend''
parameter. This is not compatible with run_hotplug_scripts=1, since
libxl can only run the hotplug scripts from the Domain 0.
Signed-off-by: Roger Pau Monne <roger.pau@citrix.com>
---
docs/misc/xl-network-configuration.markdown | 6 ++++--
tools/libxl/libxl.c | 14 ++++++++++++++
2 files changed, 18 insertions(+), 2 deletions(-)
diff --git a/docs/misc/xl-network-configuration.markdown
b/docs/misc/xl-network-configuration.markdown
index 650926c..5e2f049 100644
--- a/docs/misc/xl-network-configuration.markdown
+++ b/docs/misc/xl-network-configuration.markdown
@@ -122,8 +122,10 @@ specified IP address to be used by the guest (blocking all
others).
### backend
Specifies the backend domain which this device should attach to. This
-defaults to domain 0. Specifying another domain requires setting up a
-driver domain which is outside the scope of this document.
+defaults to domain 0. This option does not work if `run_hotplug_scripts`
+is not disabled in xl.conf (see xl.conf(5) man page for more information
+on this option). Specifying another domain requires setting up a driver
+domain which is outside the scope of this document.
### rate
diff --git a/tools/libxl/libxl.c b/tools/libxl/libxl.c
index 8ea3478..6b85cdc 100644
--- a/tools/libxl/libxl.c
+++ b/tools/libxl/libxl.c
@@ -2474,6 +2474,8 @@ out:
int libxl__device_nic_setdefault(libxl__gc *gc, libxl_device_nic *nic,
uint32_t domid)
{
+ int run_hotplug_scripts;
+
if (!nic->mtu)
nic->mtu = 1492;
if (!nic->model) {
@@ -2503,6 +2505,18 @@ int libxl__device_nic_setdefault(libxl__gc *gc,
libxl_device_nic *nic,
libxl__xen_script_dir_path()) < 0 )
return ERROR_FAIL;
+ run_hotplug_scripts = libxl__hotplug_settings(gc, XBT_NULL);
+ if (run_hotplug_scripts < 0) {
+ LOG(ERROR, "unable to get current hotplug scripts execution
setting");
+ return run_hotplug_scripts;
+ }
+ if (nic->backend_domid != LIBXL_TOOLSTACK_DOMID &&
run_hotplug_scripts) {
+ LOG(ERROR, "the vif ''backend='' option cannot be
used in conjunction "
+ "with run_hotplug_scripts, please set
run_hotplug_scripts "
+ "to 0 in xl.conf");
+ return ERROR_FAIL;
+ }
+
switch (libxl__domain_type(gc, domid)) {
case LIBXL_DOMAIN_TYPE_HVM:
if (!nic->nictype)
--
1.7.7.5 (Apple Git-26)
Ian Campbell
2012-Aug-15 08:54 UTC
Re: [PATCH] libxl: fix usage of backend parameter and run_hotplug_scripts
On Tue, 2012-08-14 at 19:15 +0100, Roger Pau Monne wrote:> vif interfaces allows the user to specify the domain that should run > the backend (also known as driver domain) using the ''backend'' > parameter. This is not compatible with run_hotplug_scripts=1, since > libxl can only run the hotplug scripts from the Domain 0. > > Signed-off-by: Roger Pau Monne <roger.pau@citrix.com> > --- > docs/misc/xl-network-configuration.markdown | 6 ++++-- > tools/libxl/libxl.c | 14 ++++++++++++++ > 2 files changed, 18 insertions(+), 2 deletions(-) > > diff --git a/docs/misc/xl-network-configuration.markdown b/docs/misc/xl-network-configuration.markdown > index 650926c..5e2f049 100644 > --- a/docs/misc/xl-network-configuration.markdown > +++ b/docs/misc/xl-network-configuration.markdown > @@ -122,8 +122,10 @@ specified IP address to be used by the guest (blocking all others). > ### backend > > Specifies the backend domain which this device should attach to. This > -defaults to domain 0. Specifying another domain requires setting up a > -driver domain which is outside the scope of this document. > +defaults to domain 0. This option does not work if `run_hotplug_scripts` > +is not disabled in xl.conf (see xl.conf(5) man page for more information > +on this option). Specifying another domain requires setting up a driver > +domain which is outside the scope of this document. > > ### rate > > diff --git a/tools/libxl/libxl.c b/tools/libxl/libxl.c > index 8ea3478..6b85cdc 100644 > --- a/tools/libxl/libxl.c > +++ b/tools/libxl/libxl.c > @@ -2474,6 +2474,8 @@ out: > int libxl__device_nic_setdefault(libxl__gc *gc, libxl_device_nic *nic, > uint32_t domid) > { > + int run_hotplug_scripts; > + > if (!nic->mtu) > nic->mtu = 1492; > if (!nic->model) { > @@ -2503,6 +2505,18 @@ int libxl__device_nic_setdefault(libxl__gc *gc, libxl_device_nic *nic, > libxl__xen_script_dir_path()) < 0 ) > return ERROR_FAIL; > > + run_hotplug_scripts = libxl__hotplug_settings(gc, XBT_NULL); > + if (run_hotplug_scripts < 0) { > + LOG(ERROR, "unable to get current hotplug scripts execution setting");Include the error value?> + return run_hotplug_scripts; > + } > + if (nic->backend_domid != LIBXL_TOOLSTACK_DOMID && run_hotplug_scripts) { > + LOG(ERROR, "the vif ''backend='' option cannot be used in conjunction " > + "with run_hotplug_scripts, please set run_hotplug_scripts " > + "to 0 in xl.conf");This mention of xl.conf in libxl is a layering violation. I think it would be fine for libxl to log something generic about hotplug scripts and return an error and to have a more specific check t parse time in xl which errors out with a reference to the config option.> + return ERROR_FAIL; > + } > + > switch (libxl__domain_type(gc, domid)) { > case LIBXL_DOMAIN_TYPE_HVM: > if (!nic->nictype)
Roger Pau Monne
2012-Aug-23 17:16 UTC
Re: [PATCH] libxl: fix usage of backend parameter and run_hotplug_scripts
Ian Campbell wrote:> On Tue, 2012-08-14 at 19:15 +0100, Roger Pau Monne wrote: >> vif interfaces allows the user to specify the domain that should run >> the backend (also known as driver domain) using the ''backend'' >> parameter. This is not compatible with run_hotplug_scripts=1, since >> libxl can only run the hotplug scripts from the Domain 0. >> >> Signed-off-by: Roger Pau Monne <roger.pau@citrix.com> >> --- >> docs/misc/xl-network-configuration.markdown | 6 ++++-- >> tools/libxl/libxl.c | 14 ++++++++++++++ >> 2 files changed, 18 insertions(+), 2 deletions(-) >> >> diff --git a/docs/misc/xl-network-configuration.markdown b/docs/misc/xl-network-configuration.markdown >> index 650926c..5e2f049 100644 >> --- a/docs/misc/xl-network-configuration.markdown >> +++ b/docs/misc/xl-network-configuration.markdown >> @@ -122,8 +122,10 @@ specified IP address to be used by the guest (blocking all others). >> ### backend >> >> Specifies the backend domain which this device should attach to. This >> -defaults to domain 0. Specifying another domain requires setting up a >> -driver domain which is outside the scope of this document. >> +defaults to domain 0. This option does not work if `run_hotplug_scripts` >> +is not disabled in xl.conf (see xl.conf(5) man page for more information >> +on this option). Specifying another domain requires setting up a driver >> +domain which is outside the scope of this document. >> >> ### rate >> >> diff --git a/tools/libxl/libxl.c b/tools/libxl/libxl.c >> index 8ea3478..6b85cdc 100644 >> --- a/tools/libxl/libxl.c >> +++ b/tools/libxl/libxl.c >> @@ -2474,6 +2474,8 @@ out: >> int libxl__device_nic_setdefault(libxl__gc *gc, libxl_device_nic *nic, >> uint32_t domid) >> { >> + int run_hotplug_scripts; >> + >> if (!nic->mtu) >> nic->mtu = 1492; >> if (!nic->model) { >> @@ -2503,6 +2505,18 @@ int libxl__device_nic_setdefault(libxl__gc *gc, libxl_device_nic *nic, >> libxl__xen_script_dir_path()) < 0 ) >> return ERROR_FAIL; >> >> + run_hotplug_scripts = libxl__hotplug_settings(gc, XBT_NULL); >> + if (run_hotplug_scripts < 0) { >> + LOG(ERROR, "unable to get current hotplug scripts execution setting"); > > Include the error value?libxl__hotplug_settings already prints an error message, that contains the errno value. I think that''s enough.>> + return run_hotplug_scripts; >> + } >> + if (nic->backend_domid != LIBXL_TOOLSTACK_DOMID && run_hotplug_scripts) { >> + LOG(ERROR, "the vif ''backend='' option cannot be used in conjunction " >> + "with run_hotplug_scripts, please set run_hotplug_scripts " >> + "to 0 in xl.conf"); > > This mention of xl.conf in libxl is a layering violation. > > I think it would be fine for libxl to log something generic about > hotplug scripts and return an error and to have a more specific check t > parse time in xl which errors out with a reference to the config option.Ok, I will probably split this in two patches, one for libxl and one for the parser. Thanks for the review.
Ian Campbell
2012-Aug-31 09:27 UTC
Re: [PATCH] libxl: fix usage of backend parameter and run_hotplug_scripts
On Thu, 2012-08-23 at 18:16 +0100, Roger Pau Monne wrote:> Ok, I will probably split this in two patches, one for libxl and one > for the parser.Are you still indenting to do this for 4.2.0? It''s fast approaching... Ian.
Roger Pau Monne
2012-Aug-31 18:22 UTC
Re: [PATCH] libxl: fix usage of backend parameter and run_hotplug_scripts
Ian Campbell wrote:> On Thu, 2012-08-23 at 18:16 +0100, Roger Pau Monne wrote: >> Ok, I will probably split this in two patches, one for libxl and one >> for the parser. > > Are you still indenting to do this for 4.2.0? It''s fast approaching...Yes, sorry for the delay. I will try to submit a patch for it on Tuesday.
Maybe Matching Threads
- [PATCH v4 1/2] libxl: postpone backend name resolution
- [PATCH] libxl: make nic 'bridge' parameter optional - do not fill default
- [PATCH 0/4] Coverity fixes for tools/libxl
- Network with xen 4.2
- [PATCH] xl: extend autoballoon xl.conf option with an "auto" option