[Spice-devel] [PATCH 12/15] worker: don't pass delta around
Fabiano FidĂȘncio
fidencio at redhat.com
Tue Nov 3 08:20:06 PST 2015
On Tue, Nov 3, 2015 at 11:20 AM, Frediano Ziglio <fziglio at redhat.com> wrote:
> From: Marc-André Lureau <marcandre.lureau at gmail.com>
>
> ---
> server/red_worker.c | 23 ++++++++++++-----------
> 1 file changed, 12 insertions(+), 11 deletions(-)
>
> diff --git a/server/red_worker.c b/server/red_worker.c
> index 9f42f87..f40cd30 100644
> --- a/server/red_worker.c
> +++ b/server/red_worker.c
> @@ -3032,9 +3032,15 @@ static void add_clip_rects(QRegion *rgn, SpiceClipRects *data)
> }
> }
>
> -static inline Shadow *__new_shadow(RedWorker *worker, Drawable *item, SpicePoint *delta)
> +static inline Shadow *__new_shadow(RedWorker *worker, Drawable *item)
> {
> - if (!delta->x && !delta->y) {
> + RedDrawable *red_drawable = item->red_drawable;
> + SpicePoint delta = {
> + .x = red_drawable->u.copy_bits.src_pos.x - red_drawable->bbox.left,
> + .y = red_drawable->u.copy_bits.src_pos.y - red_drawable->bbox.top
> + };
> +
> + if (!delta.x && !delta.y) {
> return NULL;
> }
>
> @@ -3044,22 +3050,21 @@ static inline Shadow *__new_shadow(RedWorker *worker, Drawable *item, SpicePoint
> shadow->base.container = NULL;
> shadow->owner = &item->tree_item;
> region_clone(&shadow->base.rgn, &item->tree_item.base.rgn);
> - region_offset(&shadow->base.rgn, delta->x, delta->y);
> + region_offset(&shadow->base.rgn, delta.x, delta.y);
> ring_item_init(&shadow->base.siblings_link);
> region_init(&shadow->on_hold);
> item->tree_item.shadow = shadow;
> return shadow;
> }
>
> -static inline int red_current_add_with_shadow(RedWorker *worker, Ring *ring, Drawable *item,
> - SpicePoint *delta)
> +static inline int red_current_add_with_shadow(RedWorker *worker, Ring *ring, Drawable *item)
> {
> #ifdef RED_WORKER_STAT
> stat_time_t start_time = stat_now(worker);
> ++worker->add_with_shadow_count;
> #endif
>
> - Shadow *shadow = __new_shadow(worker, item, delta);
> + Shadow *shadow = __new_shadow(worker, item);
> if (!shadow) {
> stat_add(&worker->add_stat, start_time);
> return FALSE;
> @@ -3167,11 +3172,7 @@ static int red_add_drawable(RedWorker *worker, Drawable *drawable)
> Ring *ring = &worker->surfaces[surface_id].current;
>
> if (has_shadow(red_drawable)) {
> - SpicePoint delta = {
> - .x = red_drawable->u.copy_bits.src_pos.x - red_drawable->bbox.left,
> - .y = red_drawable->u.copy_bits.src_pos.y - red_drawable->bbox.top
> - };
> - ret = red_current_add_with_shadow(worker, ring, drawable, &delta);
> + ret = red_current_add_with_shadow(worker, ring, drawable);
> } else {
> red_update_streamable(worker, drawable, red_drawable);
> ret = red_current_add(worker, ring, drawable);
> --
> 2.4.3
>
> _______________________________________________
> Spice-devel mailing list
> Spice-devel at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/spice-devel
ack!
More information about the Spice-devel
mailing list