mirror of
https://github.com/libretro/scummvm.git
synced 2024-12-16 06:39:17 +00:00
SCI: fix race condition in sierra kPalVary code
we are loading pictures very fast, this results in a kPalVary race condition, because sierra set timer to 1 tick, when it was getting called with 0 ticks and required the timer to occur before the transition. Fixes freddy pharkas nighttime being daytime during transitions (bug #3051905) svn-id: r52351
This commit is contained in:
parent
d48e173da1
commit
3e6fb233ac
@ -614,9 +614,18 @@ bool GfxPalette::kernelPalVaryInit(GuiResourceId resourceId, uint16 ticks, uint1
|
||||
_palVaryStepStop = stepStop;
|
||||
_palVaryDirection = direction;
|
||||
// if no ticks are given, jump directly to destination
|
||||
if (!_palVaryTicks)
|
||||
if (!_palVaryTicks) {
|
||||
_palVaryDirection = stepStop;
|
||||
palVaryInstallTimer();
|
||||
// sierra sci set the timer to 1 tick instead of calling it directly
|
||||
// we have to change this to prevent a race condition to happen in
|
||||
// at least freddy pharkas during nighttime. In that case kPalVary is
|
||||
// called right before that and because we load pictures much faster
|
||||
// the 1 tick won't pass sometimes resulting in the palette being
|
||||
// daytime instead of nighttime during the transition.
|
||||
palVaryProcess(1, true);
|
||||
} else {
|
||||
palVaryInstallTimer();
|
||||
}
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
@ -633,9 +642,14 @@ int16 GfxPalette::kernelPalVaryReverse(int16 ticks, uint16 stepStop, int16 direc
|
||||
_palVaryStepStop = stepStop;
|
||||
_palVaryDirection = direction != -1 ? -direction : -_palVaryDirection;
|
||||
|
||||
if (!_palVaryTicks)
|
||||
if (!_palVaryTicks) {
|
||||
_palVaryDirection = _palVaryStepStop - _palVaryStep;
|
||||
palVaryInstallTimer();
|
||||
// ffs. see palVaryInit right above, we fix the code here as well
|
||||
// just in case
|
||||
palVaryProcess(1, true);
|
||||
} else {
|
||||
palVaryInstallTimer();
|
||||
}
|
||||
return kernelPalVaryGetCurrentStep();
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user