]> git.ipfire.org Git - thirdparty/libvirt.git/commitdiff
virNetDevSaveNetConfig: Pass mode to virFileWriteStr()
authorMichal Privoznik <mprivozn@redhat.com>
Mon, 13 Jun 2022 12:20:06 +0000 (14:20 +0200)
committerMichal Privoznik <mprivozn@redhat.com>
Mon, 13 Jun 2022 14:06:44 +0000 (16:06 +0200)
For some types of SRIOV interfaces we create a temporary file
where the state of the interface is saved before we start
modifying it. The file is used then to restore the original
configuration when the interface is no longer associated with any
guest. For writing the file virFileWriteStr() is used. However,
it's given wrong argument: the last argument is supposed to be
mode to create the file with but virNetDevSaveNetConfig() passes
open(2) flags (O_CREAT|O_TRUNC|O_WRONLY). We need the file to be
writable and readable by root only (0600). Therefore, pass that
mode instead of gibberish.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
src/util/virnetdev.c

index 93f836cd92b13af946f2cbb999ebbac804d71604..6c6f6dee42a99c0341a0012421fb112abe9d5394 100644 (file)
@@ -1977,7 +1977,7 @@ virNetDevSaveNetConfig(const char *linkdev, int vf,
     if (!(fileStr = virJSONValueToString(configJSON, true)))
         return -1;
 
-    if (virFileWriteStr(filePath, fileStr, O_CREAT|O_TRUNC|O_WRONLY) < 0) {
+    if (virFileWriteStr(filePath, fileStr, 0600) < 0) {
         virReportSystemError(errno, _("Unable to preserve mac/vlan tag "
                                       "for device = %s, vf = %d"), linkdev, vf);
         return -1;