channels/rdpgfx: add egfx command line options and settings

This commit is contained in:
Marc-André Moreau 2014-07-03 14:35:03 -04:00
parent bde954107d
commit 5c5386fe04
10 changed files with 134 additions and 26 deletions

View File

@ -398,7 +398,7 @@ static void drdynvc_process_connect(rdpSvcPlugin* plugin)
for (index = 0; index < settings->DynamicChannelCount; index++) for (index = 0; index < settings->DynamicChannelCount; index++)
{ {
args = settings->DynamicChannelArray[index]; args = settings->DynamicChannelArray[index];
dvcman_load_addin(drdynvc->channel_mgr, args); dvcman_load_addin(drdynvc->channel_mgr, args, settings);
} }
dvcman_init(drdynvc->channel_mgr); dvcman_init(drdynvc->channel_mgr);

View File

@ -135,6 +135,11 @@ ADDIN_ARGV* dvcman_get_plugin_data(IDRDYNVC_ENTRY_POINTS* pEntryPoints)
return ((DVCMAN_ENTRY_POINTS*) pEntryPoints)->args; return ((DVCMAN_ENTRY_POINTS*) pEntryPoints)->args;
} }
void* dvcman_get_rdp_settings(IDRDYNVC_ENTRY_POINTS* pEntryPoints)
{
return (void*) ((DVCMAN_ENTRY_POINTS*) pEntryPoints)->settings;
}
UINT32 dvcman_get_channel_id(IWTSVirtualChannel * channel) UINT32 dvcman_get_channel_id(IWTSVirtualChannel * channel)
{ {
return ((DVCMAN_CHANNEL*) channel)->channel_id; return ((DVCMAN_CHANNEL*) channel)->channel_id;
@ -208,7 +213,7 @@ IWTSVirtualChannelManager* dvcman_new(drdynvcPlugin* plugin)
return (IWTSVirtualChannelManager*) dvcman; return (IWTSVirtualChannelManager*) dvcman;
} }
int dvcman_load_addin(IWTSVirtualChannelManager* pChannelMgr, ADDIN_ARGV* args) int dvcman_load_addin(IWTSVirtualChannelManager* pChannelMgr, ADDIN_ARGV* args, rdpSettings* settings)
{ {
DVCMAN_ENTRY_POINTS entryPoints; DVCMAN_ENTRY_POINTS entryPoints;
PDVC_PLUGIN_ENTRY pDVCPluginEntry = NULL; PDVC_PLUGIN_ENTRY pDVCPluginEntry = NULL;
@ -223,8 +228,10 @@ int dvcman_load_addin(IWTSVirtualChannelManager* pChannelMgr, ADDIN_ARGV* args)
entryPoints.iface.RegisterPlugin = dvcman_register_plugin; entryPoints.iface.RegisterPlugin = dvcman_register_plugin;
entryPoints.iface.GetPlugin = dvcman_get_plugin; entryPoints.iface.GetPlugin = dvcman_get_plugin;
entryPoints.iface.GetPluginData = dvcman_get_plugin_data; entryPoints.iface.GetPluginData = dvcman_get_plugin_data;
entryPoints.iface.GetRdpSettings = dvcman_get_rdp_settings;
entryPoints.dvcman = (DVCMAN*) pChannelMgr; entryPoints.dvcman = (DVCMAN*) pChannelMgr;
entryPoints.args = args; entryPoints.args = args;
entryPoints.settings = settings;
pDVCPluginEntry((IDRDYNVC_ENTRY_POINTS*) &entryPoints); pDVCPluginEntry((IDRDYNVC_ENTRY_POINTS*) &entryPoints);
} }

View File

