[Intel-gfx] [PATCH i-g-t 2/2] kms_plane_scaling: Find the image regardless how the test is run
Thomas Wood
thomas.wood at intel.com
Fri May 1 08:54:00 PDT 2015
On 30 April 2015 at 12:27, Tvrtko Ursulin
<tvrtko.ursulin at linux.intel.com> wrote:
> From: Tvrtko Ursulin <tvrtko.ursulin at intel.com>
>
> As it stands running the test like "sudo tests/kms_plane_scaling"
> does not work.
>
> Fix it by using the same method igt_paint_image uses.
Adding a new function to igt_kms would avoid duplicating
stdio_read_func and may be useful to other tests in the future.
There is also an unrelated whitespace change to remove at the end of the patch.
>
> Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin at intel.com>
> Cc: chandra konduru <chandra.konduru at intel.com>
> ---
> tests/kms_plane_scaling.c | 17 +++++++++++++++--
> 1 file changed, 15 insertions(+), 2 deletions(-)
>
> diff --git a/tests/kms_plane_scaling.c b/tests/kms_plane_scaling.c
> index 00db5cb..8ff154f 100644
> --- a/tests/kms_plane_scaling.c
> +++ b/tests/kms_plane_scaling.c
> @@ -202,6 +202,15 @@ static void iterate_plane_scaling(data_t *d, drmModeModeInfo *mode)
> }
> }
>
> +static cairo_status_t
> +stdio_read_func(void *closure, unsigned char* data, unsigned int size)
> +{
> + if (fread(data, 1, size, (FILE*)closure) != size)
> + return CAIRO_STATUS_READ_ERROR;
> +
> + return CAIRO_STATUS_SUCCESS;
> +}
> +
> static void test_plane_scaling(data_t *d)
> {
> igt_display_t *display = &d->display;
> @@ -210,6 +219,7 @@ static void test_plane_scaling(data_t *d)
> enum pipe pipe;
> int valid_tests = 0;
> int primary_plane_scaling = 0; /* For now */
> + FILE* f;
>
> igt_require(d->display.has_universal_planes);
> igt_require(d->num_scalers);
> @@ -223,11 +233,15 @@ static void test_plane_scaling(data_t *d)
> mode = igt_output_get_mode(output);
>
> /* allocate fb2 with image size */
> - image = cairo_image_surface_create_from_png(FILE_NAME);
> +
> + f = igt_fopen_data(FILE_NAME);
> + image = cairo_image_surface_create_from_png_stream(
> + &stdio_read_func, f);
> igt_assert(cairo_surface_status(image) == CAIRO_STATUS_SUCCESS);
> d->image_w = cairo_image_surface_get_width(image);
> d->image_h = cairo_image_surface_get_height(image);
> cairo_surface_destroy(image);
> + fclose(f);
>
> d->fb_id2 = igt_create_fb(d->drm_fd,
> d->image_w, d->image_h,
> @@ -355,7 +369,6 @@ igt_simple_main
>
> igt_skip_on_simulation();
>
> -
> data.drm_fd = drm_open_any();
> igt_require_pipe_crc();
> igt_display_init(&data.display, data.drm_fd);
> --
> 2.3.5
>
> _______________________________________________
> Intel-gfx mailing list
> Intel-gfx at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/intel-gfx
More information about the Intel-gfx
mailing list