summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorChris Wilson <chris@chris-wilson.co.uk>2012-06-29 11:06:33 +0100
committerChris Wilson <chris@chris-wilson.co.uk>2012-06-29 11:06:33 +0100
commite6f9bfe1e20c4c76822d77598f4f1c7e10754929 (patch)
treeb6cc594ee362e2e9f2c99e983069fc3573357203 /src
parentc6c4f30e194eb3b8a2421134bb005f1542b3ef9f (diff)
sna: Use currentTime rather than GetTimeInMillis()
The overhead of reading the hpet() on every block handler (more or less) is exorbitant, so trust that we update currentTime frequently enough to be a good approximation - the side effect is that we will wakeup slightly to earlier from using an old value for the current time. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Diffstat (limited to 'src')
-rw-r--r--src/sna/sna.h1
-rw-r--r--src/sna/sna_accel.c51
2 files changed, 25 insertions, 27 deletions
diff --git a/src/sna/sna.h b/src/sna/sna.h
index d4cb42f6..54ff4d52 100644
--- a/src/sna/sna.h
+++ b/src/sna/sna.h
@@ -216,7 +216,6 @@ struct sna {
unsigned watch_flush;
unsigned flush;
- uint32_t time;
OsTimerPtr timer;
uint32_t timer_expire[NUM_TIMERS];
uint16_t timer_active;
diff --git a/src/sna/sna_accel.c b/src/sna/sna_accel.c
index 86e22ec9..b9164aea 100644
--- a/src/sna/sna_accel.c
+++ b/src/sna/sna_accel.c
@@ -12308,9 +12308,10 @@ static struct sna_pixmap *sna_accel_scanout(struct sna *sna)
return priv && priv->gpu_bo ? priv : NULL;
}
+#define TIME currentTime.milliseconds
static void sna_accel_disarm_timer(struct sna *sna, int id)
{
- DBG(("%s[%d] (time=%ld)\n", __FUNCTION__, id, (long)sna->time));
+ DBG(("%s[%d] (time=%ld)\n", __FUNCTION__, id, (long)TIME));
sna->timer_active &= ~(1<<id);
sna->timer_ready &= ~(1<<id);
}
@@ -12370,9 +12371,9 @@ static bool sna_accel_do_flush(struct sna *sna)
if (sna->timer_active & (1<<(FLUSH_TIMER))) {
DBG(("%s: flush timer active\n", __FUNCTION__));
if (sna->timer_ready & (1<<(FLUSH_TIMER))) {
- DBG(("%s (time=%ld), triggered\n", __FUNCTION__, (long)sna->time));
+ DBG(("%s (time=%ld), triggered\n", __FUNCTION__, (long)TIME));
sna->timer_expire[FLUSH_TIMER] =
- sna->time + sna->vblank_interval;
+ TIME + sna->vblank_interval;
return true;
}
} else {
@@ -12382,8 +12383,8 @@ static bool sna_accel_do_flush(struct sna *sna)
sna->timer_active |= 1 << FLUSH_TIMER;
sna->timer_ready |= 1 << FLUSH_TIMER;
sna->timer_expire[FLUSH_TIMER] =
- sna->time + sna->vblank_interval / 2;
- DBG(("%s (time=%ld), starting\n", __FUNCTION__, (long)sna->time));
+ TIME + sna->vblank_interval / 2;
+ DBG(("%s (time=%ld), starting\n", __FUNCTION__, (long)TIME));
}
}
@@ -12397,18 +12398,18 @@ static bool sna_accel_do_throttle(struct sna *sna)
if (sna->timer_active & (1<<(THROTTLE_TIMER))) {
if (sna->timer_ready & (1<<(THROTTLE_TIMER))) {
- DBG(("%s (time=%ld), triggered\n", __FUNCTION__, (long)sna->time));
- sna->timer_expire[THROTTLE_TIMER] = sna->time + 20;
+ DBG(("%s (time=%ld), triggered\n", __FUNCTION__, (long)TIME));
+ sna->timer_expire[THROTTLE_TIMER] = TIME + 20;
return true;
}
} else {
if (!sna->kgem.need_retire) {
DBG(("%s -- no pending activity\n", __FUNCTION__));
} else {
- DBG(("%s (time=%ld), starting\n", __FUNCTION__, (long)sna->time));
+ DBG(("%s (time=%ld), starting\n", __FUNCTION__, (long)TIME));
sna->timer_active |= 1 << THROTTLE_TIMER;
sna->timer_ready |= 1 << THROTTLE_TIMER;
- sna->timer_expire[THROTTLE_TIMER] = sna->time + 20;
+ sna->timer_expire[THROTTLE_TIMER] = TIME + 20;
}
}
@@ -12419,9 +12420,9 @@ static bool sna_accel_do_expire(struct sna *sna)
{
if (sna->timer_active & (1<<(EXPIRE_TIMER))) {
if (sna->timer_ready & (1<<(EXPIRE_TIMER))) {
- DBG(("%s (time=%ld), triggered\n", __FUNCTION__, (long)sna->time));
+ DBG(("%s (time=%ld), triggered\n", __FUNCTION__, (long)TIME));
sna->timer_expire[EXPIRE_TIMER] =
- sna->time + MAX_INACTIVE_TIME * 1000;
+ TIME + MAX_INACTIVE_TIME * 1000;
return true;
}
} else {
@@ -12429,8 +12430,8 @@ static bool sna_accel_do_expire(struct sna *sna)
sna->timer_active |= 1 << EXPIRE_TIMER;
sna->timer_ready |= 1 << EXPIRE_TIMER;
sna->timer_expire[EXPIRE_TIMER] =
- sna->time + MAX_INACTIVE_TIME * 1000;
- DBG(("%s (time=%ld), starting\n", __FUNCTION__, (long)sna->time));
+ TIME + MAX_INACTIVE_TIME * 1000;
+ DBG(("%s (time=%ld), starting\n", __FUNCTION__, (long)TIME));
}
}
@@ -12442,8 +12443,8 @@ static bool sna_accel_do_inactive(struct sna *sna)
if (sna->timer_active & (1<<(INACTIVE_TIMER))) {
if (sna->timer_ready & (1<<(INACTIVE_TIMER))) {
sna->timer_expire[INACTIVE_TIMER] =
- sna->time + 120 * 1000;
- DBG(("%s (time=%ld), triggered\n", __FUNCTION__, (long)sna->time));
+ TIME + 120 * 1000;
+ DBG(("%s (time=%ld), triggered\n", __FUNCTION__, (long)TIME));
return true;
}
} else {
@@ -12451,8 +12452,8 @@ static bool sna_accel_do_inactive(struct sna *sna)
sna->timer_active |= 1 << INACTIVE_TIMER;
sna->timer_ready |= 1 << INACTIVE_TIMER;
sna->timer_expire[INACTIVE_TIMER] =
- sna->time + 120 * 1000;
- DBG(("%s (time=%ld), starting\n", __FUNCTION__, (long)sna->time));
+ TIME + 120 * 1000;
+ DBG(("%s (time=%ld), starting\n", __FUNCTION__, (long)TIME));
}
}
@@ -12495,7 +12496,7 @@ static void sna_accel_flush(struct sna *sna)
bool busy;
DBG(("%s (time=%ld), cpu damage? %p, exec? %d nbatch=%d, busy? %d\n",
- __FUNCTION__, (long)sna->time,
+ __FUNCTION__, (long)TIME,
priv && priv->cpu_damage,
priv && priv->gpu_bo->exec != NULL,
sna->kgem.nbatch,
@@ -12516,7 +12517,7 @@ static void sna_accel_flush(struct sna *sna)
static void sna_accel_throttle(struct sna *sna)
{
- DBG(("%s (time=%ld)\n", __FUNCTION__, (long)sna->time));
+ DBG(("%s (time=%ld)\n", __FUNCTION__, (long)TIME));
if (sna->kgem.need_throttle)
kgem_throttle(&sna->kgem);
@@ -12527,7 +12528,7 @@ static void sna_accel_throttle(struct sna *sna)
static void sna_accel_expire(struct sna *sna)
{
- DBG(("%s (time=%ld)\n", __FUNCTION__, (long)sna->time));
+ DBG(("%s (time=%ld)\n", __FUNCTION__, (long)TIME));
if (!kgem_expire_cache(&sna->kgem))
sna_accel_disarm_timer(sna, EXPIRE_TIMER);
@@ -12538,7 +12539,7 @@ static void sna_accel_inactive(struct sna *sna)
struct sna_pixmap *priv;
struct list preserve;
- DBG(("%s (time=%ld)\n", __FUNCTION__, (long)sna->time));
+ DBG(("%s (time=%ld)\n", __FUNCTION__, (long)TIME));
#if DEBUG_ACCEL
{
@@ -12633,10 +12634,10 @@ static void sna_accel_inactive(struct sna *sna)
#ifdef DEBUG_MEMORY
static bool sna_accel_do_debug_memory(struct sna *sna)
{
- int32_t delta = sna->timer_expire[DEBUG_MEMORY_TIMER] - sna->time;
+ int32_t delta = sna->timer_expire[DEBUG_MEMORY_TIMER] - TIME;
if (delta <= 3) {
- sna->timer_expire[DEBUG_MEMORY_TIMER] = sna->time + 10 * 1000;
+ sna->timer_expire[DEBUG_MEMORY_TIMER] = TIME + 10 * 1000;
return true;
} else
return false;
@@ -12806,8 +12807,6 @@ void sna_accel_close(struct sna *sna)
void sna_accel_block_handler(struct sna *sna, struct timeval **tv)
{
- sna->time = GetTimeInMillis();
-
sna_accel_wakeup_handler(sna, NULL);
if (sna_accel_do_flush(sna))
@@ -12846,7 +12845,7 @@ void sna_accel_block_handler(struct sna *sna, struct timeval **tv)
DBG(("%s: evaluating timers, ready=%x\n",
__FUNCTION__, sna->timer_ready));
sna->timer_ready = 0;
- timeout = sna_timeout(sna->timer, sna->time, sna);
+ timeout = sna_timeout(sna->timer, TIME, sna);
TimerSet(sna->timer, 0, timeout, sna_timeout, sna);
if (timeout) {
if (*tv == NULL) {