GFX: use the preferred codec preferred in the config (H264 or RFX)

(cherry picked from commit 2c2585cc90)
This commit is contained in:
Koichiro Iwao 2024-08-26 18:23:10 +09:00
parent 689a2620d3
commit 5bbeb03848
3 changed files with 29 additions and 6 deletions

View File

@ -1345,19 +1345,31 @@ xrdp_mm_egfx_caps_advertise(void *user, int caps_count,
break; break;
} }
} }
#if defined(XRDP_H264)
struct xrdp_tconfig_gfx_codec_order co = self->wm->gfx_config->codec;
bool_t use_h264 = (best_h264_index >= 0 && (best_pro_index < 0 || (co.h264_idx >= 0 && co.h264_idx < co.rfx_idx)));
if (use_h264)
{
best_index = best_h264_index;
self->egfx_flags = XRDP_EGFX_H264;
}
else if (best_pro_index >= 0)
{
best_index = best_pro_index;
self->egfx_flags = XRDP_EGFX_RFX_PRO;
}
#else
if (best_pro_index >= 0) if (best_pro_index >= 0)
{ {
best_index = best_pro_index; best_index = best_pro_index;
self->egfx_flags = XRDP_EGFX_RFX_PRO; self->egfx_flags = XRDP_EGFX_RFX_PRO;
} }
/* prefer h264, todo use setting in xrdp.ini for this */
if (best_h264_index >= 0) if (best_h264_index >= 0)
{ {
#if defined(XRDP_H264)
best_index = best_h264_index;
self->egfx_flags = XRDP_EGFX_H264;
#endif
} }
#endif
if (best_index >= 0) if (best_index >= 0)
{ {
LOG(LOG_LEVEL_INFO, " replying version 0x%8.8x flags 0x%8.8x", LOG(LOG_LEVEL_INFO, " replying version 0x%8.8x flags 0x%8.8x",

View File

@ -29,6 +29,7 @@
#include "fifo.h" #include "fifo.h"
#include "guid.h" #include "guid.h"
#include "xrdp_client_info.h" #include "xrdp_client_info.h"
#include "xrdp_tconfig.h"
#define MAX_NR_CHANNELS 16 #define MAX_NR_CHANNELS 16
#define MAX_CHANNEL_NAME 16 #define MAX_CHANNEL_NAME 16
@ -566,6 +567,8 @@ struct xrdp_wm
/* configuration derived from xrdp.ini */ /* configuration derived from xrdp.ini */
struct xrdp_config *xrdp_config; struct xrdp_config *xrdp_config;
/* configuration derived from gfx.toml */
struct xrdp_tconfig_gfx *gfx_config;
struct xrdp_region *screen_dirty_region; struct xrdp_region *screen_dirty_region;
int last_screen_draw_time; int last_screen_draw_time;

View File

@ -114,8 +114,9 @@ xrdp_wm_create(struct xrdp_process *owner,
self->target_surface = self->screen; self->target_surface = self->screen;
self->current_surface_index = 0xffff; /* screen */ self->current_surface_index = 0xffff; /* screen */
/* to store configuration from xrdp.ini */ /* to store configuration from xrdp.ini, gfx.toml */
self->xrdp_config = g_new0(struct xrdp_config, 1); self->xrdp_config = g_new0(struct xrdp_config, 1);
self->gfx_config = g_new0(struct xrdp_tconfig_gfx, 1);
/* Load the channel config so libxrdp can check whether /* Load the channel config so libxrdp can check whether
drdynvc is enabled or not */ drdynvc is enabled or not */
@ -162,6 +163,11 @@ xrdp_wm_delete(struct xrdp_wm *self)
g_free(self->xrdp_config); g_free(self->xrdp_config);
} }
if (self->gfx_config)
{
g_free(self->gfx_config);
}
/* free self */ /* free self */
g_free(self); g_free(self);
} }
@ -642,6 +648,8 @@ xrdp_wm_init(struct xrdp_wm *self)
load_xrdp_config(self->xrdp_config, self->session->xrdp_ini, load_xrdp_config(self->xrdp_config, self->session->xrdp_ini,
self->screen->bpp); self->screen->bpp);
tconfig_load_gfx(XRDP_CFG_PATH "/gfx.toml", self->gfx_config);
/* Remove a font loaded on the previous config */ /* Remove a font loaded on the previous config */
xrdp_font_delete(self->default_font); xrdp_font_delete(self->default_font);
self->painter->font = NULL; /* May be set to the default_font */ self->painter->font = NULL; /* May be set to the default_font */