VirtualBox

Ignore:
Timestamp:
May 4, 2011 2:50:32 PM (14 years ago)
Author:
vboxsync
Message:

Main/linux/USB: better permissions checking and code cleanup

Location:
trunk/src/VBox/Main/src-server/linux
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/Main/src-server/linux/USBGetDevices.cpp

    r36417 r36958  
    9393    { "s",  1, 1000,       0 },
    9494    { "",   0,    0,       0 }  /* term */
    95 };
    96 
    97 /**
    98  * List of well-known USB device tree locations.
    99  */
    100 static const USBDEVTREELOCATION s_aTreeLocations[] =
    101 {
    102     { "/dev/vboxusb",  true },
    103     { "/proc/bus/usb", false },
    10495};
    10596
     
    14011392/** Is inotify available and working on this system?  This is a requirement
    14021393 * for using USB with sysfs */
    1403 /** @todo test the "inotify in glibc but not in the kernel" case. */
    14041394static bool inotifyAvailable(void)
    14051395{
     
    14161406}
    14171407
    1418 PCUSBDEVTREELOCATION USBProxyLinuxGetDeviceRoot(bool fPreferSysfs)
    1419 {
    1420     PCUSBDEVTREELOCATION pcBestUsbfs = NULL;
    1421     PCUSBDEVTREELOCATION pcBestSysfs = NULL;
    1422 
    1423     bool fHaveInotify = inotifyAvailable();
    1424     for (unsigned i = 0; i < RT_ELEMENTS(s_aTreeLocations); ++i)
    1425         if (!s_aTreeLocations[i].fUseSysfs)
    1426         {
    1427             if (!pcBestUsbfs)
    1428             {
    1429                 PUSBDEVICE pDevices;
    1430 
    1431                 pDevices = getDevicesFromUsbfs(s_aTreeLocations[i].szDevicesRoot,
    1432                                                true);
    1433                 if (pDevices)
    1434                 {
    1435                     pcBestUsbfs = &s_aTreeLocations[i];
    1436                     deviceListFree(&pDevices);
    1437                 }
    1438             }
    1439         }
    1440         else
    1441         {
    1442             if (   fHaveInotify
    1443                 && !pcBestSysfs
    1444                 && RTPathExists(s_aTreeLocations[i].szDevicesRoot))
    1445                 pcBestSysfs = &s_aTreeLocations[i];
    1446         }
    1447     if (pcBestUsbfs && !fPreferSysfs)
    1448         return pcBestUsbfs;
    1449     return pcBestSysfs;
     1408bool USBProxyLinuxCheckDeviceRoot(const char *pcszRoot, bool fIsDeviceNodes)
     1409{
     1410    bool fOK = false;
     1411    if (!fIsDeviceNodes)  /* usbfs */
     1412    {
     1413        PUSBDEVICE pDevices;
     1414
     1415        pDevices = getDevicesFromUsbfs(pcszRoot, true);
     1416        if (pDevices)
     1417        {
     1418            PUSBDEVICE pDevice;
     1419           
     1420            fOK = true;
     1421            for (pDevice = pDevices; pDevice && fOK; pDevice = pDevice->pNext)
     1422                if (access(pDevice->pszAddress, R_OK | W_OK))
     1423                    fOK = false;
     1424            deviceListFree(&pDevices);
     1425        }
     1426    }
     1427    else  /* device nodes */
     1428        if (inotifyAvailable() && !access(pcszRoot, R_OK | X_OK))
     1429            fOK = true;
     1430    return fOK;
    14501431}
    14511432
  • trunk/src/VBox/Main/src-server/linux/USBProxyServiceLinux.cpp

    r36727 r36958  
    3232#include <iprt/assert.h>
    3333#include <iprt/ctype.h>
     34#include <iprt/dir.h>
    3435#include <iprt/env.h>
    3536#include <iprt/file.h>
     
    8283    /*
    8384     * We have two methods available for getting host USB device data - using
    84      * USBFS and using sysfs/hal.  The default choice depends on build-time
     85     * USBFS and using sysfs.  The default choice depends on build-time
    8586     * settings and an environment variable; if the default is not available
    8687     * we fall back to the second.
     
    8889     * will be presented to the user.
    8990     */
    90 #ifdef VBOX_WITH_SYSFS_BY_DEFAULT
    91     bool fUseSysfs = true;
    92 #else
    93     bool fUseSysfs = false;
    94 #endif
     91    bool fUseSysfs;
    9592    const char *pcszUsbFromEnv = RTEnvGet("VBOX_USB");
    9693    const char *pcszUsbRoot = NULL;
     
    121118    if (!pcszUsbRoot)
    122119    {
    123         PCUSBDEVTREELOCATION pLocation;
    124         pLocation = USBProxyLinuxGetDeviceRoot(fUseSysfs);
    125         if (pLocation)
    126         {
    127             pcszUsbRoot = pLocation->szDevicesRoot;
    128             fUseSysfs = pLocation->fUseSysfs;
     120        if (USBProxyLinuxCheckDeviceRoot("/dev/vboxusb", true))
     121        {
     122            fUseSysfs = true;
     123            pcszUsbRoot = "/dev/vboxusb";
     124        }
     125        else if (USBProxyLinuxCheckDeviceRoot("/proc/bus/usb", false))
     126        {
     127            fUseSysfs = false;
     128            pcszUsbRoot = "/proc/bus/usb";
    129129        }
    130130    }
     
    141141    }
    142142    else
    143         mLastError = VERR_NOT_FOUND;
     143        /** @todo fix this, preferably in the next fifteen minutes. */
     144        mLastError =   RTDirExists("/dev/vboxusb") ? VERR_PERMISSION_DENIED
     145                     : RTFileExists("/proc/bus/usb/devices") ? VERR_VUSB_USBFS_PERMISSION
     146                     : VERR_NOT_FOUND;
    144147    return S_OK;
    145148}
Note: See TracChangeset for help on using the changeset viewer.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette