summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJesse Barnes <jbarnes@virtuousgeek.org>2010-03-08 11:27:42 -0800
committerJesse Barnes <jbarnes@virtuousgeek.org>2010-03-08 11:28:59 -0800
commitb71ca26a026a356763c51c763bcdd8024fc4a783 (patch)
tree4aa5b94851fb0674774252cfc2b2b5650bbc9411 /src
parent06b54e089eb21736e6d4f6462bbfca987be0c5cc (diff)
DRI2: fixup ScheduleWaitMSC similarly to ScheduleSwap
My merge of Mario's patch for this was botched. Fix it up so that OML waits work correctly, and remove a bogus warning from ScheduleSwap. Reported-by: Mario Kleiner <mario.kleiner@tuebingen.mpg.de> Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
Diffstat (limited to 'src')
-rw-r--r--src/i830_dri.c23
1 files changed, 10 insertions, 13 deletions
diff --git a/src/i830_dri.c b/src/i830_dri.c
index 96d41e71..88e9d906 100644
--- a/src/i830_dri.c
+++ b/src/i830_dri.c
@@ -689,13 +689,6 @@ I830DRI2ScheduleSwap(ClientPtr client, DrawablePtr draw, DRI2BufferPtr front,
if (*target_msc > 0)
*target_msc -= flip;
- if ((*target_msc != 1) && (*target_msc > vbl.reply.sequence) &&
- ((*target_msc - vbl.reply.sequence) > 100))
- xf86DrvMsg(scrn->scrnIndex, X_WARNING,
- "vblank event >100 frames away: cur %ld, target %ld\n",
- (unsigned long)vbl.reply.sequence,
- (unsigned long)*target_msc);
-
/*
* If divisor is zero, or current_msc is smaller than target_msc
* we just need to make sure target_msc passes before initiating
@@ -891,7 +884,7 @@ I830DRI2ScheduleWaitMSC(ClientPtr client, DrawablePtr draw, CARD64 target_msc,
* we just need to make sure target_msc passes before waking up the
* client.
*/
- if (divisor == 0) {
+ if (divisor == 0 || current_msc < target_msc) {
vbl.request.type = DRM_VBLANK_ABSOLUTE | DRM_VBLANK_EVENT;
if (pipe > 0)
vbl.request.type |= DRM_VBLANK_SECONDARY;
@@ -917,13 +910,17 @@ I830DRI2ScheduleWaitMSC(ClientPtr client, DrawablePtr draw, CARD64 target_msc,
if (pipe > 0)
vbl.request.type |= DRM_VBLANK_SECONDARY;
+ vbl.request.sequence = current_msc - (current_msc % divisor) +
+ remainder;
+
/*
- * If the calculated remainder and the condition isn't satisified, it
- * means we've passed the last point where seq % divisor == remainder,
- * so we need to wait for the next time that will happen.
+ * If calculated remainder is larger than requested remainder,
+ * it means we've passed the last point where
+ * seq % divisor == remainder, so we need to wait for the next time
+ * that will happen.
*/
- if ((current_msc % divisor) != remainder)
- vbl.request.sequence += divisor;
+ if ((current_msc % divisor) > remainder)
+ vbl.request.sequence += divisor;
vbl.request.signal = (unsigned long)wait_info;
ret = drmWaitVBlank(intel->drmSubFD, &vbl);