From 08c8c6f285d4605821e9d8cab105b11906caace7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc-Andr=C3=A9=20Moreau?= Date: Sat, 20 Dec 2014 13:07:30 -0500 Subject: [PATCH] channels/cliprdr: fix empty clipboard format lists, server-side locking --- channels/cliprdr/client/cliprdr_format.c | 8 +++++++- channels/cliprdr/server/cliprdr_main.c | 21 ++++++++++++++++++--- winpr/libwinpr/clipboard/clipboard.c | 2 ++ 3 files changed, 27 insertions(+), 4 deletions(-) diff --git a/channels/cliprdr/client/cliprdr_format.c b/channels/cliprdr/client/cliprdr_format.c index f1114d419..29a111bdd 100644 --- a/channels/cliprdr/client/cliprdr_format.c +++ b/channels/cliprdr/client/cliprdr_format.c @@ -57,7 +57,13 @@ void cliprdr_process_format_list(cliprdrPlugin* cliprdr, wStream* s, UINT32 data formatList.numFormats = 0; position = Stream_GetPosition(s); - if (!cliprdr->useLongFormatNames) + if (!formatList.dataLen) + { + /* empty format list */ + formatList.formats = NULL; + formatList.numFormats = 0; + } + else if (!cliprdr->useLongFormatNames) { formatList.numFormats = (dataLen / 36); diff --git a/channels/cliprdr/server/cliprdr_main.c b/channels/cliprdr/server/cliprdr_main.c index 10919556d..31c04314a 100644 --- a/channels/cliprdr/server/cliprdr_main.c +++ b/channels/cliprdr/server/cliprdr_main.c @@ -330,7 +330,7 @@ static int cliprdr_server_format_data_response(CliprdrServerContext* context, CL Stream_Write(s, formatDataResponse->requestedFormatData, formatDataResponse->dataLen); - WLog_DBG(TAG, "ClientFormatDataResponse"); + WLog_DBG(TAG, "ServerFormatDataResponse"); cliprdr_server_packet_send(cliprdr, s); return 0; @@ -505,7 +505,13 @@ static int cliprdr_server_receive_format_list(CliprdrServerContext* context, wSt formatList.numFormats = 0; position = Stream_GetPosition(s); - if (!cliprdr->useLongFormatNames) + if (!header->dataLen) + { + /* empty format list */ + formatList.formats = NULL; + formatList.numFormats = 0; + } + else if (!cliprdr->useLongFormatNames) { formatList.numFormats = (dataLen / 36); @@ -895,6 +901,9 @@ int cliprdr_server_read(CliprdrServerContext* context) BytesReturned = 0; BytesToRead = CLIPRDR_HEADER_LENGTH - Stream_GetPosition(s); + if (WaitForSingleObject(cliprdr->ChannelEvent, 0) != WAIT_OBJECT_0) + return 1; + if (!WTSVirtualChannelRead(cliprdr->ChannelHandle, 0, (PCHAR) Stream_Pointer(s), BytesToRead, &BytesReturned)) { @@ -924,6 +933,9 @@ int cliprdr_server_read(CliprdrServerContext* context) BytesReturned = 0; BytesToRead = (header.dataLen + CLIPRDR_HEADER_LENGTH) - Stream_GetPosition(s); + if (WaitForSingleObject(cliprdr->ChannelEvent, 0) != WAIT_OBJECT_0) + return 1; + if (!WTSVirtualChannelRead(cliprdr->ChannelHandle, 0, (PCHAR) Stream_Pointer(s), BytesToRead, &BytesReturned)) { @@ -944,9 +956,12 @@ int cliprdr_server_read(CliprdrServerContext* context) cliprdr_server_receive_pdu(context, s, &header); + Stream_SetPosition(s, 0); + /* check for trailing zero bytes */ - Stream_SetPosition(s, 0); + if (WaitForSingleObject(cliprdr->ChannelEvent, 0) != WAIT_OBJECT_0) + return 1; BytesReturned = 0; BytesToRead = 4; diff --git a/winpr/libwinpr/clipboard/clipboard.c b/winpr/libwinpr/clipboard/clipboard.c index d3de692c9..6ee58680e 100644 --- a/winpr/libwinpr/clipboard/clipboard.c +++ b/winpr/libwinpr/clipboard/clipboard.c @@ -157,6 +157,8 @@ BOOL ClipboardEmpty(wClipboard* clipboard) } clipboard->size = 0; + + clipboard->formatId = 0; clipboard->sequenceNumber++; return TRUE;