VirtualBox

Changeset 49234 in vbox


Ignore:
Timestamp:
Oct 22, 2013 3:49:35 PM (11 years ago)
Author:
vboxsync
Message:

Main/EmulatedUSB: pass settings to the emulated device.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/Main/src-client/EmulatedUSBImpl.cpp

    r49161 r49234  
    107107};
    108108
     109static int emulatedWebcamInsertSettings(PCFGMNODE pConfig, EUSBSettingsMap *pSettings)
     110{
     111    int rc = VINF_SUCCESS;
     112
     113    EUSBSettingsMap::const_iterator it;
     114    for (it = pSettings->begin(); it != pSettings->end(); ++it)
     115    {
     116        /* Convert some well known settings for backward compatibility. */
     117        if (   RTStrCmp(it->first.c_str(), "MaxPayloadTransferSize") == 0
     118            || RTStrCmp(it->first.c_str(), "MaxFramerate") == 0)
     119        {
     120            uint32_t u32 = 0;
     121            rc = RTStrToUInt32Full(it->second.c_str(), 10, &u32);
     122            if (rc == VINF_SUCCESS)
     123            {
     124                rc = CFGMR3InsertInteger(pConfig, it->first.c_str(), u32);
     125            }
     126            else
     127            {
     128                if (RT_SUCCESS(rc)) /* VWRN_* */
     129                {
     130                    rc = VERR_INVALID_PARAMETER;
     131                }
     132            }
     133        }
     134        else
     135        {
     136            rc = CFGMR3InsertString(pConfig, it->first.c_str(), it->second.c_str());
     137        }
     138
     139        if (RT_FAILURE(rc))
     140        {
     141            break;
     142        }
     143    }
     144
     145    return rc;
     146}
    109147
    110148/* static */ DECLCALLBACK(int) EUSBWEBCAM::emulatedWebcamAttach(PUVM pUVM, EUSBWEBCAM *pThis, const char *pszDriver)
    111149{
    112     EUSBSettingsMap::const_iterator it;
    113 
    114150    PCFGMNODE pInstance = CFGMR3CreateTree(pUVM);
    115151    PCFGMNODE pConfig;
    116152    CFGMR3InsertNode(pInstance,   "Config", &pConfig);
    117     for (it = pThis->mDevSettings.begin(); it != pThis->mDevSettings.end(); ++it)
    118         CFGMR3InsertString(pConfig, it->first.c_str(), it->second.c_str());
     153    int rc = emulatedWebcamInsertSettings(pConfig, &pThis->mDevSettings);
     154    if (RT_FAILURE(rc))
     155        return rc;
    119156    PCFGMNODE pEUSB;
    120157    CFGMR3InsertNode(pConfig,       "EmulatedUSB", &pEUSB);
     
    129166    CFGMR3InsertString(pConfig,       "DevicePath", pThis->mPath.c_str());
    130167    CFGMR3InsertInteger(pConfig,      "Object", (uintptr_t)pThis->mpvObject);
    131     for (it = pThis->mDrvSettings.begin(); it != pThis->mDrvSettings.end(); ++it)
    132         CFGMR3InsertString(pConfig, it->first.c_str(), it->second.c_str());
     168    rc = emulatedWebcamInsertSettings(pConfig, &pThis->mDrvSettings);
     169    if (RT_FAILURE(rc))
     170        return rc;
    133171
    134172    /* pInstance will be used by PDM and deallocated on error. */
    135     int rc = PDMR3UsbCreateEmulatedDevice(pUVM, "Webcam", pInstance, &pThis->mUuid);
     173    rc = PDMR3UsbCreateEmulatedDevice(pUVM, "Webcam", pInstance, &pThis->mUuid);
    136174    LogRelFlowFunc(("PDMR3UsbCreateEmulatedDevice %Rrc\n", rc));
    137175    return rc;
     
    185223HRESULT EUSBWEBCAM::settingsParse(void)
    186224{
    187     HRESULT hrc = S_OK;
    188 
    189     return hrc;
     225    HRESULT hr = S_OK;
     226
     227    /* Parse mSettings string:
     228     * "[dev:|drv:]Name1=Value1;[dev:|drv:]Name2=Value2"
     229     */
     230    char *pszSrc = mSettings.mutableRaw();
     231
     232    if (pszSrc)
     233    {
     234        while (*pszSrc)
     235        {
     236            /* Does the setting belong to device of driver. Default is both. */
     237            bool fDev = true;
     238            bool fDrv = true;
     239            if (RTStrNICmp(pszSrc, "drv:", strlen("drv:")) == 0)
     240            {
     241                pszSrc += strlen("drv:");
     242                fDev = false;
     243            }
     244            else if (RTStrNICmp(pszSrc, "dev:", strlen("dev:")) == 0)
     245            {
     246                pszSrc += strlen("dev:");
     247                fDrv = false;
     248            }
     249
     250            char *pszEq = RTStrStr(pszSrc, "=");
     251            if (!pszEq)
     252            {
     253                hr = E_INVALIDARG;
     254                break;
     255            }
     256
     257            char *pszEnd = RTStrStr(pszEq, ";");
     258            if (!pszEnd)
     259            {
     260                pszEnd = pszEq + strlen(pszEq);
     261            }
     262
     263            *pszEq = 0;
     264            char chEnd = *pszEnd;
     265            *pszEnd = 0;
     266
     267            /* Empty strings not allowed. */
     268            if (*pszSrc != 0 && pszEq[1] != 0)
     269            {
     270                if (fDev)
     271                {
     272                    mDevSettings[pszSrc] = &pszEq[1];
     273                }
     274                if (fDrv)
     275                {
     276                    mDrvSettings[pszSrc] = &pszEq[1];
     277                }
     278            }
     279
     280            *pszEq = '=';
     281            *pszEnd = chEnd;
     282
     283            pszSrc = pszEnd;
     284            if (*pszSrc == ';')
     285            {
     286                pszSrc++;
     287            }
     288        }
     289
     290        if (SUCCEEDED(hr))
     291        {
     292            EUSBSettingsMap::const_iterator it;
     293            for (it = mDevSettings.begin(); it != mDevSettings.end(); ++it)
     294                LogRelFlowFunc(("[dev:%s] = [%s]\n", it->first.c_str(), it->second.c_str()));
     295            for (it = mDrvSettings.begin(); it != mDrvSettings.end(); ++it)
     296                LogRelFlowFunc(("[drv:%s] = [%s]\n", it->first.c_str(), it->second.c_str()));
     297        }
     298    }
     299
     300    return hr;
    190301}
    191302
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