mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-12 15:02:11 +00:00
Bug 888899 - Part 2 - Uses layout.frame_rate=0 for ASAP mode instead of 10k. r=jrmuizel
This commit is contained in:
parent
f1700221b6
commit
91d31fafd1
@ -138,12 +138,13 @@ public:
|
|||||||
|
|
||||||
if (mContext) {
|
if (mContext) {
|
||||||
[mContext makeCurrentContext];
|
[mContext makeCurrentContext];
|
||||||
// Use blocking swap only with the default frame rate.
|
// Use non-blocking swap in "ASAP mode".
|
||||||
|
// ASAP mode means that rendering is iterated as fast as possible.
|
||||||
|
// ASAP mode is entered when layout.frame_rate=0 (requires restart).
|
||||||
// If swapInt is 1, then glSwapBuffers will block and wait for a vblank signal.
|
// If swapInt is 1, then glSwapBuffers will block and wait for a vblank signal.
|
||||||
// While this is fine for the default refresh rate, if the user chooses some
|
// When we're iterating as fast as possible, however, we want a non-blocking
|
||||||
// other rate, and specifically if this rate is higher than the screen refresh rate,
|
// glSwapBuffers, which will happen when swapInt==0.
|
||||||
// then we want a non-blocking glSwapBuffers, which will happen when swapInt==0.
|
GLint swapInt = gfxPlatform::GetPrefLayoutFrameRate() == 0 ? 0 : 1;
|
||||||
GLint swapInt = gfxPlatform::GetPrefLayoutFrameRate() == -1 ? 1 : 0;
|
|
||||||
[mContext setValues:&swapInt forParameter:NSOpenGLCPSwapInterval];
|
[mContext setValues:&swapInt forParameter:NSOpenGLCPSwapInterval];
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -654,11 +654,16 @@ nsRefreshDriver::DefaultInterval()
|
|||||||
// Compute the interval to use for the refresh driver timer, in milliseconds.
|
// Compute the interval to use for the refresh driver timer, in milliseconds.
|
||||||
// outIsDefault indicates that rate was not explicitly set by the user
|
// outIsDefault indicates that rate was not explicitly set by the user
|
||||||
// so we might choose other, more appropriate rates (e.g. vsync, etc)
|
// so we might choose other, more appropriate rates (e.g. vsync, etc)
|
||||||
|
// layout.frame_rate=0 indicates "ASAP mode".
|
||||||
|
// In ASAP mode rendering is iterated as fast as possible (typically for stress testing).
|
||||||
|
// A target rate of 10k is used internally instead of special-handling 0.
|
||||||
|
// Backends which block on swap/present/etc should try to not block
|
||||||
|
// when layout.frame_rate=0 - to comply with "ASAP" as much as possible.
|
||||||
double
|
double
|
||||||
nsRefreshDriver::GetRegularTimerInterval(bool *outIsDefault) const
|
nsRefreshDriver::GetRegularTimerInterval(bool *outIsDefault) const
|
||||||
{
|
{
|
||||||
int32_t rate = Preferences::GetInt("layout.frame_rate", -1);
|
int32_t rate = Preferences::GetInt("layout.frame_rate", -1);
|
||||||
if (rate <= 0) {
|
if (rate < 0) {
|
||||||
rate = DEFAULT_FRAME_RATE;
|
rate = DEFAULT_FRAME_RATE;
|
||||||
if (outIsDefault) {
|
if (outIsDefault) {
|
||||||
*outIsDefault = true;
|
*outIsDefault = true;
|
||||||
@ -668,6 +673,11 @@ nsRefreshDriver::GetRegularTimerInterval(bool *outIsDefault) const
|
|||||||
*outIsDefault = false;
|
*outIsDefault = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (rate == 0) {
|
||||||
|
rate = 10000;
|
||||||
|
}
|
||||||
|
|
||||||
return 1000.0 / rate;
|
return 1000.0 / rate;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user