@ -22,6 +22,7 @@
#include <freerdp/dvc.h> #include <freerdp/dvc.h>
#include <freerdp/addin.h> #include <freerdp/addin.h>
#include <freerdp/settings.h>
#include <winpr/synch.h> #include <winpr/synch.h>
#include <winpr/collections.h> #include <winpr/collections.h>
@ -65,6 +66,7 @@ struct _DVCMAN_ENTRY_POINTS
DVCMAN* dvcman; DVCMAN* dvcman;
ADDIN_ARGV* args; ADDIN_ARGV* args;
rdpSettings* settings;
}; };
typedef struct _DVCMAN_ENTRY_POINTS DVCMAN_ENTRY_POINTS; typedef struct _DVCMAN_ENTRY_POINTS DVCMAN_ENTRY_POINTS;
@ -85,7 +87,7 @@ struct _DVCMAN_CHANNEL
typedef struct _DVCMAN_CHANNEL DVCMAN_CHANNEL; typedef struct _DVCMAN_CHANNEL DVCMAN_CHANNEL;
IWTSVirtualChannelManager* dvcman_new(drdynvcPlugin* plugin); IWTSVirtualChannelManager* dvcman_new(drdynvcPlugin* plugin);
int dvcman_load_addin(IWTSVirtualChannelManager* pChannelMgr, ADDIN_ARGV* args); int dvcman_load_addin(IWTSVirtualChannelManager* pChannelMgr, ADDIN_ARGV* args, rdpSettings* settings);
void dvcman_free(IWTSVirtualChannelManager* pChannelMgr); void dvcman_free(IWTSVirtualChannelManager* pChannelMgr);
int dvcman_init(IWTSVirtualChannelManager* pChannelMgr); int dvcman_init(IWTSVirtualChannelManager* pChannelMgr);
int dvcman_create_channel(IWTSVirtualChannelManager* pChannelMgr, UINT32 ChannelId, const char* ChannelName); int dvcman_create_channel(IWTSVirtualChannelManager* pChannelMgr, UINT32 ChannelId, const char* ChannelName);

View File

@ -56,25 +56,13 @@ int rdpgfx_send_caps_advertise_pdu(RDPGFX_CHANNEL_CALLBACK* callback)
gfx = (RDPGFX_PLUGIN*) callback->plugin; gfx = (RDPGFX_PLUGIN*) callback->plugin;
gfx->ThinClient = TRUE;
gfx->SmallCache = FALSE;
#ifdef WITH_OPENH264
gfx->H264 = TRUE;
#else
gfx->H264 = FALSE;
#endif
gfx->MaxCacheSlot = (gfx->ThinClient) ? 4096 : 25600;
header.flags = 0; header.flags = 0;
header.cmdId = RDPGFX_CMDID_CAPSADVERTISE; header.cmdId = RDPGFX_CMDID_CAPSADVERTISE;
pdu.capsSetCount = 2; pdu.capsSetCount = 0;
pdu.capsSets = (RDPGFX_CAPSET*) capsSets; pdu.capsSets = (RDPGFX_CAPSET*) capsSets;
capsSet = &capsSets[0]; capsSet = &capsSets[pdu.capsSetCount++];
capsSet->version = RDPGFX_CAPVERSION_8; capsSet->version = RDPGFX_CAPVERSION_8;
capsSet->flags = 0; capsSet->flags = 0;
@ -84,8 +72,7 @@ int rdpgfx_send_caps_advertise_pdu(RDPGFX_CHANNEL_CALLBACK* callback)
if (gfx->SmallCache) if (gfx->SmallCache)
capsSet->flags |= RDPGFX_CAPS_FLAG_SMALL_CACHE; capsSet->flags |= RDPGFX_CAPS_FLAG_SMALL_CACHE;
capsSet = &capsSets[1]; capsSet = &capsSets[pdu.capsSetCount++];
capsSet->version = RDPGFX_CAPVERSION_81; capsSet->version = RDPGFX_CAPVERSION_81;
capsSet->flags = 0; capsSet->flags = 0;
@ -1066,6 +1053,7 @@ int DVCPluginEntry(IDRDYNVC_ENTRY_POINTS* pEntryPoints)
return -1; return -1;
gfx->log = WLog_Get("com.freerdp.gfx.client"); gfx->log = WLog_Get("com.freerdp.gfx.client");
gfx->settings = (rdpSettings*) pEntryPoints->GetRdpSettings(pEntryPoints);
gfx->iface.Initialize = rdpgfx_plugin_initialize; gfx->iface.Initialize = rdpgfx_plugin_initialize;
gfx->iface.Connected = NULL; gfx->iface.Connected = NULL;
@ -1077,7 +1065,18 @@ int DVCPluginEntry(IDRDYNVC_ENTRY_POINTS* pEntryPoints)
if (!gfx->SurfaceTable) if (!gfx->SurfaceTable)
return -1; return -1;
gfx->ThinClient = TRUE; gfx->ThinClient = gfx->settings->GfxThinClient;
gfx->SmallCache = gfx->settings->GfxSmallCache;
gfx->Progressive = gfx->settings->GfxProgressive;
gfx->ProgressiveV2 = gfx->settings->GfxProgressiveV2;
gfx->H264 = gfx->settings->GfxH264;
if (gfx->H264)
gfx->SmallCache = TRUE;
if (gfx->SmallCache)
gfx->ThinClient = FALSE;
gfx->MaxCacheSlot = (gfx->ThinClient) ? 4096 : 25600; gfx->MaxCacheSlot = (gfx->ThinClient) ? 4096 : 25600;
context = (RdpgfxClientContext*) calloc(1, sizeof(RdpgfxClientContext)); context = (RdpgfxClientContext*) calloc(1, sizeof(RdpgfxClientContext));

