Skip to content

Commit

Permalink
Merge pull request #186 from jsorg71/damage
Browse files Browse the repository at this point in the history
use damage to track any lost screen changes
  • Loading branch information
matt335672 authored May 4, 2022
2 parents 1c02fe3 + cfafcd2 commit 946f39b
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 2 deletions.
1 change: 1 addition & 0 deletions module/rdp.h
Original file line number Diff line number Diff line change
Expand Up @@ -325,6 +325,7 @@ struct _rdpRec
int fd;
/* egl */
void *egl;
DamagePtr damage;
};
typedef struct _rdpRec rdpRec;
typedef struct _rdpRec * rdpPtr;
Expand Down
47 changes: 45 additions & 2 deletions xrdpdev/xrdpdev.c
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,8 @@ Bool g_use_dri3 = TRUE;
while (0)

static int g_setup_done = 0;
static OsTimerPtr g_timer = 0;
static OsTimerPtr g_randr_timer = 0;
static OsTimerPtr g_damage_timer = 0;

static char g_xrdp_driver_name[] = XRDP_DRIVER_NAME;

Expand Down Expand Up @@ -367,6 +368,47 @@ rdpResizeSession(rdpPtr dev, int width, int height)
return ok;
}

/*****************************************************************************/
static void
xorgxrdpDamageReport(DamagePtr pDamage, RegionPtr pRegion, void *closure)
{
rdpPtr dev;
ScreenPtr pScreen;

LLOGLN(10, ("xorgxrdpDamageReport:"));
pScreen = (ScreenPtr)closure;
dev = rdpGetDevFromScreen(pScreen);
rdpClientConAddAllReg(dev, pRegion, &(pScreen->root->drawable));
}

/*****************************************************************************/
static void
xorgxrdpDamageDestroy(DamagePtr pDamage, void *closure)
{
LLOGLN(0, ("xorgxrdpDamageDestroy:"));
}

/******************************************************************************/
/* returns error */
static CARD32
rdpDeferredDamage(OsTimerPtr timer, CARD32 now, pointer arg)
{
ScreenPtr pScreen;
rdpPtr dev;

pScreen = (ScreenPtr) arg;
dev = rdpGetDevFromScreen(pScreen);
dev->damage = DamageCreate(xorgxrdpDamageReport, xorgxrdpDamageDestroy,
DamageReportRawRegion, TRUE,
pScreen, pScreen);
if (dev->damage != NULL)
{
DamageSetReportAfterOp(dev->damage, TRUE);
DamageRegister(&(pScreen->root->drawable), dev->damage);
}
return 0;
}

/******************************************************************************/
/* returns error */
static CARD32
Expand Down Expand Up @@ -723,7 +765,8 @@ rdpScreenInit(ScreenPtr pScreen, int argc, char **argv)

RegisterBlockAndWakeupHandlers(rdpBlockHandler1, rdpWakeupHandler1, pScreen);

g_timer = TimerSet(g_timer, 0, 10, rdpDeferredRandR, pScreen);
g_randr_timer = TimerSet(g_randr_timer, 0, 10, rdpDeferredRandR, pScreen);
g_damage_timer = TimerSet(g_damage_timer, 0, 10, rdpDeferredDamage, pScreen);

if (rdpClientConInit(dev) != 0)
{
Expand Down

0 comments on commit 946f39b

Please sign in to comment.