Clean up drdynvc channels porperly locked.
This commit is contained in:
parent
c5f746d71a
commit
7f1cca78aa
@ -1398,15 +1398,23 @@ static DWORD WINAPI drdynvc_virtual_channel_client_thread(LPVOID arg)
|
|||||||
/* Disconnect remaining dynamic channels that the server did not.
|
/* Disconnect remaining dynamic channels that the server did not.
|
||||||
* This is required to properly shut down channels by calling the appropriate
|
* This is required to properly shut down channels by calling the appropriate
|
||||||
* event handlers. */
|
* event handlers. */
|
||||||
|
size_t count = 0;
|
||||||
DVCMAN* drdynvcMgr = (DVCMAN*)drdynvc->channel_mgr;
|
DVCMAN* drdynvcMgr = (DVCMAN*)drdynvc->channel_mgr;
|
||||||
|
|
||||||
while (ArrayList_Count(drdynvcMgr->channels) > 0)
|
do
|
||||||
{
|
{
|
||||||
IWTSVirtualChannel* channel =
|
ArrayList_Lock(drdynvcMgr->channels);
|
||||||
(IWTSVirtualChannel*)ArrayList_GetItem(drdynvcMgr->channels, 0);
|
count = ArrayList_Count(drdynvcMgr->channels);
|
||||||
const UINT32 ChannelId = drdynvc->channel_mgr->GetChannelId(channel);
|
if (count > 0)
|
||||||
dvcman_close_channel(drdynvc->channel_mgr, ChannelId, FALSE);
|
{
|
||||||
}
|
IWTSVirtualChannel* channel =
|
||||||
|
(IWTSVirtualChannel*)ArrayList_GetItem(drdynvcMgr->channels, 0);
|
||||||
|
const UINT32 ChannelId = drdynvc->channel_mgr->GetChannelId(channel);
|
||||||
|
dvcman_close_channel(drdynvc->channel_mgr, ChannelId, FALSE);
|
||||||
|
count--;
|
||||||
|
}
|
||||||
|
ArrayList_Unlock(drdynvcMgr->channels);
|
||||||
|
} while (count > 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (error && drdynvc->rdpcontext)
|
if (error && drdynvc->rdpcontext)
|
||||||
|
Loading…
Reference in New Issue
Block a user