2bb0659fb4
* make sure fast-path packages are not fragmented if no multifragment support was announced * handle special server side case where the multifragment size received from the client is smaller than one maximum fast-path PDU size
171 lines
4.5 KiB
C
171 lines
4.5 KiB
C
/**
|
|
* FreeRDP: A Remote Desktop Protocol Implementation
|
|
* Fast Path
|
|
*
|
|
* Copyright 2011 Vic Lee
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#ifndef __FASTPATH_H
|
|
#define __FASTPATH_H
|
|
|
|
/*
|
|
* Fast-Path has 15 bits available for length information which would lead to a
|
|
* maximal pdu size of 0x8000. However in practice only 14 bits are used
|
|
* this isn't documented anywhere but it looks like most implementations will
|
|
* fail if fast-path packages > 0x3FFF arrive.
|
|
*/
|
|
#define FASTPATH_MAX_PACKET_SIZE 0x3FFF
|
|
|
|
/*
|
|
* The following size guarantees that no fast-path PDU fragmentation occurs.
|
|
* It was calculated by subtracting 128 from FASTPATH_MAX_PACKET_SIZE.
|
|
* 128 was chosen because it includes all required and optional headers as well as
|
|
* possible paddings and some extra bytes for safety.
|
|
*/
|
|
#define FASTPATH_FRAGMENT_SAFE_SIZE 0x3F80
|
|
|
|
typedef struct rdp_fastpath rdpFastPath;
|
|
|
|
#include "rdp.h"
|
|
|
|
#include <winpr/stream.h>
|
|
|
|
enum FASTPATH_INPUT_ACTION_TYPE
|
|
{
|
|
FASTPATH_INPUT_ACTION_FASTPATH = 0x0,
|
|
FASTPATH_INPUT_ACTION_X224 = 0x3
|
|
};
|
|
|
|
enum FASTPATH_OUTPUT_ACTION_TYPE
|
|
{
|
|
FASTPATH_OUTPUT_ACTION_FASTPATH = 0x0,
|
|
FASTPATH_OUTPUT_ACTION_X224 = 0x3
|
|
};
|
|
|
|
enum FASTPATH_INPUT_ENCRYPTION_FLAGS
|
|
{
|
|
FASTPATH_INPUT_SECURE_CHECKSUM = 0x1,
|
|
FASTPATH_INPUT_ENCRYPTED = 0x2
|
|
};
|
|
|
|
enum FASTPATH_OUTPUT_ENCRYPTION_FLAGS
|
|
{
|
|
FASTPATH_OUTPUT_SECURE_CHECKSUM = 0x1,
|
|
FASTPATH_OUTPUT_ENCRYPTED = 0x2
|
|
};
|
|
|
|
enum FASTPATH_UPDATETYPE
|
|
{
|
|
FASTPATH_UPDATETYPE_ORDERS = 0x0,
|
|
FASTPATH_UPDATETYPE_BITMAP = 0x1,
|
|
FASTPATH_UPDATETYPE_PALETTE = 0x2,
|
|
FASTPATH_UPDATETYPE_SYNCHRONIZE = 0x3,
|
|
FASTPATH_UPDATETYPE_SURFCMDS = 0x4,
|
|
FASTPATH_UPDATETYPE_PTR_NULL = 0x5,
|
|
FASTPATH_UPDATETYPE_PTR_DEFAULT = 0x6,
|
|
FASTPATH_UPDATETYPE_PTR_POSITION = 0x8,
|
|
FASTPATH_UPDATETYPE_COLOR = 0x9,
|
|
FASTPATH_UPDATETYPE_CACHED = 0xA,
|
|
FASTPATH_UPDATETYPE_POINTER = 0xB
|
|
};
|
|
|
|
enum FASTPATH_FRAGMENT
|
|
{
|
|
FASTPATH_FRAGMENT_SINGLE = 0x0,
|
|
FASTPATH_FRAGMENT_LAST = 0x1,
|
|
FASTPATH_FRAGMENT_FIRST = 0x2,
|
|
FASTPATH_FRAGMENT_NEXT = 0x3
|
|
};
|
|
|
|
enum FASTPATH_OUTPUT_COMPRESSION
|
|
{
|
|
FASTPATH_OUTPUT_COMPRESSION_USED = 0x2
|
|
};
|
|
|
|
/* FastPath Input Events */
|
|
enum FASTPATH_INPUT_EVENT_CODE
|
|
{
|
|
FASTPATH_INPUT_EVENT_SCANCODE = 0x0,
|
|
FASTPATH_INPUT_EVENT_MOUSE = 0x1,
|
|
FASTPATH_INPUT_EVENT_MOUSEX = 0x2,
|
|
FASTPATH_INPUT_EVENT_SYNC = 0x3,
|
|
FASTPATH_INPUT_EVENT_UNICODE = 0x4
|
|
};
|
|
|
|
/* FastPath Keyboard Event Flags */
|
|
enum FASTPATH_INPUT_KBDFLAGS
|
|
{
|
|
FASTPATH_INPUT_KBDFLAGS_RELEASE = 0x01,
|
|
FASTPATH_INPUT_KBDFLAGS_EXTENDED = 0x02
|
|
};
|
|
|
|
struct _FASTPATH_UPDATE_PDU_HEADER
|
|
{
|
|
BYTE fpOutputHeader;
|
|
BYTE length1;
|
|
BYTE length2;
|
|
BYTE fipsInformation[4];
|
|
BYTE dataSignature[8];
|
|
|
|
BYTE action;
|
|
BYTE secFlags;
|
|
UINT16 length;
|
|
};
|
|
typedef struct _FASTPATH_UPDATE_PDU_HEADER FASTPATH_UPDATE_PDU_HEADER;
|
|
|
|
struct _FASTPATH_UPDATE_HEADER
|
|
{
|
|
BYTE updateHeader;
|
|
BYTE compressionFlags;
|
|
UINT16 size;
|
|
|
|
BYTE updateCode;
|
|
BYTE fragmentation;
|
|
BYTE compression;
|
|
};
|
|
typedef struct _FASTPATH_UPDATE_HEADER FASTPATH_UPDATE_HEADER;
|
|
|
|
struct rdp_fastpath
|
|
{
|
|
rdpRdp* rdp;
|
|
wStream* fs;
|
|
BYTE encryptionFlags;
|
|
BYTE numberEvents;
|
|
wStream* updateData;
|
|
int fragmentation;
|
|
};
|
|
|
|
UINT16 fastpath_header_length(wStream* s);
|
|
UINT16 fastpath_read_header(rdpFastPath* fastpath, wStream* s);
|
|
BOOL fastpath_read_header_rdp(rdpFastPath* fastpath, wStream* s, UINT16 *length);
|
|
int fastpath_recv_updates(rdpFastPath* fastpath, wStream* s);
|
|
int fastpath_recv_inputs(rdpFastPath* fastpath, wStream* s);
|
|
|
|
wStream* fastpath_input_pdu_init_header(rdpFastPath* fastpath);
|
|
wStream* fastpath_input_pdu_init(rdpFastPath* fastpath, BYTE eventFlags, BYTE eventCode);
|
|
BOOL fastpath_send_multiple_input_pdu(rdpFastPath* fastpath, wStream* s, int iEventCount);
|
|
BOOL fastpath_send_input_pdu(rdpFastPath* fastpath, wStream* s);
|
|
|
|
wStream* fastpath_update_pdu_init(rdpFastPath* fastpath);
|
|
wStream* fastpath_update_pdu_init_new(rdpFastPath* fastpath);
|
|
BOOL fastpath_send_update_pdu(rdpFastPath* fastpath, BYTE updateCode, wStream* s);
|
|
|
|
BOOL fastpath_send_surfcmd_frame_marker(rdpFastPath* fastpath, UINT16 frameAction, UINT32 frameId);
|
|
|
|
rdpFastPath* fastpath_new(rdpRdp* rdp);
|
|
void fastpath_free(rdpFastPath* fastpath);
|
|
|
|
#endif
|