summaryrefslogtreecommitdiffstats
path: root/server/red_worker.c
diff options
context:
space:
mode:
Diffstat (limited to 'server/red_worker.c')
-rw-r--r--server/red_worker.c18
1 files changed, 4 insertions, 14 deletions
diff --git a/server/red_worker.c b/server/red_worker.c
index 2b23ffdb..11267e9f 100644
--- a/server/red_worker.c
+++ b/server/red_worker.c
@@ -95,6 +95,7 @@
#include "pixmap-cache.h"
#include "display-channel.h"
#include "cursor-channel.h"
+#include "utils.h"
//#define COMPRESS_STAT
//#define DUMP_BITMAP
@@ -155,11 +156,6 @@ static void rendering_incorrect(const char *msg)
spice_warning("rendering incorrect from now on: %s", msg);
}
-static inline red_time_t timespec_to_red_time(struct timespec *time)
-{
- return (red_time_t) time->tv_sec * (1000 * 1000 * 1000) + time->tv_nsec;
-}
-
typedef unsigned long stat_time_t;
#if defined(RED_WORKER_STAT) || defined(COMPRESS_STAT)
@@ -2375,10 +2371,8 @@ static inline unsigned int red_get_streams_timout(RedWorker *worker)
unsigned int timout = -1;
Ring *ring = &worker->streams;
RingItem *item = ring;
- struct timespec time;
- clock_gettime(CLOCK_MONOTONIC, &time);
- red_time_t now = timespec_to_red_time(&time);
+ red_time_t now = red_get_monotonic_time();
while ((item = ring_next(ring, item))) {
Stream *stream;
@@ -2396,11 +2390,9 @@ static inline unsigned int red_get_streams_timout(RedWorker *worker)
static inline void red_handle_streams_timout(RedWorker *worker)
{
Ring *ring = &worker->streams;
- struct timespec time;
RingItem *item;
- clock_gettime(CLOCK_MONOTONIC, &time);
- red_time_t now = timespec_to_red_time(&time);
+ red_time_t now = red_get_monotonic_time();
item = ring_get_head(ring);
while (item) {
Stream *stream = SPICE_CONTAINEROF(item, Stream, link);
@@ -3543,7 +3535,6 @@ static Drawable *get_drawable(RedWorker *worker, uint8_t effect, RedDrawable *re
uint32_t group_id)
{
Drawable *drawable;
- struct timespec time;
int x;
VALIDATE_SURFACE_RETVAL(worker, red_drawable->surface_id, NULL)
@@ -3563,8 +3554,7 @@ static Drawable *get_drawable(RedWorker *worker, uint8_t effect, RedDrawable *re
worker->drawable_count++;
memset(drawable, 0, sizeof(Drawable));
drawable->refs = 1;
- clock_gettime(CLOCK_MONOTONIC, &time);
- drawable->creation_time = timespec_to_red_time(&time);
+ drawable->creation_time = red_get_monotonic_time();
ring_item_init(&drawable->list_link);
ring_item_init(&drawable->surface_list_link);
ring_item_init(&drawable->tree_item.base.siblings_link);