[igt-dev] [PATCH i-g-t v3 11/21] lib/igt_vc4: Add helpers for converting linear to SAND-tiled buffers
Lyude Paul
lyude at redhat.com
Tue Jan 15 21:53:31 UTC 2019
Acked-by: Lyude Paul <lyude at redhat.com>
On Fri, 2019-01-11 at 10:05 +0100, Paul Kocialkowski wrote:
> In order to test buffers with SAND tiling, it is useful to convert
> linear buffers to SAND tiling mode.
>
> Introduce helpers to assist in that direction, one that calculates the
> memory offset in the SAND-tiled buffer for a given pixel position and
> one that makes use of the latter for framebuffer conversion.
>
> Signed-off-by: Paul Kocialkowski <paul.kocialkowski at bootlin.com>
> ---
> lib/igt_vc4.c | 111 ++++++++++++++++++++++++++++++++++++++++++++++++++
> lib/igt_vc4.h | 5 +++
> 2 files changed, 116 insertions(+)
>
> diff --git a/lib/igt_vc4.c b/lib/igt_vc4.c
> index b4b9c2fc6914..3137c0ef85fa 100644
> --- a/lib/igt_vc4.c
> +++ b/lib/igt_vc4.c
> @@ -307,3 +307,114 @@ size_t igt_vc4_t_tiled_offset(size_t stride, size_t
> height, size_t bpp,
>
> return offset;
> }
> +
> +static void vc4_fb_sand_tiled_convert_plane(struct igt_fb *dst, void
> *dst_buf,
> + struct igt_fb *src, void *src_buf,
> + size_t column_width_bytes,
> + size_t column_height,
> + unsigned int plane)
> +{
> + size_t bpp = dst->plane_bpp[plane];
> + size_t column_width = column_width_bytes * dst->plane_width[plane] /
> + dst->width;
> + size_t column_size = column_width_bytes * column_height;
> + unsigned int i, j;
> +
> + for (i = 0; i < dst->plane_height[plane]; i++) {
> + for (j = 0; j < src->plane_width[plane]; j++) {
> + size_t src_offset = src->offsets[plane];
> + size_t dst_offset = dst->offsets[plane];
> +
> + src_offset += src->strides[plane] * i + j * bpp / 8;
> + dst_offset += vc4_sand_tiled_offset(column_width,
> + column_size, j, i,
> + bpp);
> +
> + switch (bpp) {
> + case 8:
> + *(uint8_t *)(dst_buf + dst_offset) =
> + *(uint8_t *)(src_buf + src_offset);
> + break;
> + case 16:
> + *(uint16_t *)(dst_buf + dst_offset) =
> + *(uint16_t *)(src_buf + src_offset);
> + break;
> + default:
> + igt_assert(false);
> + }
> + }
> + }
> +}
> +
> +unsigned int vc4_fb_sand_tiled_convert(struct igt_fb *dst, struct igt_fb
> *src,
> + size_t column_width_bytes,
> + size_t column_height)
> +{
> + unsigned int fb_id;
> + unsigned int i;
> + uint64_t modifier;
> + void *src_buf;
> + void *dst_buf;
> +
> + if (!column_height)
> + column_height = src->height;
> +
> + switch (column_width_bytes) {
> + case 32:
> + modifier =
> + DRM_FORMAT_MOD_BROADCOM_SAND32_COL_HEIGHT(column_heigh
> t);
> + break;
> + case 64:
> + modifier =
> + DRM_FORMAT_MOD_BROADCOM_SAND64_COL_HEIGHT(column_heigh
> t);
> + break;
> + case 128:
> + modifier =
> + DRM_FORMAT_MOD_BROADCOM_SAND128_COL_HEIGHT(column_heig
> ht);
> + break;
> + case 256:
> + modifier =
> + DRM_FORMAT_MOD_BROADCOM_SAND256_COL_HEIGHT(column_heig
> ht);
> + break;
> + default:
> + igt_assert(false);
> + }
> +
> + fb_id = igt_create_fb(src->fd, src->width, src->height, src-
> >drm_format,
> + modifier, dst);
> + igt_assert(fb_id > 0);
> +
> + src_buf = igt_fb_map_buffer(src->fd, src);
> + igt_assert(src_buf);
> +
> + dst_buf = igt_fb_map_buffer(dst->fd, dst);
> + igt_assert(dst_buf);
> +
> + for (i = 0; i < dst->num_planes; i++)
> + vc4_fb_sand_tiled_convert_plane(dst, dst_buf, src, src_buf,
> + column_width_bytes,
> + column_height, i);
> +
> + igt_fb_unmap_buffer(src, src_buf);
> + igt_fb_unmap_buffer(dst, dst_buf);
> +
> + return fb_id;
> +}
> +
> +size_t vc4_sand_tiled_offset(size_t column_width, size_t column_size,
> size_t x,
> + size_t y, size_t bpp)
> +{
> + size_t offset = 0;
> + size_t cols_x;
> + size_t pix_x;
> +
> + /* Offset to the beginning of the relevant column. */
> + cols_x = x / column_width;
> + offset += cols_x * column_size;
> +
> + /* Offset to the relevant pixel. */
> + pix_x = x % column_width;
> + offset += (column_width * y + pix_x) * bpp / 8;
> +
> + return offset;
> +}
> diff --git a/lib/igt_vc4.h b/lib/igt_vc4.h
> index ee7af737ade9..9118ae193f60 100644
> --- a/lib/igt_vc4.h
> +++ b/lib/igt_vc4.h
> @@ -45,5 +45,10 @@ uint64_t igt_vc4_get_tiling(int fd, uint32_t handle);
> unsigned int igt_vc4_fb_t_tiled_convert(struct igt_fb *dst, struct igt_fb
> *src);
> size_t igt_vc4_t_tiled_offset(size_t stride, size_t height, size_t bpp,
> size_t x, size_t y);
> +unsigned int vc4_fb_sand_tiled_convert(struct igt_fb *dst, struct igt_fb
> *src,
> + size_t column_width_bytes,
> + size_t column_height);
> +size_t vc4_sand_tiled_offset(size_t column_width, size_t column_size,
> size_t x,
> + size_t y, size_t bpp);
>
> #endif /* IGT_VC4_H */
--
Cheers,
Lyude Paul
More information about the igt-dev
mailing list