[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