core: message channel pdu broken with rdp security

rdp_recv_message_channel_pdu always read the rdp security header
even if it was already previously read (which is the case if rdp
security is active)

This caused malfunctions and disconnects when heartbeat or bandwidth
autodetect packets were sent/received in rdp security mode.

Credit goes to @MartinHaimberger for identifying the broken code
part.
This commit is contained in:
Norbert Federa 2015-06-19 14:47:00 +02:00
parent c8731eaa2c
commit 91a9b23b91
4 changed files with 18 additions and 10 deletions

View File

@ -755,7 +755,12 @@ BOOL rdp_client_connect_auto_detect(rdpRdp* rdp, wStream* s)
{ {
if (channelId == rdp->mcs->messageChannelId) if (channelId == rdp->mcs->messageChannelId)
{ {
if (rdp_recv_message_channel_pdu(rdp, s) == 0) UINT16 securityFlags;
if (!rdp_read_security_header(s, &securityFlags))
return FALSE;
if (rdp_recv_message_channel_pdu(rdp, s, securityFlags) == 0)
return TRUE; return TRUE;
} }
} }

View File

@ -405,7 +405,11 @@ static int peer_recv_tpkt_pdu(freerdp_peer* client, wStream* s)
} }
else if (rdp->mcs->messageChannelId && channelId == rdp->mcs->messageChannelId) else if (rdp->mcs->messageChannelId && channelId == rdp->mcs->messageChannelId)
{ {
return rdp_recv_message_channel_pdu(rdp, s); if (!rdp->settings->UseRdpSecurityLayer)
if (!rdp_read_security_header(s, &securityFlags))
return -1;
return rdp_recv_message_channel_pdu(rdp, s, securityFlags);
} }
else else
{ {

View File

@ -898,13 +898,8 @@ out_fail:
return -1; return -1;
} }
int rdp_recv_message_channel_pdu(rdpRdp* rdp, wStream* s) int rdp_recv_message_channel_pdu(rdpRdp* rdp, wStream* s, UINT16 securityFlags)
{ {
UINT16 securityFlags;
if (!rdp_read_security_header(s, &securityFlags))
return -1;
if (securityFlags & SEC_AUTODETECT_REQ) if (securityFlags & SEC_AUTODETECT_REQ)
{ {
/* Server Auto-Detect Request PDU */ /* Server Auto-Detect Request PDU */
@ -1162,7 +1157,11 @@ static int rdp_recv_tpkt_pdu(rdpRdp* rdp, wStream* s)
} }
else if (rdp->mcs->messageChannelId && channelId == rdp->mcs->messageChannelId) else if (rdp->mcs->messageChannelId && channelId == rdp->mcs->messageChannelId)
{ {
return rdp_recv_message_channel_pdu(rdp, s); if (!rdp->settings->UseRdpSecurityLayer)
if (!rdp_read_security_header(s, &securityFlags))
return -1;
return rdp_recv_message_channel_pdu(rdp, s, securityFlags);
} }
else else
{ {

View File

@ -209,7 +209,7 @@ int rdp_send_channel_data(rdpRdp* rdp, UINT16 channelId, BYTE* data, int size);
wStream* rdp_message_channel_pdu_init(rdpRdp* rdp); wStream* rdp_message_channel_pdu_init(rdpRdp* rdp);
BOOL rdp_send_message_channel_pdu(rdpRdp* rdp, wStream* s, UINT16 sec_flags); BOOL rdp_send_message_channel_pdu(rdpRdp* rdp, wStream* s, UINT16 sec_flags);
int rdp_recv_message_channel_pdu(rdpRdp* rdp, wStream* s); int rdp_recv_message_channel_pdu(rdpRdp* rdp, wStream* s, UINT16 securityFlags);
int rdp_recv_out_of_sequence_pdu(rdpRdp* rdp, wStream* s); int rdp_recv_out_of_sequence_pdu(rdpRdp* rdp, wStream* s);