Blame 0001-VBoxServiceAutoMount-Change-Linux-mount-code-to-use-.patch

32e434
From 369dd2ee3c82c4417fee04aeec933c74fd198e78 Mon Sep 17 00:00:00 2001
32e434
From: Hans de Goede <hdegoede@redhat.com>
32e434
Date: Tue, 23 Jan 2018 15:09:20 +0100
32e434
Subject: [PATCH resend] VBoxServiceAutoMount: Change Linux mount code to use
32e434
 an options string
32e434
32e434
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
32e434
---
32e434
 .../common/VBoxService/VBoxServiceAutoMount.cpp    | 62 +++-------------------
32e434
 1 file changed, 8 insertions(+), 54 deletions(-)
32e434
32e434
diff --git a/src/VBox/Additions/common/VBoxService/VBoxServiceAutoMount.cpp b/src/VBox/Additions/common/VBoxService/VBoxServiceAutoMount.cpp
b22ed6
--- ./src/VBox/Additions/common/VBoxService/VBoxServiceAutoMount.cpp.orig	2019-04-16 11:09:11.000000000 +0100
b22ed6
+++ ./src/VBox/Additions/common/VBoxService/VBoxServiceAutoMount.cpp	2019-04-26 17:10:47.178485356 +0100
8c7d23
@@ -40,6 +40,7 @@
8c7d23
 #include <iprt/ctype.h>
32e434
 #include <iprt/dir.h>
32e434
 #include <iprt/mem.h>
32e434
+#include <iprt/param.h>
32e434
 #include <iprt/path.h>
32e434
 #include <iprt/semaphore.h>
8c7d23
 #include <iprt/sort.h>
b22ed6
@@ -114,6 +115,9 @@ RT_C_DECLS_END
8c7d23
 # define VBOXSERVICE_AUTOMOUNT_MIQF             SHFL_MIQF_PATH
32e434
 #endif
32e434
 
32e434
+#ifndef MAX_MNTOPT_STR
32e434
+#define MAX_MNTOPT_STR PAGE_SIZE
32e434
+#endif
32e434
 
32e434
 /*********************************************************************************************************************************
8c7d23
 *   Structures and Typedefs                                                                                                      *
b22ed6
@@ -400,13 +399,13 @@ static int vbsvcAutoMountSharedFolderOld
8c7d23
     int rc = vbsvcAutoMountPrepareMountPointOld(pszMountPoint, pszShareName, &Opts);
8c7d23
     if (RT_SUCCESS(rc))
32e434
     {
8c7d23
+        char szOptBuf[MAX_MNTOPT_STR] = { '\0', };
32e434
+        RTStrPrintf(szOptBuf, sizeof(szOptBuf), "uid=%d,gid=%d,dmode=%0o,fmode=%0o,dmask=%0o,fmask=%0o",
8c7d23
+                    Opts.uid, Opts.gid, Opts.dmode, Opts.fmode, Opts.dmask, Opts.fmask);
8c7d23
 # ifdef RT_OS_SOLARIS
32e434
         int fFlags = 0;
8c7d23
         if (Opts.ronly)
32e434
             fFlags |= MS_RDONLY;
8c7d23
-        char szOptBuf[MAX_MNTOPT_STR] = { '\0', };
32e434
-        RTStrPrintf(szOptBuf, sizeof(szOptBuf), "uid=%d,gid=%d,dmode=%0o,fmode=%0o,dmask=%0o,fmask=%0o",
8c7d23
-                    Opts.uid, Opts.gid, Opts.dmode, Opts.fmode, Opts.dmask, Opts.fmask);
32e434
         int r = mount(pszShareName,
32e434
                       pszMountPoint,
32e434
                       fFlags | MS_OPTIONSTR,
b22ed6
@@ -423,35 +422,11 @@ static int vbsvcAutoMountSharedFolderOld
32e434
 
8c7d23
 # else /* RT_OS_LINUX */
32e434
         unsigned long fFlags = MS_NODEV;
