提交 19425d11 编写于 作者: C Cole Robinson

qemu: Build nvram directory at driver startup

Similar to what was done for the channel socket in the previous commit.
上级 e31ab02f
...@@ -1985,7 +1985,6 @@ exit 0 ...@@ -1985,7 +1985,6 @@ exit 0
%dir %attr(0700, root, root) %{_localstatedir}/log/libvirt/qemu/ %dir %attr(0700, root, root) %{_localstatedir}/log/libvirt/qemu/
%ghost %dir %attr(0700, root, root) %{_localstatedir}/run/libvirt/qemu/ %ghost %dir %attr(0700, root, root) %{_localstatedir}/run/libvirt/qemu/
%dir %attr(0750, %{qemu_user}, %{qemu_group}) %{_localstatedir}/lib/libvirt/qemu/ %dir %attr(0750, %{qemu_user}, %{qemu_group}) %{_localstatedir}/lib/libvirt/qemu/
%dir %attr(0711, %{qemu_user}, %{qemu_group}) %{_localstatedir}/lib/libvirt/qemu/nvram/
%dir %attr(0750, %{qemu_user}, %{qemu_group}) %{_localstatedir}/cache/libvirt/qemu/ %dir %attr(0750, %{qemu_user}, %{qemu_group}) %{_localstatedir}/cache/libvirt/qemu/
%{_datadir}/augeas/lenses/libvirtd_qemu.aug %{_datadir}/augeas/lenses/libvirtd_qemu.aug
%{_datadir}/augeas/lenses/tests/test_libvirtd_qemu.aug %{_datadir}/augeas/lenses/tests/test_libvirtd_qemu.aug
...@@ -2089,7 +2088,6 @@ exit 0 ...@@ -2089,7 +2088,6 @@ exit 0
%config(noreplace) %{_sysconfdir}/logrotate.d/libvirtd.qemu %config(noreplace) %{_sysconfdir}/logrotate.d/libvirtd.qemu
%ghost %dir %attr(0700, root, root) %{_localstatedir}/run/libvirt/qemu/ %ghost %dir %attr(0700, root, root) %{_localstatedir}/run/libvirt/qemu/
%dir %attr(0750, %{qemu_user}, %{qemu_group}) %{_localstatedir}/lib/libvirt/qemu/ %dir %attr(0750, %{qemu_user}, %{qemu_group}) %{_localstatedir}/lib/libvirt/qemu/
%dir %attr(0711, %{qemu_user}, %{qemu_group}) %{_localstatedir}/lib/libvirt/qemu/nvram/
%dir %attr(0750, %{qemu_user}, %{qemu_group}) %{_localstatedir}/cache/libvirt/qemu/ %dir %attr(0750, %{qemu_user}, %{qemu_group}) %{_localstatedir}/cache/libvirt/qemu/
%{_datadir}/augeas/lenses/libvirtd_qemu.aug %{_datadir}/augeas/lenses/libvirtd_qemu.aug
%{_datadir}/augeas/lenses/tests/test_libvirtd_qemu.aug %{_datadir}/augeas/lenses/tests/test_libvirtd_qemu.aug
......
...@@ -2705,7 +2705,6 @@ if WITH_SANLOCK ...@@ -2705,7 +2705,6 @@ if WITH_SANLOCK
endif WITH_SANLOCK endif WITH_SANLOCK
if WITH_QEMU if WITH_QEMU
$(MKDIR_P) "$(DESTDIR)$(localstatedir)/lib/libvirt/qemu" $(MKDIR_P) "$(DESTDIR)$(localstatedir)/lib/libvirt/qemu"
$(MKDIR_P) "$(DESTDIR)$(localstatedir)/lib/libvirt/qemu/nvram"
$(MKDIR_P) "$(DESTDIR)$(localstatedir)/run/libvirt/qemu" $(MKDIR_P) "$(DESTDIR)$(localstatedir)/run/libvirt/qemu"
$(MKDIR_P) "$(DESTDIR)$(localstatedir)/cache/libvirt/qemu" $(MKDIR_P) "$(DESTDIR)$(localstatedir)/cache/libvirt/qemu"
$(MKDIR_P) "$(DESTDIR)$(localstatedir)/log/libvirt/qemu" $(MKDIR_P) "$(DESTDIR)$(localstatedir)/log/libvirt/qemu"
......
...@@ -208,6 +208,8 @@ virQEMUDriverConfigPtr virQEMUDriverConfigNew(bool privileged) ...@@ -208,6 +208,8 @@ virQEMUDriverConfigPtr virQEMUDriverConfigNew(bool privileged)
if (virAsprintf(&cfg->channelTargetDir, if (virAsprintf(&cfg->channelTargetDir,
"%s/channel/target", cfg->libDir) < 0) "%s/channel/target", cfg->libDir) < 0)
goto error; goto error;
if (virAsprintf(&cfg->nvramDir, "%s/nvram", cfg->libDir) < 0)
goto error;
} else { } else {
char *rundir; char *rundir;
char *cachedir; char *cachedir;
...@@ -250,6 +252,9 @@ virQEMUDriverConfigPtr virQEMUDriverConfigNew(bool privileged) ...@@ -250,6 +252,9 @@ virQEMUDriverConfigPtr virQEMUDriverConfigNew(bool privileged)
if (virAsprintf(&cfg->channelTargetDir, if (virAsprintf(&cfg->channelTargetDir,
"%s/qemu/channel/target", cfg->configBaseDir) < 0) "%s/qemu/channel/target", cfg->configBaseDir) < 0)
goto error; goto error;
if (virAsprintf(&cfg->nvramDir,
"%s/qemu/nvram", cfg->configBaseDir) < 0)
goto error;
} }
if (virAsprintf(&cfg->configDir, "%s/qemu", cfg->configBaseDir) < 0) if (virAsprintf(&cfg->configDir, "%s/qemu", cfg->configBaseDir) < 0)
...@@ -349,6 +354,7 @@ static void virQEMUDriverConfigDispose(void *obj) ...@@ -349,6 +354,7 @@ static void virQEMUDriverConfigDispose(void *obj)
VIR_FREE(cfg->saveDir); VIR_FREE(cfg->saveDir);
VIR_FREE(cfg->snapshotDir); VIR_FREE(cfg->snapshotDir);
VIR_FREE(cfg->channelTargetDir); VIR_FREE(cfg->channelTargetDir);
VIR_FREE(cfg->nvramDir);
VIR_FREE(cfg->vncTLSx509certdir); VIR_FREE(cfg->vncTLSx509certdir);
VIR_FREE(cfg->vncListen); VIR_FREE(cfg->vncListen);
......
...@@ -105,6 +105,7 @@ struct _virQEMUDriverConfig { ...@@ -105,6 +105,7 @@ struct _virQEMUDriverConfig {
char *saveDir; char *saveDir;
char *snapshotDir; char *snapshotDir;
char *channelTargetDir; char *channelTargetDir;
char *nvramDir;
bool vncAutoUnixSocket; bool vncAutoUnixSocket;
bool vncTLS; bool vncTLS;
......
...@@ -709,6 +709,11 @@ qemuStateInitialize(bool privileged, ...@@ -709,6 +709,11 @@ qemuStateInitialize(bool privileged,
virStrerror(errno, ebuf, sizeof(ebuf))); virStrerror(errno, ebuf, sizeof(ebuf)));
goto error; goto error;
} }
if (virFileMakePath(cfg->nvramDir) < 0) {
VIR_ERROR(_("Failed to create nvram dir '%s': %s"),
cfg->nvramDir, virStrerror(errno, ebuf, sizeof(ebuf)));
goto error;
}
qemu_driver->qemuImgBinary = virFindFileInPath("kvm-img"); qemu_driver->qemuImgBinary = virFindFileInPath("kvm-img");
if (!qemu_driver->qemuImgBinary) if (!qemu_driver->qemuImgBinary)
...@@ -825,6 +830,13 @@ qemuStateInitialize(bool privileged, ...@@ -825,6 +830,13 @@ qemuStateInitialize(bool privileged,
(int) cfg->group); (int) cfg->group);
goto error; goto error;
} }
if (chown(cfg->nvramDir, cfg->user, cfg->group) < 0) {
virReportSystemError(errno,
_("unable to set ownership of '%s' to %d:%d"),
cfg->nvramDir, (int) cfg->user,
(int) cfg->group);
goto error;
}
run_uid = cfg->user; run_uid = cfg->user;
run_gid = cfg->group; run_gid = cfg->group;
......
...@@ -4144,8 +4144,8 @@ qemuPrepareNVRAM(virQEMUDriverConfigPtr cfg, ...@@ -4144,8 +4144,8 @@ qemuPrepareNVRAM(virQEMUDriverConfigPtr cfg,
/* Autogenerate nvram path if needed.*/ /* Autogenerate nvram path if needed.*/
if (!loader->nvram) { if (!loader->nvram) {
if (virAsprintf(&loader->nvram, if (virAsprintf(&loader->nvram,
"%s/lib/libvirt/qemu/nvram/%s_VARS.fd", "%s/%s_VARS.fd",
LOCALSTATEDIR, vm->def->name) < 0) cfg->nvramDir, vm->def->name) < 0)
goto cleanup; goto cleanup;
generated = true; generated = true;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册