VirtualBox

Changeset 62292 in vbox for trunk/src/VBox/Main


Ignore:
Timestamp:
Jul 18, 2016 8:57:06 AM (9 years ago)
Author:
vboxsync
Message:

Main/Machine: Eliminate unneeded taking of the Host object lock in SessionMachine::uninit and additionally release the lock during IPC to be on the safe side (currently there is no problem).

File:
1 edited

Legend:

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

    r62192 r62292  
    1258912589    // we need to lock this object in uninit() because the lock is shared
    1259012590    // with mPeer (as well as data we modify below). mParent lock is needed
    12591     // by several calls to it, and USB needs host lock.
    12592     AutoMultiWriteLock3 multilock(mParent, mParent->i_host(), this COMMA_LOCKVAL_SRC_POS);
     12591    // by several calls to it.
     12592    AutoMultiWriteLock2 multilock(mParent, this COMMA_LOCKVAL_SRC_POS);
    1259312593
    1259412594#ifdef VBOX_WITH_RESOURCE_USAGE_API
     
    1264512645        while (it != mData->mSession.mRemoteControls.end())
    1264612646        {
     12647            ComPtr<IInternalSessionControl> pControl = *it;
     12648            mData->mSession.mRemoteControls.erase(it);
    1264712649            LogFlowThisFunc(("  Calling remoteControl->Uninitialize()...\n"));
    12648             HRESULT rc = (*it)->Uninitialize();
     12650            HRESULT rc = pControl->Uninitialize();
    1264912651            LogFlowThisFunc(("  remoteControl->Uninitialize() returned %08X\n", rc));
    1265012652            if (FAILED(rc))
    1265112653                Log1WarningThisFunc(("Forgot to close the remote session?\n"));
    12652             ++it;
     12654            multilock.acquire();
     12655            it = mData->mSession.mRemoteControls.begin();
    1265312656        }
    1265412657        mData->mSession.mRemoteControls.clear();
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