render / rpms / libvirt

Forked from rpms/libvirt 11 months ago
Clone
d76c62
From 4f9e2b4b36fda208d25acf4126abbf4fee37f0b5 Mon Sep 17 00:00:00 2001
d76c62
Message-Id: <4f9e2b4b36fda208d25acf4126abbf4fee37f0b5@dist-git>
d76c62
From: Michal Privoznik <mprivozn@redhat.com>
d76c62
Date: Tue, 25 Feb 2020 11:24:52 +0100
d76c62
Subject: [PATCH] security: Don't fail if locking a file on NFS mount fails
d76c62
d76c62
The way that our file locking works is that we open() the file we
d76c62
want to lock and then use fcntl(fd, F_SETLKW, ...) to lock it.
d76c62
The problem is, we are doing all of these as root which doesn't
d76c62
work if the file lives on root squashed NFS, because if it does
d76c62
then the open() fails. The way to resolve this is to make this a
d76c62
non fatal error and leave callers deal with this (i.e. disable
d76c62
remembering) - implemented in the previous commit.
d76c62
d76c62
https://bugzilla.redhat.com/show_bug.cgi?id=1804672
d76c62
d76c62
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
d76c62
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
d76c62
(cherry picked from commit f16663d58f7aab6bf800fcffd34f83f522927897)
d76c62
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
d76c62
Message-Id: <d3cb3d3214cf3e67bd357fa9781ce55f8dc8c751.1582626185.git.mprivozn@redhat.com>
d76c62
Reviewed-by: Jiri Denemark <jdenemar@redhat.com>
d76c62
---
d76c62
 src/security/security_manager.c | 5 +++++
d76c62
 1 file changed, 5 insertions(+)
d76c62
d76c62
diff --git a/src/security/security_manager.c b/src/security/security_manager.c
d76c62
index 9d06316a99..23ed6a127c 100644
d76c62
--- a/src/security/security_manager.c
d76c62
+++ b/src/security/security_manager.c
d76c62
@@ -1343,6 +1343,11 @@ virSecurityManagerMetadataLock(virSecurityManagerPtr mgr G_GNUC_UNUSED,
d76c62
                 continue;
d76c62
             }
d76c62
 
d76c62
+            if (virFileIsSharedFS(p)) {
d76c62
+                /* Probably a root squashed NFS. */
d76c62
+                continue;
d76c62
+            }
d76c62
+
d76c62
             virReportSystemError(errno,
d76c62
                                  _("unable to open %s"),
d76c62
                                  p);
d76c62
-- 
d76c62
2.25.1
d76c62