diff options
author | Chris Wilson <chris@chris-wilson.co.uk> | 2013-09-17 09:15:40 +0100 |
---|---|---|
committer | Chris Wilson <chris@chris-wilson.co.uk> | 2013-09-17 09:29:42 +0100 |
commit | f99e49f7642545f75bac682274767c45c2e6192a (patch) | |
tree | f1ab3e74eadd42c97f60581c91a873e2fd49cd1f /src/sna/sna_driver.c | |
parent | 76790db4e6b33a439a6426ec73547904a50047c5 (diff) |
intel: Make the option to control VSync and PageFlip explict
Too often our implementation of vsync or pageflip is buggy, or for some
other reason it is desired by the user to disable those code paths. Make
it possible once again by restoring the Options for the user to control.
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Diffstat (limited to 'src/sna/sna_driver.c')
-rw-r--r-- | src/sna/sna_driver.c | 32 |
1 files changed, 25 insertions, 7 deletions
diff --git a/src/sna/sna_driver.c b/src/sna/sna_driver.c index 4da6cbb0..da5740a7 100644 --- a/src/sna/sna_driver.c +++ b/src/sna/sna_driver.c @@ -294,12 +294,20 @@ static void sna_selftest(void) sna_damage_selftest(); } +static bool has_vsync(struct sna *sna) +{ + if (sna->flags & SNA_IS_HOSTED) + return false; + + return true; +} + static bool has_pageflipping(struct sna *sna) { drm_i915_getparam_t gp; int v; - if (sna->flags & (SNA_IS_HOSTED | SNA_NO_WAIT)) + if (sna->flags & SNA_IS_HOSTED) return false; v = 0; @@ -508,13 +516,23 @@ static Bool sna_pre_init(ScrnInfoPtr scrn, int flags) if (!xf86ReturnOptValBool(sna->Options, OPTION_SWAPBUFFERS_WAIT, TRUE)) sna->flags |= SNA_NO_WAIT; - if (xf86ReturnOptValBool(sna->Options, OPTION_TRIPLE_BUFFER, TRUE)) - sna->flags |= SNA_TRIPLE_BUFFER; - if (has_pageflipping(sna)) { - if (xf86ReturnOptValBool(sna->Options, OPTION_TEAR_FREE, FALSE)) - sna->flags |= SNA_TEAR_FREE; - } else + + if (!has_vsync(sna) || + !xf86ReturnOptValBool(sna->Options, OPTION_VSYNC, TRUE)) + sna->flags |= SNA_NO_VSYNC; + + if (!has_pageflipping(sna) || + !xf86ReturnOptValBool(sna->Options, OPTION_PAGEFLIP, TRUE)) sna->flags |= SNA_NO_FLIP; + + if ((sna->flags & (SNA_NO_VSYNC | SNA_NO_FLIP | SNA_NO_WAIT)) == 0 && + xf86ReturnOptValBool(sna->Options, OPTION_TRIPLE_BUFFER, TRUE)) + sna->flags |= SNA_TRIPLE_BUFFER; + + if ((sna->flags & (SNA_NO_VSYNC | SNA_NO_FLIP)) == 0 && + xf86ReturnOptValBool(sna->Options, OPTION_TEAR_FREE, FALSE)) + sna->flags |= SNA_TEAR_FREE; + if (xf86ReturnOptValBool(sna->Options, OPTION_CRTC_PIXMAPS, FALSE)) sna->flags |= SNA_FORCE_SHADOW; |