[Mesa-dev] [PATCH 04/27] gbm: Create a gbm_device getter for stride

Eric Engestrom eric.engestrom at imgtec.com
Fri Dec 2 17:58:40 UTC 2016


On Thursday, 2016-12-01 14:09:45 -0800, Ben Widawsky wrote:
> From: Ben Widawsky <ben at bwidawsk.net>
> 
> This will be used so we can query information per plane.
> 
> Signed-off-by: Ben Widawsky <ben at bwidawsk.net>
> ---
>  src/gbm/backends/dri/gbm_dri.c | 7 +++++++
>  src/gbm/main/gbm.c             | 2 +-
>  src/gbm/main/gbmint.h          | 1 +
>  3 files changed, 9 insertions(+), 1 deletion(-)
> 
> diff --git a/src/gbm/backends/dri/gbm_dri.c b/src/gbm/backends/dri/gbm_dri.c
> index c61d56b..f3ca228 100644
> --- a/src/gbm/backends/dri/gbm_dri.c
> +++ b/src/gbm/backends/dri/gbm_dri.c
> @@ -622,6 +622,12 @@ gbm_dri_bo_get_planes(struct gbm_bo *_bo)
>     return get_number_planes(dri, bo->image);
>  }
>  
> +static uint32_t
> +gbm_dri_bo_get_stride(struct gbm_bo *_bo, int plane)

`unsigned plane`?
Same in the next patches.

There is a very weird mix of sized- and unsized-types in these patches
(see also comment on patch #2); what is the reasoning here?
(For instance, the return type is sized but the input plane isn't.)

> +{
> +   return _bo->stride;
> +}
> +
>  static void
>  gbm_dri_bo_destroy(struct gbm_bo *_bo)
>  {
> @@ -1080,6 +1086,7 @@ dri_device_create(int fd)
>     dri->base.base.bo_write = gbm_dri_bo_write;
>     dri->base.base.bo_get_fd = gbm_dri_bo_get_fd;
>     dri->base.base.bo_get_planes = gbm_dri_bo_get_planes;
> +   dri->base.base.bo_get_stride = gbm_dri_bo_get_stride;
>     dri->base.base.bo_destroy = gbm_dri_bo_destroy;
>     dri->base.base.destroy = dri_destroy;
>     dri->base.base.surface_create = gbm_dri_surface_create;
> diff --git a/src/gbm/main/gbm.c b/src/gbm/main/gbm.c
> index b5e0316..14c31ad 100644
> --- a/src/gbm/main/gbm.c
> +++ b/src/gbm/main/gbm.c
> @@ -165,7 +165,7 @@ gbm_bo_get_height(struct gbm_bo *bo)
>  GBM_EXPORT uint32_t
>  gbm_bo_get_stride(struct gbm_bo *bo)
>  {
> -   return bo->stride;
> +   return bo->gbm->bo_get_stride(bo, 0);
>  }
>  
>  /** Get the format of the buffer object
> diff --git a/src/gbm/main/gbmint.h b/src/gbm/main/gbmint.h
> index c6a6701..35d3bcb 100644
> --- a/src/gbm/main/gbmint.h
> +++ b/src/gbm/main/gbmint.h
> @@ -77,6 +77,7 @@ struct gbm_device {
>     int (*bo_write)(struct gbm_bo *bo, const void *buf, size_t data);
>     int (*bo_get_fd)(struct gbm_bo *bo);
>     int (*bo_get_planes)(struct gbm_bo *bo);
> +   uint32_t (*bo_get_stride)(struct gbm_bo *bo, int plane);
>     void (*bo_destroy)(struct gbm_bo *bo);
>  
>     struct gbm_surface *(*surface_create)(struct gbm_device *gbm,
> -- 
> 2.10.2
> 


More information about the mesa-dev mailing list