View File

@ -59,9 +59,12 @@ struct _RDPGFX_PLUGIN
RDPGFX_LISTENER_CALLBACK* listener_callback; RDPGFX_LISTENER_CALLBACK* listener_callback;
wLog* log; wLog* log;
rdpSettings* settings;
BOOL ThinClient; BOOL ThinClient;
BOOL SmallCache; BOOL SmallCache;
BOOL Progressive;
BOOL ProgressiveV2;
BOOL H264; BOOL H264;
ZGFX_CONTEXT* zgfx; ZGFX_CONTEXT* zgfx;

View File

@ -111,6 +111,11 @@ COMMAND_LINE_ARGUMENT_A args[] =
{ "wallpaper", COMMAND_LINE_VALUE_BOOL, NULL, BoolValueTrue, NULL, -1, NULL, "Wallpaper" }, { "wallpaper", COMMAND_LINE_VALUE_BOOL, NULL, BoolValueTrue, NULL, -1, NULL, "Wallpaper" },
{ "gdi", COMMAND_LINE_VALUE_REQUIRED, "<sw|hw>", NULL, NULL, -1, NULL, "GDI rendering" }, { "gdi", COMMAND_LINE_VALUE_REQUIRED, "<sw|hw>", NULL, NULL, -1, NULL, "GDI rendering" },
{ "gfx", COMMAND_LINE_VALUE_OPTIONAL, NULL, NULL, NULL, -1, NULL, "RDP8 graphics pipeline (experimental)" }, { "gfx", COMMAND_LINE_VALUE_OPTIONAL, NULL, NULL, NULL, -1, NULL, "RDP8 graphics pipeline (experimental)" },
{ "gfx-thin-client", COMMAND_LINE_VALUE_BOOL, NULL, BoolValueFalse, NULL, -1, NULL, "RDP8 graphics pipeline thin client mode" },
{ "gfx-small-cache", COMMAND_LINE_VALUE_BOOL, NULL, BoolValueFalse, NULL, -1, NULL, "RDP8 graphics pipeline small cache mode" },
{ "gfx-progressive", COMMAND_LINE_VALUE_BOOL, NULL, BoolValueFalse, NULL, -1, NULL, "RDP8 graphics pipeline progressive codec" },
{ "gfx-progressive-v2", COMMAND_LINE_VALUE_BOOL, NULL, BoolValueFalse, NULL, -1, NULL, "RDP8.1 graphics pipeline progressive v2 codec" },
{ "gfx-h264", COMMAND_LINE_VALUE_BOOL, NULL, BoolValueFalse, NULL, -1, NULL, "RDP8.1 graphics pipeline H264 codec" },
{ "rfx", COMMAND_LINE_VALUE_FLAG, NULL, NULL, NULL, -1, NULL, "RemoteFX" }, { "rfx", COMMAND_LINE_VALUE_FLAG, NULL, NULL, NULL, -1, NULL, "RemoteFX" },
{ "rfx-mode", COMMAND_LINE_VALUE_REQUIRED, "<image|video>", NULL, NULL, -1, NULL, "RemoteFX mode" }, { "rfx-mode", COMMAND_LINE_VALUE_REQUIRED, "<image|video>", NULL, NULL, -1, NULL, "RemoteFX mode" },
{ "frame-ack", COMMAND_LINE_VALUE_REQUIRED, "<number>", NULL, NULL, -1, NULL, "Frame acknowledgement" }, { "frame-ack", COMMAND_LINE_VALUE_REQUIRED, "<number>", NULL, NULL, -1, NULL, "Frame acknowledgement" },
@ -1621,10 +1626,31 @@ int freerdp_client_settings_parse_command_line_arguments(rdpSettings* settings,
CommandLineSwitchCase(arg, "gfx") CommandLineSwitchCase(arg, "gfx")
{ {
settings->SupportGraphicsPipeline = TRUE; settings->SupportGraphicsPipeline = TRUE;
settings->FastPathOutput = TRUE; }
settings->ColorDepth = 32; CommandLineSwitchCase(arg, "gfx-thin-client")
settings->LargePointerFlag = TRUE; {
settings->FrameMarkerCommandEnabled = TRUE; settings->GfxThinClient = arg->Value ? TRUE : FALSE;
settings->SupportGraphicsPipeline = TRUE;
}
CommandLineSwitchCase(arg, "gfx-small-cache")
{
settings->GfxSmallCache = arg->Value ? TRUE : FALSE;
settings->SupportGraphicsPipeline = TRUE;
}
CommandLineSwitchCase(arg, "gfx-progressive")
{
settings->GfxProgressive = arg->Value ? TRUE : FALSE;
settings->SupportGraphicsPipeline = TRUE;
}
CommandLineSwitchCase(arg, "gfx-progressive-v2")
{
settings->GfxProgressiveV2 = arg->Value ? TRUE : FALSE;
settings->SupportGraphicsPipeline = TRUE;
}
CommandLineSwitchCase(arg, "gfx-h264")
{
settings->GfxH264 = arg->Value ? TRUE : FALSE;
settings->SupportGraphicsPipeline = TRUE;
} }
CommandLineSwitchCase(arg, "rfx") CommandLineSwitchCase(arg, "rfx")
{ {
@ -1887,6 +1913,14 @@ int freerdp_client_settings_parse_command_line_arguments(rdpSettings* settings,
} }
} }
if (settings->SupportGraphicsPipeline)
{
settings->FastPathOutput = TRUE;
settings->ColorDepth = 32;
settings->LargePointerFlag = TRUE;
settings->FrameMarkerCommandEnabled = TRUE;
}
arg = CommandLineFindArgumentA(args, "port"); arg = CommandLineFindArgumentA(args, "port");
if (arg->Flags & COMMAND_LINE_ARGUMENT_PRESENT) if (arg->Flags & COMMAND_LINE_ARGUMENT_PRESENT)