32e434
-
32e434
-        /*const char *szOptions = { "rw" }; - ??? */
32e434
-        struct vbsf_mount_info_new mntinf;
8c7d23
-        RT_ZERO(mntinf);
32e434
-
32e434
-        mntinf.nullchar     = '\0';
32e434
-        mntinf.signature[0] = VBSF_MOUNT_SIGNATURE_BYTE_0;
32e434
-        mntinf.signature[1] = VBSF_MOUNT_SIGNATURE_BYTE_1;
32e434
-        mntinf.signature[2] = VBSF_MOUNT_SIGNATURE_BYTE_2;
32e434
-        mntinf.length       = sizeof(mntinf);
32e434
-
8c7d23
-        mntinf.uid   = Opts.uid;
8c7d23
-        mntinf.gid   = Opts.gid;
8c7d23
-        mntinf.ttl   = Opts.ttl;
8c7d23
-        mntinf.dmode = Opts.dmode;
8c7d23
-        mntinf.fmode = Opts.fmode;
8c7d23
-        mntinf.dmask = Opts.dmask;
8c7d23
-        mntinf.fmask = Opts.fmask;
b22ed6
-        mntinf.cMaxIoPages = Opts.cMaxIoPages;
b22ed6
-        mntinf.szTag[0] = '\0';
32e434
-
32e434
-        strcpy(mntinf.name, pszShareName);
32e434
-        strcpy(mntinf.nls_name, "\0");
32e434
-
32e434
         int r = mount(pszShareName,
32e434
                       pszMountPoint,
32e434
                       "vboxsf",
32e434
                       fFlags,
32e434
-                      &mntinf);
32e434
+                      szOptBuf);
32e434
         if (r == 0)
32e434
         {
32e434
             VGSvcVerbose(0, "vbsvcAutoMountWorker: Shared folder '%s' was mounted to '%s'\n", pszShareName, pszMountPoint);
b22ed6
@@ -484,34 +459,6 @@ static int vbsvcAutoMountSharedFolderOld
32e434
         }
32e434
         else /* r == -1, we got some error in errno.  */
