Accepting request 241206 from home:cbosdonnat:branches:Virtualization
- lxc AppArmor profile now only restricting potentially dangerous accesses. fdo#886460 - added patches: * 9265f8ab-apparmor-lxc-rework.patch * 9b1e4cd5-skip-useless-apparmor-files.patch - virt-lxc-convert: force free to output values in bytes - added patches: * dba3432b-virt-lxc-convert-fix.patch - lxc: allow setting a custom name for container NICs as LXC is is able to do it. lxc-net-target-name.patch, lxc-net-target-name-conversion.patch, lxc-net-target-name-doc.patch OBS-URL: https://build.opensuse.org/request/show/241206 OBS-URL: https://build.opensuse.org/package/show/Virtualization/libvirt?expand=0&rev=390
This commit is contained in:
parent
803ff43893
commit
43a3b335a6
358
9265f8ab-apparmor-lxc-rework.patch
Normal file
358
9265f8ab-apparmor-lxc-rework.patch
Normal file
@ -0,0 +1,358 @@
|
|||||||
|
From 9265f8ab67dc14fe89a26efd5c22b156d3168fd6 Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?C=C3=A9dric=20Bosdonnat?= <cbosdonnat@suse.com>
|
||||||
|
Date: Tue, 15 Jul 2014 11:02:50 +0200
|
||||||
|
Subject: [PATCH] Rework lxc apparmor profile
|
||||||
|
|
||||||
|
Rework the apparmor lxc profile abstraction to mimic ubuntu's container-default.
|
||||||
|
This profile allows quite a lot, but strives to restrict access to
|
||||||
|
dangerous resources.
|
||||||
|
|
||||||
|
Removing the explicit authorizations to bash, systemd and cron files,
|
||||||
|
forces them to keep the lxc profile for all applications inside the
|
||||||
|
container. PUx permissions where leading to running systemd (and others
|
||||||
|
tasks) unconfined.
|
||||||
|
|
||||||
|
Put the generic files, network and capabilities restrictions directly
|
||||||
|
in the TEMPLATE.lxc: this way, users can restrict them on a per
|
||||||
|
container basis.
|
||||||
|
---
|
||||||
|
examples/apparmor/Makefile.am | 6 +-
|
||||||
|
examples/apparmor/TEMPLATE.lxc | 15 ++++
|
||||||
|
examples/apparmor/{TEMPLATE => TEMPLATE.qemu} | 2 +-
|
||||||
|
examples/apparmor/libvirt-lxc | 119 +++++++++++++++++++++++---
|
||||||
|
src/security/security_apparmor.c | 21 +++--
|
||||||
|
src/security/virt-aa-helper.c | 29 +------
|
||||||
|
6 files changed, 149 insertions(+), 43 deletions(-)
|
||||||
|
create mode 100644 examples/apparmor/TEMPLATE.lxc
|
||||||
|
rename examples/apparmor/{TEMPLATE => TEMPLATE.qemu} (75%)
|
||||||
|
|
||||||
|
Index: libvirt-1.2.6/examples/apparmor/Makefile.am
|
||||||
|
===================================================================
|
||||||
|
--- libvirt-1.2.6.orig/examples/apparmor/Makefile.am
|
||||||
|
+++ libvirt-1.2.6/examples/apparmor/Makefile.am
|
||||||
|
@@ -15,7 +15,8 @@
|
||||||
|
## <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
EXTRA_DIST= \
|
||||||
|
- TEMPLATE \
|
||||||
|
+ TEMPLATE.qemu \
|
||||||
|
+ TEMPLATE.lxc \
|
||||||
|
libvirt-qemu \
|
||||||
|
libvirt-lxc \
|
||||||
|
usr.lib.libvirt.virt-aa-helper \
|
||||||
|
@@ -36,6 +37,7 @@ abstractions_DATA = \
|
||||||
|
|
||||||
|
templatesdir = $(apparmordir)/libvirt
|
||||||
|
templates_DATA = \
|
||||||
|
- TEMPLATE \
|
||||||
|
+ TEMPLATE.qemu \
|
||||||
|
+ TEMPLATE.lxc \
|
||||||
|
$(NULL)
|
||||||
|
endif WITH_APPARMOR_PROFILES
|
||||||
|
Index: libvirt-1.2.6/examples/apparmor/TEMPLATE.lxc
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null
|
||||||
|
+++ libvirt-1.2.6/examples/apparmor/TEMPLATE.lxc
|
||||||
|
@@ -0,0 +1,15 @@
|
||||||
|
+#
|
||||||
|
+# This profile is for the domain whose UUID matches this file.
|
||||||
|
+#
|
||||||
|
+
|
||||||
|
+#include <tunables/global>
|
||||||
|
+
|
||||||
|
+profile LIBVIRT_TEMPLATE {
|
||||||
|
+ #include <abstractions/libvirt-lxc>
|
||||||
|
+
|
||||||
|
+ # Globally allows everything to run under this profile
|
||||||
|
+ # These can be narrowed depending on the container's use.
|
||||||
|
+ file,
|
||||||
|
+ capability,
|
||||||
|
+ network,
|
||||||
|
+}
|
||||||
|
Index: libvirt-1.2.6/examples/apparmor/TEMPLATE
|
||||||
|
===================================================================
|
||||||
|
--- libvirt-1.2.6.orig/examples/apparmor/TEMPLATE
|
||||||
|
+++ /dev/null
|
||||||
|
@@ -1,9 +0,0 @@
|
||||||
|
-#
|
||||||
|
-# This profile is for the domain whose UUID matches this file.
|
||||||
|
-#
|
||||||
|
-
|
||||||
|
-#include <tunables/global>
|
||||||
|
-
|
||||||
|
-profile LIBVIRT_TEMPLATE {
|
||||||
|
- #include <abstractions/libvirt-driver>
|
||||||
|
-}
|
||||||
|
Index: libvirt-1.2.6/examples/apparmor/TEMPLATE.qemu
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null
|
||||||
|
+++ libvirt-1.2.6/examples/apparmor/TEMPLATE.qemu
|
||||||
|
@@ -0,0 +1,9 @@
|
||||||
|
+#
|
||||||
|
+# This profile is for the domain whose UUID matches this file.
|
||||||
|
+#
|
||||||
|
+
|
||||||
|
+#include <tunables/global>
|
||||||
|
+
|
||||||
|
+profile LIBVIRT_TEMPLATE {
|
||||||
|
+ #include <abstractions/libvirt-qemu>
|
||||||
|
+}
|
||||||
|
Index: libvirt-1.2.6/examples/apparmor/libvirt-lxc
|
||||||
|
===================================================================
|
||||||
|
--- libvirt-1.2.6.orig/examples/apparmor/libvirt-lxc
|
||||||
|
+++ libvirt-1.2.6/examples/apparmor/libvirt-lxc
|
||||||
|
@@ -2,16 +2,115 @@
|
||||||
|
|
||||||
|
#include <abstractions/base>
|
||||||
|
|
||||||
|
- # Needed for lxc-enter-namespace
|
||||||
|
- capability sys_admin,
|
||||||
|
- capability sys_chroot,
|
||||||
|
-
|
||||||
|
- # Added for lxc-enter-namespace --cmd /bin/bash
|
||||||
|
- /bin/bash PUx,
|
||||||
|
-
|
||||||
|
- /usr/sbin/cron PUx,
|
||||||
|
- /usr/lib/systemd/systemd PUx,
|
||||||
|
-
|
||||||
|
- /usr/lib/libsystemd-*.so.* mr,
|
||||||
|
- /usr/lib/libudev-*.so.* mr,
|
||||||
|
- /etc/ld.so.cache mr,
|
||||||
|
+ umount,
|
||||||
|
+
|
||||||
|
+ # ignore DENIED message on / remount
|
||||||
|
+ deny mount options=(ro, remount) -> /,
|
||||||
|
+
|
||||||
|
+ # allow tmpfs mounts everywhere
|
||||||
|
+ mount fstype=tmpfs,
|
||||||
|
+
|
||||||
|
+ # allow mqueue mounts everywhere
|
||||||
|
+ mount fstype=mqueue,
|
||||||
|
+
|
||||||
|
+ # allow fuse mounts everywhere
|
||||||
|
+ mount fstype=fuse.*,
|
||||||
|
+
|
||||||
|
+ # deny writes in /proc/sys/fs but allow binfmt_misc to be mounted
|
||||||
|
+ mount fstype=binfmt_misc -> /proc/sys/fs/binfmt_misc/,
|
||||||
|
+ deny @{PROC}/sys/fs/** wklx,
|
||||||
|
+
|
||||||
|
+ # allow efivars to be mounted, writing to it will be blocked though
|
||||||
|
+ mount fstype=efivarfs -> /sys/firmware/efi/efivars/,
|
||||||
|
+
|
||||||
|
+ # block some other dangerous paths
|
||||||
|
+ deny @{PROC}/sysrq-trigger rwklx,
|
||||||
|
+ deny @{PROC}/mem rwklx,
|
||||||
|
+ deny @{PROC}/kmem rwklx,
|
||||||
|
+
|
||||||
|
+ # deny writes in /sys except for /sys/fs/cgroup, also allow
|
||||||
|
+ # fusectl, securityfs and debugfs to be mounted there (read-only)
|
||||||
|
+ mount fstype=fusectl -> /sys/fs/fuse/connections/,
|
||||||
|
+ mount fstype=securityfs -> /sys/kernel/security/,
|
||||||
|
+ mount fstype=debugfs -> /sys/kernel/debug/,
|
||||||
|
+ mount fstype=proc -> /proc/,
|
||||||
|
+ mount fstype=sysfs -> /sys/,
|
||||||
|
+ deny /sys/firmware/efi/efivars/** rwklx,
|
||||||
|
+ deny /sys/kernel/security/** rwklx,
|
||||||
|
+
|
||||||
|
+ # generated by: lxc-generate-aa-rules.py container-rules.base
|
||||||
|
+ deny /proc/sys/[^kn]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/k[^e]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/ke[^r]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/ker[^n]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kern[^e]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kerne[^l]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/[^smhd]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/d[^o]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/do[^m]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/dom[^a]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/doma[^i]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/domai[^n]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/domain[^n]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/domainn[^a]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/domainna[^m]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/domainnam[^e]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/domainname?*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/h[^o]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/ho[^s]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/hos[^t]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/host[^n]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/hostn[^a]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/hostna[^m]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/hostnam[^e]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/hostname?*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/m[^s]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/ms[^g]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/msg*/** wklx,
|
||||||
|
+ deny /proc/sys/kernel/s[^he]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/se[^m]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/sem*/** wklx,
|
||||||
|
+ deny /proc/sys/kernel/sh[^m]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/kernel/shm*/** wklx,
|
||||||
|
+ deny /proc/sys/kernel?*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/n[^e]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/ne[^t]*{,/**} wklx,
|
||||||
|
+ deny /proc/sys/net?*{,/**} wklx,
|
||||||
|
+ deny /sys/[^fdc]*{,/**} wklx,
|
||||||
|
+ deny /sys/c[^l]*{,/**} wklx,
|
||||||
|
+ deny /sys/cl[^a]*{,/**} wklx,
|
||||||
|
+ deny /sys/cla[^s]*{,/**} wklx,
|
||||||
|
+ deny /sys/clas[^s]*{,/**} wklx,
|
||||||
|
+ deny /sys/class/[^n]*{,/**} wklx,
|
||||||
|
+ deny /sys/class/n[^e]*{,/**} wklx,
|
||||||
|
+ deny /sys/class/ne[^t]*{,/**} wklx,
|
||||||
|
+ deny /sys/class/net?*{,/**} wklx,
|
||||||
|
+ deny /sys/class?*{,/**} wklx,
|
||||||
|
+ deny /sys/d[^e]*{,/**} wklx,
|
||||||
|
+ deny /sys/de[^v]*{,/**} wklx,
|
||||||
|
+ deny /sys/dev[^i]*{,/**} wklx,
|
||||||
|
+ deny /sys/devi[^c]*{,/**} wklx,
|
||||||
|
+ deny /sys/devic[^e]*{,/**} wklx,
|
||||||
|
+ deny /sys/device[^s]*{,/**} wklx,
|
||||||
|
+ deny /sys/devices/[^v]*{,/**} wklx,
|
||||||
|
+ deny /sys/devices/v[^i]*{,/**} wklx,
|
||||||
|
+ deny /sys/devices/vi[^r]*{,/**} wklx,
|
||||||
|
+ deny /sys/devices/vir[^t]*{,/**} wklx,
|
||||||
|
+ deny /sys/devices/virt[^u]*{,/**} wklx,
|
||||||
|
+ deny /sys/devices/virtu[^a]*{,/**} wklx,
|
||||||
|
+ deny /sys/devices/virtua[^l]*{,/**} wklx,
|
||||||
|
+ deny /sys/devices/virtual/[^n]*{,/**} wklx,
|
||||||
|
+ deny /sys/devices/virtual/n[^e]*{,/**} wklx,
|
||||||
|
+ deny /sys/devices/virtual/ne[^t]*{,/**} wklx,
|
||||||
|
+ deny /sys/devices/virtual/net?*{,/**} wklx,
|
||||||
|
+ deny /sys/devices/virtual?*{,/**} wklx,
|
||||||
|
+ deny /sys/devices?*{,/**} wklx,
|
||||||
|
+ deny /sys/f[^s]*{,/**} wklx,
|
||||||
|
+ deny /sys/fs/[^c]*{,/**} wklx,
|
||||||
|
+ deny /sys/fs/c[^g]*{,/**} wklx,
|
||||||
|
+ deny /sys/fs/cg[^r]*{,/**} wklx,
|
||||||
|
+ deny /sys/fs/cgr[^o]*{,/**} wklx,
|
||||||
|
+ deny /sys/fs/cgro[^u]*{,/**} wklx,
|
||||||
|
+ deny /sys/fs/cgrou[^p]*{,/**} wklx,
|
||||||
|
+ deny /sys/fs/cgroup?*{,/**} wklx,
|
||||||
|
+ deny /sys/fs?*{,/**} wklx,
|
||||||
|
Index: libvirt-1.2.6/src/security/security_apparmor.c
|
||||||
|
===================================================================
|
||||||
|
--- libvirt-1.2.6.orig/src/security/security_apparmor.c
|
||||||
|
+++ libvirt-1.2.6/src/security/security_apparmor.c
|
||||||
|
@@ -351,26 +351,37 @@ AppArmorSetSecuritySCSILabel(virSCSIDevi
|
||||||
|
static int
|
||||||
|
AppArmorSecurityManagerProbe(const char *virtDriver ATTRIBUTE_UNUSED)
|
||||||
|
{
|
||||||
|
- char *template = NULL;
|
||||||
|
+ char *template_qemu = NULL;
|
||||||
|
+ char *template_lxc = NULL;
|
||||||
|
int rc = SECURITY_DRIVER_DISABLE;
|
||||||
|
|
||||||
|
if (use_apparmor() < 0)
|
||||||
|
return rc;
|
||||||
|
|
||||||
|
/* see if template file exists */
|
||||||
|
- if (virAsprintf(&template, "%s/TEMPLATE",
|
||||||
|
+ if (virAsprintf(&template_qemu, "%s/TEMPLATE.qemu",
|
||||||
|
APPARMOR_DIR "/libvirt") == -1)
|
||||||
|
return rc;
|
||||||
|
|
||||||
|
- if (!virFileExists(template)) {
|
||||||
|
+ if (virAsprintf(&template_lxc, "%s/TEMPLATE.lxc",
|
||||||
|
+ APPARMOR_DIR "/libvirt") == -1)
|
||||||
|
+ goto cleanup;
|
||||||
|
+
|
||||||
|
+ if (!virFileExists(template_qemu)) {
|
||||||
|
+ virReportError(VIR_ERR_INTERNAL_ERROR,
|
||||||
|
+ _("template \'%s\' does not exist"), template_qemu);
|
||||||
|
+ goto cleanup;
|
||||||
|
+ }
|
||||||
|
+ if (!virFileExists(template_lxc)) {
|
||||||
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
||||||
|
- _("template \'%s\' does not exist"), template);
|
||||||
|
+ _("template \'%s\' does not exist"), template_lxc);
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
rc = SECURITY_DRIVER_ENABLE;
|
||||||
|
|
||||||
|
cleanup:
|
||||||
|
- VIR_FREE(template);
|
||||||
|
+ VIR_FREE(template_qemu);
|
||||||
|
+ VIR_FREE(template_lxc);
|
||||||
|
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
Index: libvirt-1.2.6/src/security/virt-aa-helper.c
|
||||||
|
===================================================================
|
||||||
|
--- libvirt-1.2.6.orig/src/security/virt-aa-helper.c
|
||||||
|
+++ libvirt-1.2.6/src/security/virt-aa-helper.c
|
||||||
|
@@ -336,24 +336,20 @@ create_profile(const char *profile, cons
|
||||||
|
char *pcontent = NULL;
|
||||||
|
char *replace_name = NULL;
|
||||||
|
char *replace_files = NULL;
|
||||||
|
- char *replace_driver = NULL;
|
||||||
|
const char *template_name = "\nprofile LIBVIRT_TEMPLATE";
|
||||||
|
const char *template_end = "\n}";
|
||||||
|
- const char *template_driver = "libvirt-driver";
|
||||||
|
int tlen, plen;
|
||||||
|
int fd;
|
||||||
|
int rc = -1;
|
||||||
|
- const char *driver_name = "qemu";
|
||||||
|
-
|
||||||
|
- if (virtType == VIR_DOMAIN_VIRT_LXC)
|
||||||
|
- driver_name = "lxc";
|
||||||
|
|
||||||
|
if (virFileExists(profile)) {
|
||||||
|
vah_error(NULL, 0, _("profile exists"));
|
||||||
|
goto end;
|
||||||
|
}
|
||||||
|
|
||||||
|
- if (virAsprintfQuiet(&template, "%s/TEMPLATE", APPARMOR_DIR "/libvirt") < 0) {
|
||||||
|
+
|
||||||
|
+ if (virAsprintfQuiet(&template, "%s/TEMPLATE.%s", APPARMOR_DIR "/libvirt",
|
||||||
|
+ virDomainVirtTypeToString(virtType)) < 0) {
|
||||||
|
vah_error(NULL, 0, _("template name exceeds maximum length"));
|
||||||
|
goto end;
|
||||||
|
}
|
||||||
|
@@ -378,11 +374,6 @@ create_profile(const char *profile, cons
|
||||||
|
goto clean_tcontent;
|
||||||
|
}
|
||||||
|
|
||||||
|
- if (strstr(tcontent, template_driver) == NULL) {
|
||||||
|
- vah_error(NULL, 0, _("no replacement string in template"));
|
||||||
|
- goto clean_tcontent;
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
/* '\nprofile <profile_name>\0' */
|
||||||
|
if (virAsprintfQuiet(&replace_name, "\nprofile %s", profile_name) == -1) {
|
||||||
|
vah_error(NULL, 0, _("could not allocate memory for profile name"));
|
||||||
|
@@ -397,15 +388,7 @@ create_profile(const char *profile, cons
|
||||||
|
goto clean_tcontent;
|
||||||
|
}
|
||||||
|
|
||||||
|
- /* 'libvirt-<driver_name>\0' */
|
||||||
|
- if (virAsprintfQuiet(&replace_driver, "libvirt-%s", driver_name) == -1) {
|
||||||
|
- vah_error(NULL, 0, _("could not allocate memory for profile driver"));
|
||||||
|
- VIR_FREE(replace_driver);
|
||||||
|
- goto clean_tcontent;
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- plen = tlen + strlen(replace_name) - strlen(template_name) +
|
||||||
|
- strlen(replace_driver) - strlen(template_driver) + 1;
|
||||||
|
+ plen = tlen + strlen(replace_name) - strlen(template_name) + 1;
|
||||||
|
|
||||||
|
if (virtType != VIR_DOMAIN_VIRT_LXC)
|
||||||
|
plen += strlen(replace_files) - strlen(template_end);
|
||||||
|
@@ -422,9 +405,6 @@ create_profile(const char *profile, cons
|
||||||
|
pcontent[0] = '\0';
|
||||||
|
strcpy(pcontent, tcontent);
|
||||||
|
|
||||||
|
- if (replace_string(pcontent, plen, template_driver, replace_driver) < 0)
|
||||||
|
- goto clean_all;
|
||||||
|
-
|
||||||
|
if (replace_string(pcontent, plen, template_name, replace_name) < 0)
|
||||||
|
goto clean_all;
|
||||||
|
|
||||||
|
@@ -455,7 +435,6 @@ create_profile(const char *profile, cons
|
||||||
|
clean_replace:
|
||||||
|
VIR_FREE(replace_name);
|
||||||
|
VIR_FREE(replace_files);
|
||||||
|
- VIR_FREE(replace_driver);
|
||||||
|
clean_tcontent:
|
||||||
|
VIR_FREE(tcontent);
|
||||||
|
end:
|
29
9b1e4cd5-skip-useless-apparmor-files.patch
Normal file
29
9b1e4cd5-skip-useless-apparmor-files.patch
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
commit 9b1e4cd5034225c7f750b38968b576c966c51d75
|
||||||
|
Author: Cédric Bosdonnat <cbosdonnat@suse.com>
|
||||||
|
Date: Wed Jul 9 16:15:02 2014 +0200
|
||||||
|
|
||||||
|
Don't output libvirt-UUID.files for LXC apparmor profiles
|
||||||
|
|
||||||
|
---
|
||||||
|
src/security/virt-aa-helper.c | 5 ++++-
|
||||||
|
1 file changed, 4 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/src/security/virt-aa-helper.c b/src/security/virt-aa-helper.c
|
||||||
|
index b5f66f3..c8f17f9 100644
|
||||||
|
--- a/src/security/virt-aa-helper.c
|
||||||
|
+++ b/src/security/virt-aa-helper.c
|
||||||
|
@@ -1342,10 +1342,13 @@ main(int argc, char **argv)
|
||||||
|
vah_info(include_file);
|
||||||
|
vah_info(included_files);
|
||||||
|
rc = 0;
|
||||||
|
+ } else if (ctl->def->virtType == VIR_DOMAIN_VIRT_LXC) {
|
||||||
|
+ rc = 0;
|
||||||
|
} else if ((rc = update_include_file(include_file,
|
||||||
|
included_files,
|
||||||
|
- ctl->append)) != 0)
|
||||||
|
+ ctl->append)) != 0) {
|
||||||
|
goto cleanup;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
|
||||||
|
/* create the profile from TEMPLATE */
|
22
dba3432b-virt-lxc-convert-fix.patch
Normal file
22
dba3432b-virt-lxc-convert-fix.patch
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
From 236a18572216a35f742824f4056108245fac3082 Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?C=C3=A9dric=20Bosdonnat?= <cbosdonnat@suse.com>
|
||||||
|
Date: Fri, 4 Jul 2014 15:57:17 +0200
|
||||||
|
Subject: [PATCH] virt-lxc-convert: make free return values in bytes
|
||||||
|
|
||||||
|
---
|
||||||
|
examples/lxcconvert/virt-lxc-convert | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
Index: libvirt-1.2.5/examples/lxcconvert/virt-lxc-convert
|
||||||
|
===================================================================
|
||||||
|
--- libvirt-1.2.5.orig/examples/lxcconvert/virt-lxc-convert
|
||||||
|
+++ libvirt-1.2.5/examples/lxcconvert/virt-lxc-convert
|
||||||
|
@@ -64,7 +64,7 @@ if test -r "$fstab"; then
|
||||||
|
sed 's/^\([^#]\)/lxc.mount.entry = \1/' "$fstab" >>"${conf_new}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
-memory=$(free | sed -n '/Mem:/s/ \+/ /gp' | cut -f 2 -d ' ')
|
||||||
|
+memory=$(free -b | sed -n '/Mem:/s/ \+/ /gp' | cut -f 2 -d ' ')
|
||||||
|
default_tmpfs="size=$((memory/2))"
|
||||||
|
|
||||||
|
# Do we have tmpfs without size param?
|
@ -2,8 +2,8 @@ Index: libvirt-1.2.6/examples/apparmor/Makefile.am
|
|||||||
===================================================================
|
===================================================================
|
||||||
--- libvirt-1.2.6.orig/examples/apparmor/Makefile.am
|
--- libvirt-1.2.6.orig/examples/apparmor/Makefile.am
|
||||||
+++ libvirt-1.2.6/examples/apparmor/Makefile.am
|
+++ libvirt-1.2.6/examples/apparmor/Makefile.am
|
||||||
@@ -18,10 +18,22 @@ EXTRA_DIST= \
|
@@ -19,10 +19,22 @@ EXTRA_DIST= \
|
||||||
TEMPLATE \
|
TEMPLATE.lxc \
|
||||||
libvirt-qemu \
|
libvirt-qemu \
|
||||||
libvirt-lxc \
|
libvirt-lxc \
|
||||||
- usr.lib.libvirt.virt-aa-helper \
|
- usr.lib.libvirt.virt-aa-helper \
|
||||||
|
@ -1,3 +1,29 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Wed Jul 16 12:07:33 UTC 2014 - cbosdonnat@suse.com
|
||||||
|
|
||||||
|
- lxc AppArmor profile now only restricting potentially dangerous
|
||||||
|
accesses. fdo#886460
|
||||||
|
|
||||||
|
- added patches:
|
||||||
|
* 9265f8ab-apparmor-lxc-rework.patch
|
||||||
|
* 9b1e4cd5-skip-useless-apparmor-files.patch
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Wed Jul 16 11:40:35 UTC 2014 - cbosdonnat@suse.com
|
||||||
|
|
||||||
|
- virt-lxc-convert: force free to output values in bytes
|
||||||
|
|
||||||
|
- added patches:
|
||||||
|
* dba3432b-virt-lxc-convert-fix.patch
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Wed Jul 16 11:33:31 UTC 2014 - cbosdonnat@suse.com
|
||||||
|
|
||||||
|
- lxc: allow setting a custom name for container NICs as LXC is
|
||||||
|
is able to do it.
|
||||||
|
lxc-net-target-name.patch,
|
||||||
|
lxc-net-target-name-conversion.patch,
|
||||||
|
lxc-net-target-name-doc.patch
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Wed Jul 2 12:49:36 MDT 2014 - jfehlig@suse.com
|
Wed Jul 2 12:49:36 MDT 2014 - jfehlig@suse.com
|
||||||
|
|
||||||
|
15
libvirt.spec
15
libvirt.spec
@ -428,6 +428,9 @@ Source1: libvirtd.init
|
|||||||
Source2: libvirtd-relocation-server.fw
|
Source2: libvirtd-relocation-server.fw
|
||||||
Source99: baselibs.conf
|
Source99: baselibs.conf
|
||||||
# Upstream patches
|
# Upstream patches
|
||||||
|
Patch0: dba3432b-virt-lxc-convert-fix.patch
|
||||||
|
Patch1: 9b1e4cd5-skip-useless-apparmor-files.patch
|
||||||
|
Patch2: 9265f8ab-apparmor-lxc-rework.patch
|
||||||
# Need to go upstream
|
# Need to go upstream
|
||||||
Patch100: xen-name-for-devid.patch
|
Patch100: xen-name-for-devid.patch
|
||||||
Patch101: xen-pv-cdrom.patch
|
Patch101: xen-pv-cdrom.patch
|
||||||
@ -436,6 +439,9 @@ Patch102: add-nocow-to-vol-xml.patch
|
|||||||
Patch150: lxc-keep-caps-feature.patch
|
Patch150: lxc-keep-caps-feature.patch
|
||||||
Patch151: lxc-keep-caps-feature-conversion.patch
|
Patch151: lxc-keep-caps-feature-conversion.patch
|
||||||
Patch152: lxc-keep-caps-feature-doc.patch
|
Patch152: lxc-keep-caps-feature-doc.patch
|
||||||
|
Patch153: lxc-net-target-name.patch
|
||||||
|
Patch154: lxc-net-target-name-conversion.patch
|
||||||
|
Patch155: lxc-net-target-name-doc.patch
|
||||||
# Our patches
|
# Our patches
|
||||||
Patch200: libvirtd-defaults.patch
|
Patch200: libvirtd-defaults.patch
|
||||||
Patch201: libvirtd-init-script.patch
|
Patch201: libvirtd-init-script.patch
|
||||||
@ -947,12 +953,18 @@ namespaces.
|
|||||||
|
|
||||||
%prep
|
%prep
|
||||||
%setup -q
|
%setup -q
|
||||||
|
%patch0 -p1
|
||||||
|
%patch1 -p1
|
||||||
|
%patch2 -p1
|
||||||
%patch100 -p1
|
%patch100 -p1
|
||||||
%patch101 -p1
|
%patch101 -p1
|
||||||
%patch102 -p1
|
%patch102 -p1
|
||||||
%patch150 -p1
|
%patch150 -p1
|
||||||
%patch151 -p1
|
%patch151 -p1
|
||||||
%patch152 -p1
|
%patch152 -p1
|
||||||
|
%patch153 -p1
|
||||||
|
%patch154 -p1
|
||||||
|
%patch155 -p1
|
||||||
%patch200 -p1
|
%patch200 -p1
|
||||||
%patch201 -p1
|
%patch201 -p1
|
||||||
%patch202 -p1
|
%patch202 -p1
|
||||||
@ -1488,7 +1500,8 @@ fi
|
|||||||
%config(noreplace) %{_sysconfdir}/apparmor.d/usr.lib.libvirt.virt-aa-helper
|
%config(noreplace) %{_sysconfdir}/apparmor.d/usr.lib.libvirt.virt-aa-helper
|
||||||
%config(noreplace) %{_sysconfdir}/apparmor.d/abstractions/libvirt-qemu
|
%config(noreplace) %{_sysconfdir}/apparmor.d/abstractions/libvirt-qemu
|
||||||
%config(noreplace) %{_sysconfdir}/apparmor.d/abstractions/libvirt-lxc
|
%config(noreplace) %{_sysconfdir}/apparmor.d/abstractions/libvirt-lxc
|
||||||
%config(noreplace) %{_sysconfdir}/apparmor.d/libvirt/TEMPLATE
|
%config(noreplace) %{_sysconfdir}/apparmor.d/libvirt/TEMPLATE.lxc
|
||||||
|
%config(noreplace) %{_sysconfdir}/apparmor.d/libvirt/TEMPLATE.qemu
|
||||||
%{_libdir}/%{name}/virt-aa-helper
|
%{_libdir}/%{name}/virt-aa-helper
|
||||||
%endif
|
%endif
|
||||||
%config %{_fwdefdir}/libvirtd-relocation-server
|
%config %{_fwdefdir}/libvirtd-relocation-server
|
||||||
|
130
lxc-net-target-name-conversion.patch
Normal file
130
lxc-net-target-name-conversion.patch
Normal file
@ -0,0 +1,130 @@
|
|||||||
|
From 27b425b5f77029bf0d322afb930eabf6ec6899e4 Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?C=C3=A9dric=20Bosdonnat?= <cbosdonnat@suse.com>
|
||||||
|
Date: Wed, 2 Jul 2014 15:13:40 +0200
|
||||||
|
Subject: [PATCH 1/2] lxc conf2xml: convert lxc.network.name for veth networks
|
||||||
|
|
||||||
|
---
|
||||||
|
src/lxc/lxc_native.c | 22 ++++++++++++++++------
|
||||||
|
.../lxcconf2xmldata/lxcconf2xml-physnetwork.config | 1 +
|
||||||
|
tests/lxcconf2xmldata/lxcconf2xml-simple.xml | 1 +
|
||||||
|
3 files changed, 18 insertions(+), 6 deletions(-)
|
||||||
|
|
||||||
|
Index: libvirt-1.2.5/src/lxc/lxc_native.c
|
||||||
|
===================================================================
|
||||||
|
--- libvirt-1.2.5.orig/src/lxc/lxc_native.c
|
||||||
|
+++ libvirt-1.2.5/src/lxc/lxc_native.c
|
||||||
|
@@ -338,7 +338,8 @@ lxcCreateNetDef(const char *type,
|
||||||
|
const char *linkdev,
|
||||||
|
const char *mac,
|
||||||
|
const char *flag,
|
||||||
|
- const char *macvlanmode)
|
||||||
|
+ const char *macvlanmode,
|
||||||
|
+ const char *name)
|
||||||
|
{
|
||||||
|
virDomainNetDefPtr net = NULL;
|
||||||
|
virMacAddr macAddr;
|
||||||
|
@@ -353,6 +354,8 @@ lxcCreateNetDef(const char *type,
|
||||||
|
net->linkstate = VIR_DOMAIN_NET_INTERFACE_LINK_STATE_DOWN;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ if (name && VIR_STRDUP(net->ifname_guest, name) < 0)
|
||||||
|
+ goto error;
|
||||||
|
|
||||||
|
if (mac && virMacAddrParse(mac, &macAddr) == 0)
|
||||||
|
net->mac = macAddr;
|
||||||
|
@@ -416,7 +419,8 @@ lxcAddNetworkDefinition(virDomainDefPtr
|
||||||
|
const char *mac,
|
||||||
|
const char *flag,
|
||||||
|
const char *macvlanmode,
|
||||||
|
- const char *vlanid)
|
||||||
|
+ const char *vlanid,
|
||||||
|
+ const char *name)
|
||||||
|
{
|
||||||
|
virDomainNetDefPtr net = NULL;
|
||||||
|
virDomainHostdevDefPtr hostdev = NULL;
|
||||||
|
@@ -452,7 +456,7 @@ lxcAddNetworkDefinition(virDomainDefPtr
|
||||||
|
goto error;
|
||||||
|
def->hostdevs[def->nhostdevs - 1] = hostdev;
|
||||||
|
} else {
|
||||||
|
- if (!(net = lxcCreateNetDef(type, linkdev, mac, flag, macvlanmode)))
|
||||||
|
+ if (!(net = lxcCreateNetDef(type, linkdev, mac, flag, macvlanmode, name)))
|
||||||
|
goto error;
|
||||||
|
|
||||||
|
if (VIR_EXPAND_N(def->nets, def->nnets, 1) < 0)
|
||||||
|
@@ -476,6 +480,7 @@ typedef struct {
|
||||||
|
char *flag;
|
||||||
|
char *macvlanmode;
|
||||||
|
char *vlanid;
|
||||||
|
+ char *name;
|
||||||
|
bool privnet;
|
||||||
|
size_t networks;
|
||||||
|
} lxcNetworkParseData;
|
||||||
|
@@ -492,7 +497,8 @@ lxcNetworkWalkCallback(const char *name,
|
||||||
|
parseData->link, parseData->mac,
|
||||||
|
parseData->flag,
|
||||||
|
parseData->macvlanmode,
|
||||||
|
- parseData->vlanid);
|
||||||
|
+ parseData->vlanid,
|
||||||
|
+ parseData->name);
|
||||||
|
|
||||||
|
if (status < 0)
|
||||||
|
return -1;
|
||||||
|
@@ -508,6 +514,7 @@ lxcNetworkWalkCallback(const char *name,
|
||||||
|
parseData->flag = NULL;
|
||||||
|
parseData->macvlanmode = NULL;
|
||||||
|
parseData->vlanid = NULL;
|
||||||
|
+ parseData->name = NULL;
|
||||||
|
|
||||||
|
/* Keep the new value */
|
||||||
|
parseData->type = value->str;
|
||||||
|
@@ -522,6 +529,8 @@ lxcNetworkWalkCallback(const char *name,
|
||||||
|
parseData->macvlanmode = value->str;
|
||||||
|
else if (STREQ(name, "lxc.network.vlan.id"))
|
||||||
|
parseData->vlanid = value->str;
|
||||||
|
+ else if (STREQ(name, "lxc.network.name"))
|
||||||
|
+ parseData->name = value->str;
|
||||||
|
else if (STRPREFIX(name, "lxc.network"))
|
||||||
|
VIR_WARN("Unhandled network property: %s = %s",
|
||||||
|
name,
|
||||||
|
@@ -535,7 +544,7 @@ lxcConvertNetworkSettings(virDomainDefPt
|
||||||
|
{
|
||||||
|
int status;
|
||||||
|
lxcNetworkParseData data = {def, NULL, NULL, NULL, NULL,
|
||||||
|
- NULL, NULL, true, 0};
|
||||||
|
+ NULL, NULL, NULL, true, 0};
|
||||||
|
|
||||||
|
virConfWalk(properties, lxcNetworkWalkCallback, &data);
|
||||||
|
|
||||||
|
@@ -543,7 +552,8 @@ lxcConvertNetworkSettings(virDomainDefPt
|
||||||
|
status = lxcAddNetworkDefinition(def, data.type, data.link,
|
||||||
|
data.mac, data.flag,
|
||||||
|
data.macvlanmode,
|
||||||
|
- data.vlanid);
|
||||||
|
+ data.vlanid,
|
||||||
|
+ data.name);
|
||||||
|
if (status < 0)
|
||||||
|
return -1;
|
||||||
|
else if (status > 0)
|
||||||
|
Index: libvirt-1.2.5/tests/lxcconf2xmldata/lxcconf2xml-physnetwork.config
|
||||||
|
===================================================================
|
||||||
|
--- libvirt-1.2.5.orig/tests/lxcconf2xmldata/lxcconf2xml-physnetwork.config
|
||||||
|
+++ libvirt-1.2.5/tests/lxcconf2xmldata/lxcconf2xml-physnetwork.config
|
||||||
|
@@ -1,5 +1,6 @@
|
||||||
|
lxc.network.type = phys
|
||||||
|
lxc.network.link = eth0
|
||||||
|
+lxc.network.name = eth1
|
||||||
|
|
||||||
|
lxc.rootfs = /var/lib/lxc/migrate_test/rootfs
|
||||||
|
lxc.utsname = migrate_test
|
||||||
|
Index: libvirt-1.2.5/tests/lxcconf2xmldata/lxcconf2xml-simple.xml
|
||||||
|
===================================================================
|
||||||
|
--- libvirt-1.2.5.orig/tests/lxcconf2xmldata/lxcconf2xml-simple.xml
|
||||||
|
+++ libvirt-1.2.5/tests/lxcconf2xmldata/lxcconf2xml-simple.xml
|
||||||
|
@@ -37,6 +37,7 @@
|
||||||
|
<interface type='bridge'>
|
||||||
|
<mac address='02:00:15:8f:05:c1'/>
|
||||||
|
<source bridge='virbr0'/>
|
||||||
|
+ <guest dev='eth0'/>
|
||||||
|
<link state='up'/>
|
||||||
|
</interface>
|
||||||
|
<console type='pty'>
|
37
lxc-net-target-name-doc.patch
Normal file
37
lxc-net-target-name-doc.patch
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
From c0b1a318442740b6c63630b61d0718598a9937d2 Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?C=C3=A9dric=20Bosdonnat?= <cbosdonnat@suse.com>
|
||||||
|
Date: Wed, 2 Jul 2014 15:24:56 +0200
|
||||||
|
Subject: [PATCH 2/2] lxc network device names change documentation
|
||||||
|
|
||||||
|
---
|
||||||
|
docs/formatdomain.html.in | 17 +++++++++++++++++
|
||||||
|
1 file changed, 17 insertions(+)
|
||||||
|
|
||||||
|
Index: libvirt-1.2.5/docs/formatdomain.html.in
|
||||||
|
===================================================================
|
||||||
|
--- libvirt-1.2.5.orig/docs/formatdomain.html.in
|
||||||
|
+++ libvirt-1.2.5/docs/formatdomain.html.in
|
||||||
|
@@ -3757,6 +3757,23 @@ qemu-kvm -net nic,model=? /dev/null
|
||||||
|
targets using these prefixes will be ignored.
|
||||||
|
</p>
|
||||||
|
|
||||||
|
+ <p>
|
||||||
|
+ Note that for LXC containers, this defines the name of the interface
|
||||||
|
+ on the host side. <span class="since">Since 1.2.7</span>, to define
|
||||||
|
+ the name of the device on the guest side, the <code>guest</code>
|
||||||
|
+ element should be used, as in the following snippet:
|
||||||
|
+ </p>
|
||||||
|
+
|
||||||
|
+<pre>
|
||||||
|
+ ...
|
||||||
|
+ <devices>
|
||||||
|
+ <interface type='network'>
|
||||||
|
+ <source network='default'/>
|
||||||
|
+ <b><guest dev='myeth'/></b>
|
||||||
|
+ </interface>
|
||||||
|
+ </devices>
|
||||||
|
+ ...</pre>
|
||||||
|
+
|
||||||
|
<h5><a name="elementsNICSBoot">Specifying boot order</a></h5>
|
||||||
|
|
||||||
|
<pre>
|
269
lxc-net-target-name.patch
Normal file
269
lxc-net-target-name.patch
Normal file
@ -0,0 +1,269 @@
|
|||||||
|
From 2dd011bd1451e5e6e41c0fbe98884d7594a46dc1 Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?C=C3=A9dric=20Bosdonnat?= <cbosdonnat@suse.com>
|
||||||
|
Date: Fri, 27 Jun 2014 10:41:22 +0200
|
||||||
|
Subject: [PATCH] lxc network configuration allows setting target container NIC
|
||||||
|
name
|
||||||
|
|
||||||
|
LXC network devices can now be assigned a custom NIC device name on the
|
||||||
|
container side. For example, this is configured with:
|
||||||
|
|
||||||
|
<interface type='network'>
|
||||||
|
<source network='default'/>
|
||||||
|
<guest dev="eth1"/>
|
||||||
|
</interface>
|
||||||
|
|
||||||
|
In this example the network card will appear as eth1 in the guest.
|
||||||
|
---
|
||||||
|
docs/schemas/domaincommon.rng | 17 +++++++++++++++++
|
||||||
|
src/conf/domain_conf.c | 27 +++++++++++++++++++++++++++
|
||||||
|
src/conf/domain_conf.h | 2 ++
|
||||||
|
src/lxc/lxc_container.c | 29 +++++++++++++++++++++++++----
|
||||||
|
src/lxc/lxc_process.c | 25 +++++++++++++++++++++++++
|
||||||
|
tests/lxcxml2xmldata/lxc-idmap.xml | 1 +
|
||||||
|
6 files changed, 97 insertions(+), 4 deletions(-)
|
||||||
|
|
||||||
|
Index: libvirt-1.2.5/docs/schemas/domaincommon.rng
|
||||||
|
===================================================================
|
||||||
|
--- libvirt-1.2.5.orig/docs/schemas/domaincommon.rng
|
||||||
|
+++ libvirt-1.2.5/docs/schemas/domaincommon.rng
|
||||||
|
@@ -2165,6 +2165,23 @@
|
||||||
|
</element>
|
||||||
|
</optional>
|
||||||
|
<optional>
|
||||||
|
+ <element name="guest">
|
||||||
|
+ <interleave>
|
||||||
|
+ <optional>
|
||||||
|
+ <attribute name="dev">
|
||||||
|
+ <ref name="deviceName"/>
|
||||||
|
+ </attribute>
|
||||||
|
+ </optional>
|
||||||
|
+ <optional>
|
||||||
|
+ <attribute name="actual">
|
||||||
|
+ <ref name="deviceName"/>
|
||||||
|
+ </attribute>
|
||||||
|
+ </optional>
|
||||||
|
+ </interleave>
|
||||||
|
+ <empty/>
|
||||||
|
+ </element>
|
||||||
|
+ </optional>
|
||||||
|
+ <optional>
|
||||||
|
<element name="mac">
|
||||||
|
<attribute name="address">
|
||||||
|
<ref name="uniMacAddr"/>
|
||||||
|
Index: libvirt-1.2.5/src/conf/domain_conf.c
|
||||||
|
===================================================================
|
||||||
|
--- libvirt-1.2.5.orig/src/conf/domain_conf.c
|
||||||
|
+++ libvirt-1.2.5/src/conf/domain_conf.c
|
||||||
|
@@ -1415,6 +1415,8 @@ void virDomainNetDefFree(virDomainNetDef
|
||||||
|
VIR_FREE(def->virtPortProfile);
|
||||||
|
VIR_FREE(def->script);
|
||||||
|
VIR_FREE(def->ifname);
|
||||||
|
+ VIR_FREE(def->ifname_guest);
|
||||||
|
+ VIR_FREE(def->ifname_guest_actual);
|
||||||
|
|
||||||
|
virDomainDeviceInfoClear(&def->info);
|
||||||
|
|
||||||
|
@@ -6621,6 +6623,8 @@ virDomainNetDefParseXML(virDomainXMLOpti
|
||||||
|
char *bridge = NULL;
|
||||||
|
char *dev = NULL;
|
||||||
|
char *ifname = NULL;
|
||||||
|
+ char *ifname_guest = NULL;
|
||||||
|
+ char *ifname_guest_actual = NULL;
|
||||||
|
char *script = NULL;
|
||||||
|
char *address = NULL;
|
||||||
|
char *port = NULL;
|
||||||
|
@@ -6726,6 +6730,10 @@ virDomainNetDefParseXML(virDomainXMLOpti
|
||||||
|
/* An auto-generated target name, blank it out */
|
||||||
|
VIR_FREE(ifname);
|
||||||
|
}
|
||||||
|
+ } else if ((!ifname_guest || !ifname_guest_actual) &&
|
||||||
|
+ xmlStrEqual(cur->name, BAD_CAST "guest")) {
|
||||||
|
+ ifname_guest = virXMLPropString(cur, "dev");
|
||||||
|
+ ifname_guest_actual = virXMLPropString(cur, "actual");
|
||||||
|
} else if (!linkstate &&
|
||||||
|
xmlStrEqual(cur->name, BAD_CAST "link")) {
|
||||||
|
linkstate = virXMLPropString(cur, "state");
|
||||||
|
@@ -6967,6 +6975,14 @@ virDomainNetDefParseXML(virDomainXMLOpti
|
||||||
|
def->ifname = ifname;
|
||||||
|
ifname = NULL;
|
||||||
|
}
|
||||||
|
+ if (ifname_guest != NULL) {
|
||||||
|
+ def->ifname_guest = ifname_guest;
|
||||||
|
+ ifname_guest = NULL;
|
||||||
|
+ }
|
||||||
|
+ if (ifname_guest_actual != NULL) {
|
||||||
|
+ def->ifname_guest_actual = ifname_guest_actual;
|
||||||
|
+ ifname_guest_actual = NULL;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
/* NIC model (see -net nic,model=?). We only check that it looks
|
||||||
|
* reasonable, not that it is a supported NIC type. FWIW kvm
|
||||||
|
@@ -15918,6 +15934,17 @@ virDomainNetDefFormat(virBufferPtr buf,
|
||||||
|
/* Skip auto-generated target names for inactive config. */
|
||||||
|
virBufferEscapeString(buf, "<target dev='%s'/>\n", def->ifname);
|
||||||
|
}
|
||||||
|
+ if (def->ifname_guest || def->ifname_guest_actual) {
|
||||||
|
+ virBufferAddLit(buf, "<guest");
|
||||||
|
+ /* Skip auto-generated target names for inactive config. */
|
||||||
|
+ if (def->ifname_guest)
|
||||||
|
+ virBufferEscapeString(buf, " dev='%s'", def->ifname_guest);
|
||||||
|
+
|
||||||
|
+ /* Only set if the host is running, so shouldn't pollute output */
|
||||||
|
+ if (def->ifname_guest_actual)
|
||||||
|
+ virBufferEscapeString(buf, " actual='%s'", def->ifname_guest_actual);
|
||||||
|
+ virBufferAddLit(buf, "/>\n");
|
||||||
|
+ }
|
||||||
|
if (def->model) {
|
||||||
|
virBufferEscapeString(buf, "<model type='%s'/>\n",
|
||||||
|
def->model);
|
||||||
|
Index: libvirt-1.2.5/src/conf/domain_conf.h
|
||||||
|
===================================================================
|
||||||
|
--- libvirt-1.2.5.orig/src/conf/domain_conf.h
|
||||||
|
+++ libvirt-1.2.5/src/conf/domain_conf.h
|
||||||
|
@@ -916,6 +916,8 @@ struct _virDomainNetDef {
|
||||||
|
} tune;
|
||||||
|
char *script;
|
||||||
|
char *ifname;
|
||||||
|
+ char *ifname_guest;
|
||||||
|
+ char *ifname_guest_actual;
|
||||||
|
virDomainDeviceInfo info;
|
||||||
|
char *filter;
|
||||||
|
virNWFilterHashTablePtr filterparams;
|
||||||
|
Index: libvirt-1.2.5/src/lxc/lxc_container.c
|
||||||
|
===================================================================
|
||||||
|
--- libvirt-1.2.5.orig/src/lxc/lxc_container.c
|
||||||
|
+++ libvirt-1.2.5/src/lxc/lxc_container.c
|
||||||
|
@@ -464,6 +464,21 @@ static int lxcContainerSetID(virDomainDe
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
+static virDomainNetDefPtr
|
||||||
|
+lxcContainerGetNetDef(virDomainDefPtr vmDef, const char *devName)
|
||||||
|
+{
|
||||||
|
+ size_t i;
|
||||||
|
+ virDomainNetDefPtr netDef;
|
||||||
|
+
|
||||||
|
+ for (i = 0; i < vmDef->nnets; i++) {
|
||||||
|
+ netDef = vmDef->nets[i];
|
||||||
|
+ if (STREQ(netDef->ifname_guest_actual, devName))
|
||||||
|
+ return netDef;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return NULL;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
/**
|
||||||
|
* lxcContainerRenameAndEnableInterfaces:
|
||||||
|
* @nveths: number of interfaces
|
||||||
|
@@ -475,16 +490,23 @@ static int lxcContainerSetID(virDomainDe
|
||||||
|
*
|
||||||
|
* Returns 0 on success or nonzero in case of error
|
||||||
|
*/
|
||||||
|
-static int lxcContainerRenameAndEnableInterfaces(bool privNet,
|
||||||
|
+static int lxcContainerRenameAndEnableInterfaces(virDomainDefPtr vmDef,
|
||||||
|
size_t nveths,
|
||||||
|
char **veths)
|
||||||
|
{
|
||||||
|
int rc = 0;
|
||||||
|
size_t i;
|
||||||
|
char *newname = NULL;
|
||||||
|
+ virDomainNetDefPtr netDef;
|
||||||
|
+ bool privNet = vmDef->features[VIR_DOMAIN_FEATURE_PRIVNET] ==
|
||||||
|
+ VIR_DOMAIN_FEATURE_STATE_ON;
|
||||||
|
|
||||||
|
for (i = 0; i < nveths; i++) {
|
||||||
|
- if (virAsprintf(&newname, "eth%zu", i) < 0) {
|
||||||
|
+ if (!(netDef = lxcContainerGetNetDef(vmDef, veths[i])))
|
||||||
|
+ return -1;
|
||||||
|
+
|
||||||
|
+ newname = netDef->ifname_guest;
|
||||||
|
+ if (!newname) {
|
||||||
|
rc = -1;
|
||||||
|
goto error_out;
|
||||||
|
}
|
||||||
|
@@ -2074,8 +2096,7 @@ static int lxcContainerChild(void *data)
|
||||||
|
}
|
||||||
|
|
||||||
|
/* rename and enable interfaces */
|
||||||
|
- if (lxcContainerRenameAndEnableInterfaces(vmDef->features[VIR_DOMAIN_FEATURE_PRIVNET] ==
|
||||||
|
- VIR_DOMAIN_FEATURE_STATE_ON,
|
||||||
|
+ if (lxcContainerRenameAndEnableInterfaces(vmDef,
|
||||||
|
argv->nveths,
|
||||||
|
argv->veths) < 0) {
|
||||||
|
goto cleanup;
|
||||||
|
Index: libvirt-1.2.5/src/lxc/lxc_process.c
|
||||||
|
===================================================================
|
||||||
|
--- libvirt-1.2.5.orig/src/lxc/lxc_process.c
|
||||||
|
+++ libvirt-1.2.5/src/lxc/lxc_process.c
|
||||||
|
@@ -259,6 +259,8 @@ char *virLXCProcessSetupInterfaceBridged
|
||||||
|
|
||||||
|
if (virNetDevSetMAC(containerVeth, &net->mac) < 0)
|
||||||
|
goto cleanup;
|
||||||
|
+ if (VIR_STRDUP(net->ifname_guest_actual, containerVeth) < 0)
|
||||||
|
+ goto cleanup;
|
||||||
|
|
||||||
|
if (vport && vport->virtPortType == VIR_NETDEV_VPORT_PROFILE_OPENVSWITCH) {
|
||||||
|
if (virNetDevOpenvswitchAddPort(brname, parentVeth, &net->mac,
|
||||||
|
@@ -369,6 +371,7 @@ static int virLXCProcessSetupInterfaces(
|
||||||
|
{
|
||||||
|
int ret = -1;
|
||||||
|
size_t i;
|
||||||
|
+ size_t niface = 0;
|
||||||
|
|
||||||
|
for (i = 0; i < def->nnets; i++) {
|
||||||
|
char *veth = NULL;
|
||||||
|
@@ -451,6 +454,13 @@ static int virLXCProcessSetupInterfaces(
|
||||||
|
}
|
||||||
|
|
||||||
|
(*veths)[(*nveths)-1] = veth;
|
||||||
|
+
|
||||||
|
+ /* Make sure all net definitions will have a name in the container */
|
||||||
|
+ if (!def->nets[i]->ifname_guest) {
|
||||||
|
+ if (virAsprintf(&def->nets[i]->ifname_guest, "eth%zu", niface) < 0)
|
||||||
|
+ return -1;
|
||||||
|
+ niface++;
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = 0;
|
||||||
|
@@ -470,6 +480,18 @@ static int virLXCProcessSetupInterfaces(
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
+static void
|
||||||
|
+virLXCProcessCleanInterfaces(virDomainDefPtr def)
|
||||||
|
+{
|
||||||
|
+ size_t i;
|
||||||
|
+
|
||||||
|
+ for (i = 0; i < def->nnets; i++) {
|
||||||
|
+ VIR_FREE(def->nets[i]->ifname_guest_actual);
|
||||||
|
+ def->nets[i]->ifname_guest_actual = NULL;
|
||||||
|
+ VIR_DEBUG("Cleared net names: %s", def->nets[i]->ifname_guest);
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
|
||||||
|
extern virLXCDriverPtr lxc_driver;
|
||||||
|
static void virLXCProcessMonitorEOFNotify(virLXCMonitorPtr mon,
|
||||||
|
@@ -1306,6 +1328,9 @@ int virLXCProcessStart(virConnectPtr con
|
||||||
|
vm, false) < 0)
|
||||||
|
goto error;
|
||||||
|
|
||||||
|
+ /* We don't need the temporary NIC names anymore, clear them */
|
||||||
|
+ virLXCProcessCleanInterfaces(vm->def);
|
||||||
|
+
|
||||||
|
/* Write domain status to disk.
|
||||||
|
*
|
||||||
|
* XXX: Earlier we wrote the plain "live" domain XML to this
|
||||||
|
Index: libvirt-1.2.5/tests/lxcxml2xmldata/lxc-idmap.xml
|
||||||
|
===================================================================
|
||||||
|
--- libvirt-1.2.5.orig/tests/lxcxml2xmldata/lxc-idmap.xml
|
||||||
|
+++ libvirt-1.2.5/tests/lxcxml2xmldata/lxc-idmap.xml
|
||||||
|
@@ -29,6 +29,7 @@
|
||||||
|
<mac address='00:16:3e:0f:ef:8a'/>
|
||||||
|
<source bridge='bri0'/>
|
||||||
|
<target dev='veth0'/>
|
||||||
|
+ <guest dev='eth2'/>
|
||||||
|
</interface>
|
||||||
|
<console type='pty'>
|
||||||
|
<target type='lxc' port='0'/>
|
Loading…
Reference in New Issue
Block a user