View File

@ -152,7 +152,8 @@ struct _IDRDYNVC_ENTRY_POINTS
const char *name, IWTSPlugin *pPlugin); const char *name, IWTSPlugin *pPlugin);
IWTSPlugin *(*GetPlugin)(IDRDYNVC_ENTRY_POINTS *pEntryPoints, IWTSPlugin *(*GetPlugin)(IDRDYNVC_ENTRY_POINTS *pEntryPoints,
const char *name); const char *name);
ADDIN_ARGV *(*GetPluginData)(IDRDYNVC_ENTRY_POINTS *pEntryPoints); ADDIN_ARGV* (*GetPluginData)(IDRDYNVC_ENTRY_POINTS* pEntryPoints);
void* (*GetRdpSettings)(IDRDYNVC_ENTRY_POINTS* pEntryPoints);
}; };
typedef int (*PDVC_PLUGIN_ENTRY)(IDRDYNVC_ENTRY_POINTS *); typedef int (*PDVC_PLUGIN_ENTRY)(IDRDYNVC_ENTRY_POINTS *);

View File

@ -753,6 +753,11 @@ typedef struct _RDPDR_PARALLEL RDPDR_PARALLEL;
#define FreeRDP_JpegCodec 3776 #define FreeRDP_JpegCodec 3776
#define FreeRDP_JpegCodecId 3777 #define FreeRDP_JpegCodecId 3777
#define FreeRDP_JpegQuality 3778 #define FreeRDP_JpegQuality 3778
#define FreeRDP_GfxThinClient 3840
#define FreeRDP_GfxSmallCache 3841
#define FreeRDP_GfxProgressive 3842
#define FreeRDP_GfxProgressiveV2 3843
#define FreeRDP_GfxH264 3844
#define FreeRDP_BitmapCacheV3CodecId 3904 #define FreeRDP_BitmapCacheV3CodecId 3904
#define FreeRDP_DrawNineGridEnabled 3968 #define FreeRDP_DrawNineGridEnabled 3968
#define FreeRDP_DrawNineGridCacheSize 3969 #define FreeRDP_DrawNineGridCacheSize 3969
@ -1261,7 +1266,13 @@ struct rdp_settings
ALIGN64 UINT32 JpegCodecId; /* 3777 */ ALIGN64 UINT32 JpegCodecId; /* 3777 */
ALIGN64 UINT32 JpegQuality; /* 3778 */ ALIGN64 UINT32 JpegQuality; /* 3778 */
UINT64 padding3840[3840 - 3779]; /* 3779 */ UINT64 padding3840[3840 - 3779]; /* 3779 */
UINT64 padding3904[3904 - 3840]; /* 3840 */
ALIGN64 BOOL GfxThinClient; /* 3840 */
ALIGN64 BOOL GfxSmallCache; /* 3841 */
ALIGN64 BOOL GfxProgressive; /* 3842 */
ALIGN64 BOOL GfxProgressiveV2; /* 3843 */
ALIGN64 BOOL GfxH264; /* 3844 */
UINT64 padding3904[3904 - 3845]; /* 3845 */
/** /**
* Caches * Caches

View File

@ -1077,6 +1077,26 @@ BOOL freerdp_get_param_bool(rdpSettings* settings, int id)
return settings->JpegCodec; return settings->JpegCodec;
break; break;
case FreeRDP_GfxThinClient:
return settings->GfxThinClient;
break;
case FreeRDP_GfxSmallCache:
return settings->GfxSmallCache;
break;
case FreeRDP_GfxProgressive:
return settings->GfxProgressive;
break;
case FreeRDP_GfxProgressiveV2:
return settings->GfxProgressiveV2;
break;
case FreeRDP_GfxH264:
return settings->GfxH264;
break;
case FreeRDP_DrawNineGridEnabled: case FreeRDP_DrawNineGridEnabled:
return settings->DrawNineGridEnabled; return settings->DrawNineGridEnabled;
break; break;
@ -1566,6 +1586,26 @@ int freerdp_set_param_bool(rdpSettings* settings, int id, BOOL param)
settings->JpegCodec = param; settings->JpegCodec = param;
break; break;
case FreeRDP_GfxThinClient:
settings->GfxThinClient = param;
break;
case FreeRDP_GfxSmallCache:
settings->GfxSmallCache = param;
break;
case FreeRDP_GfxProgressive:
settings->GfxProgressive = param;
break;
case FreeRDP_GfxProgressiveV2:
settings->GfxProgressiveV2 = param;
break;
case FreeRDP_GfxH264:
settings->GfxH264 = param;
break;
case FreeRDP_DrawNineGridEnabled: case FreeRDP_DrawNineGridEnabled:
settings->DrawNineGridEnabled = param; settings->DrawNineGridEnabled = param;
break; break;

View File

@ -401,6 +401,12 @@ rdpSettings* freerdp_settings_new(DWORD flags)
settings->AutoReconnectionEnabled = FALSE; settings->AutoReconnectionEnabled = FALSE;
settings->AutoReconnectMaxRetries = 20; settings->AutoReconnectMaxRetries = 20;
settings->GfxThinClient = TRUE;
settings->GfxSmallCache = FALSE;
settings->GfxProgressive = FALSE;
settings->GfxProgressiveV2 = FALSE;
settings->GfxH264 = FALSE;
settings->ClientAutoReconnectCookie = (ARC_CS_PRIVATE_PACKET*) malloc(sizeof(ARC_CS_PRIVATE_PACKET)); settings->ClientAutoReconnectCookie = (ARC_CS_PRIVATE_PACKET*) malloc(sizeof(ARC_CS_PRIVATE_PACKET));
settings->ServerAutoReconnectCookie = (ARC_SC_PRIVATE_PACKET*) malloc(sizeof(ARC_SC_PRIVATE_PACKET)); settings->ServerAutoReconnectCookie = (ARC_SC_PRIVATE_PACKET*) malloc(sizeof(ARC_SC_PRIVATE_PACKET));
ZeroMemory(settings->ClientAutoReconnectCookie, sizeof(ARC_CS_PRIVATE_PACKET)); ZeroMemory(settings->ClientAutoReconnectCookie, sizeof(ARC_CS_PRIVATE_PACKET));
@ -697,6 +703,11 @@ rdpSettings* freerdp_settings_clone(rdpSettings* settings)
_settings->RemoteFxImageCodec = settings->RemoteFxImageCodec; /* 3652 */ _settings->RemoteFxImageCodec = settings->RemoteFxImageCodec; /* 3652 */
_settings->NSCodec = settings->NSCodec; /* 3712 */ _settings->NSCodec = settings->NSCodec; /* 3712 */
_settings->JpegCodec = settings->JpegCodec; /* 3776 */ _settings->JpegCodec = settings->JpegCodec; /* 3776 */
_settings->GfxThinClient = settings->GfxThinClient; /* 3840 */
_settings->GfxSmallCache = settings->GfxSmallCache; /* 3841 */
_settings->GfxProgressive = settings->GfxProgressive; /* 3842 */
_settings->GfxProgressiveV2 = settings->GfxProgressiveV2; /* 3843 */
_settings->GfxH264 = settings->GfxH264; /* 3844 */
_settings->DrawNineGridEnabled = settings->DrawNineGridEnabled; /* 3968 */ _settings->DrawNineGridEnabled = settings->DrawNineGridEnabled; /* 3968 */
_settings->DrawGdiPlusEnabled = settings->DrawGdiPlusEnabled; /* 4032 */ _settings->DrawGdiPlusEnabled = settings->DrawGdiPlusEnabled; /* 4032 */
_settings->DrawGdiPlusCacheEnabled = settings->DrawGdiPlusCacheEnabled; /* 4033 */ _settings->DrawGdiPlusCacheEnabled = settings->DrawGdiPlusCacheEnabled; /* 4033 */