mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-20 11:35:19 +00:00
security: apparmor: load the storage driver dynamically
In commit 5e515b542d I've attempted to fix the inability to access storage from the apparmor helper program by linking with the storage driver. By linking with the .so the linker complains that it's not portable. Fix this by loading the module dynamically as we are supposed to do. Reviewed-by: Daniel P. Berrange <berrange@redhat.com>
This commit is contained in:
parent
5aec02dc37
commit
6cf7fc573f
@ -3124,7 +3124,7 @@ virt_aa_helper_LDADD = \
|
|||||||
libvirt.la \
|
libvirt.la \
|
||||||
libvirt_conf.la \
|
libvirt_conf.la \
|
||||||
libvirt_util.la \
|
libvirt_util.la \
|
||||||
libvirt_driver_storage.la \
|
libvirt_driver_storage_impl.la \
|
||||||
../gnulib/lib/libgnu.la
|
../gnulib/lib/libgnu.la
|
||||||
if WITH_DTRACE_PROBES
|
if WITH_DTRACE_PROBES
|
||||||
virt_aa_helper_LDADD += libvirt_probes.lo
|
virt_aa_helper_LDADD += libvirt_probes.lo
|
||||||
|
@ -41,6 +41,7 @@
|
|||||||
#include "viralloc.h"
|
#include "viralloc.h"
|
||||||
#include "vircommand.h"
|
#include "vircommand.h"
|
||||||
#include "virlog.h"
|
#include "virlog.h"
|
||||||
|
#include "driver.h"
|
||||||
|
|
||||||
#include "security_driver.h"
|
#include "security_driver.h"
|
||||||
#include "security_apparmor.h"
|
#include "security_apparmor.h"
|
||||||
@ -56,7 +57,6 @@
|
|||||||
#include "virgettext.h"
|
#include "virgettext.h"
|
||||||
|
|
||||||
#include "storage/storage_source.h"
|
#include "storage/storage_source.h"
|
||||||
#include "storage/storage_backend.h"
|
|
||||||
|
|
||||||
#define VIR_FROM_THIS VIR_FROM_SECURITY
|
#define VIR_FROM_THIS VIR_FROM_SECURITY
|
||||||
|
|
||||||
@ -927,10 +927,10 @@ get_files(vahControl * ctl)
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (virStorageBackendDriversRegister(false) < 0) {
|
/* load the storage driver so that backing store can be accessed */
|
||||||
vah_error(ctl, 0, _("failed to register storage driver backend"));
|
#ifdef WITH_STORAGE
|
||||||
goto cleanup;
|
virDriverLoadModule("storage", "storageRegister");
|
||||||
}
|
#endif
|
||||||
|
|
||||||
for (i = 0; i < ctl->def->ndisks; i++) {
|
for (i = 0; i < ctl->def->ndisks; i++) {
|
||||||
virDomainDiskDefPtr disk = ctl->def->disks[i];
|
virDomainDiskDefPtr disk = ctl->def->disks[i];
|
||||||
|
Loading…
x
Reference in New Issue
Block a user