32e434
         {
32e434
-            if (errno == EPROTO)
32e434
-            {
32e434
-                VGSvcVerbose(3, "vbsvcAutoMountWorker: Messed up share name, re-trying ...\n");
32e434
-
32e434
-                /** @todo r=bird: What on earth is going on here?????  Why can't you
32e434
-                 *        strcpy(mntinf.name, pszShareName) to fix it again? */
32e434
-
32e434
-                /* Sometimes the mount utility messes up the share name.  Try to
32e434
-                 * un-mangle it again. */
32e434
-                char szCWD[RTPATH_MAX];
32e434
-                size_t cchCWD;
32e434
-                if (!getcwd(szCWD, sizeof(szCWD)))
32e434
-                {
32e434
-                    VGSvcError("vbsvcAutoMountWorker: Failed to get the current working directory\n");
32e434
-                    szCWD[0] = '\0';
32e434
-                }
32e434
-                cchCWD = strlen(szCWD);
32e434
-                if (!strncmp(pszMountPoint, szCWD, cchCWD))
32e434
-                {
32e434
-                    while (pszMountPoint[cchCWD] == '/')
32e434
-                        ++cchCWD;
32e434
-                    /* We checked before that we have enough space */
32e434
-                    strcpy(mntinf.name, pszMountPoint + cchCWD);
32e434
-                }
32e434
-                r = mount(mntinf.name, pszMountPoint, "vboxsf", fFlags, &mntinf);
32e434
-            }
32e434
-            if (r == -1) /* Was there some error from one of the tries above? */
32e434
-            {
32e434
                 switch (errno)
32e434
                 {
32e434
                     /* If we get EINVAL here, the system already has mounted the Shared Folder to another
b22ed6
@@ -530,7 +477,6 @@ static int vbsvcAutoMountSharedFolderOld
32e434
                         rc = RTErrConvertFromErrno(errno);
32e434
                         break;
32e434
                 }
32e434
-            }
32e434
         }
8c7d23
 # endif
8c7d23
     }
b22ed6
@@ -1464,51 +1410,21 @@ static int vbsvcAutomounterMountIt(PVBSV
cfa360
     }
cfa360
 
cfa360
 #  if defined(RT_OS_LINUX)
cfa360
-    /*
cfa360
-     * Linux a bit more work...
cfa360
-     */
cfa360
-    struct vbsf_mount_info_new MntInfo;
cfa360
-    RT_ZERO(MntInfo);
cfa360
-    struct vbsf_mount_opts MntOpts;
cfa360
-    RT_ZERO(MntOpts);
cfa360
-    MntInfo.nullchar     = '\0';
cfa360
-    MntInfo.signature[0] = VBSF_MOUNT_SIGNATURE_BYTE_0;
cfa360
-    MntInfo.signature[1] = VBSF_MOUNT_SIGNATURE_BYTE_1;
cfa360
-    MntInfo.signature[2] = VBSF_MOUNT_SIGNATURE_BYTE_2;
cfa360
-    MntInfo.length       = sizeof(MntInfo);
472632
-    MntInfo.ttl          = MntOpts.ttl              = -1 /*default*/;
b22ed6
-    MntInfo.msDirCacheTTL= MntOpts.msDirCacheTTL    = -1 /*default*/;
b22ed6
-    MntInfo.msInodeTTL   = MntOpts.msInodeTTL       = -1 /*default*/;
b22ed6
-    MntInfo.cMaxIoPages  = MntOpts.cMaxIoPages      = 0 /*default*/;
b22ed6
-    MntInfo.cbDirBuf     = MntOpts.cbDirBuf         = 0 /*default*/;
b22ed6
-    MntInfo.enmCacheMode = MntOpts.enmCacheMode     = kVbsfCacheMode_Default;
cfa360
-    MntInfo.uid          = MntOpts.uid   = 0;
cfa360
-    MntInfo.gid          = MntOpts.gid   = gidMount;
cfa360
-    MntInfo.dmode        = MntOpts.dmode = 0770;
cfa360
-    MntInfo.fmode        = MntOpts.fmode = 0770;
cfa360
-    MntInfo.dmask        = MntOpts.dmask = 0000;
cfa360
-    MntInfo.fmask        = MntOpts.fmask = 0000;
b22ed6
-    memcpy(MntInfo.szTag, g_szTag, sizeof(g_szTag)); AssertCompile(sizeof(MntInfo.szTag) >= sizeof(g_szTag));
cfa360
-    rc = RTStrCopy(MntInfo.name, sizeof(MntInfo.name), pEntry->pszName);
cfa360
-    if (RT_FAILURE(rc))
cfa360
+    unsigned long fFlags = MS_NODEV;
cfa360
+    char szOpts[MAX_MNTOPT_STR] = { '\0', };
cfa360
+    ssize_t cchOpts = RTStrPrintf2(szOpts, sizeof(szOpts),
cfa360
+                                   "uid=0,gid=%d,dmode=0770,fmode=0770,dmask=0000,fmask=0000", gidMount);
cfa360
+    if (cchOpts <= 0)
cfa360
     {
cfa360
-        VGSvcError("vbsvcAutomounterMountIt: Share name '%s' is too long for the MntInfo.name field!\n", pEntry->pszName);
cfa360
-        return rc;
cfa360
+        VGSvcError("vbsvcAutomounterMountIt: szOpts overflow! %zd\n", cchOpts);
cfa360
+        return VERR_BUFFER_OVERFLOW;
cfa360
     }
cfa360
 
cfa360
-    errno = 0;
cfa360
-    unsigned long fFlags = MS_NODEV;
cfa360
-    rc = mount(pEntry->pszName, pEntry->pszActualMountPoint, "vboxsf", fFlags, &MntInfo);
cfa360
+    rc = mount(pEntry->pszName, pEntry->pszActualMountPoint, "vboxsf", fFlags, szOpts);
cfa360
     if (rc == 0)
cfa360
     {
cfa360
         VGSvcVerbose(0, "vbsvcAutomounterMountIt: Successfully mounted '%s' on '%s'\n",
cfa360
                      pEntry->pszName, pEntry->pszActualMountPoint);
cfa360
-
cfa360
-        errno = 0;
cfa360
-        rc = vbsfmount_complete(pEntry->pszName, pEntry->pszActualMountPoint, fFlags, &MntOpts);
cfa360
-        if (rc != 0) /* Ignorable. /etc/mtab is probably a link to /proc/mounts. */
cfa360
-            VGSvcVerbose(1, "vbsvcAutomounterMountIt: vbsfmount_complete failed: %s (%d/%d)\n",
cfa360
-                         rc == 1 ? "open_memstream" : rc == 2 ? "setmntent" : rc == 3 ? "addmntent" : "unknown", rc, errno);
cfa360
         return VINF_SUCCESS;
cfa360
     }
cfa360
     else if (errno == EINVAL)