From: Juha-Pekka Heikkila <juhapekka.heikkila@gmail.com>
To: imre.deak@intel.com
Cc: igt-dev@lists.freedesktop.org
Subject: Re: [igt-dev] [PATCH i-g-t 10/10] tests/kms_ccs: Add option to check the CCS planes
Date: Mon, 30 Dec 2019 15:34:08 +0200 [thread overview]
Message-ID: <56343d56-f300-7313-3856-c46169266e01@gmail.com> (raw)
In-Reply-To: <20191230131220.GB27309@ideak-desk.fi.intel.com>
On 30.12.2019 15.12, Imre Deak wrote:
> On Mon, Dec 30, 2019 at 02:47:04PM +0200, Juha-Pekka Heikkila wrote:
>> Small nag on this patch number 10 but generally patches 6..10 are
>>
>> Reviewed-by: Juha-Pekka Heikkila <juhapekka.heikkila@gmail.com>
>>
>>
>> On 30.12.2019 5.40, Imre Deak wrote:
>>> Add an option to check whether the framebuffer content was really
>>> compressed.
>>>
>>> Cc: Mika Kahola <mika.kahola@intel.com>
>>> Signed-off-by: Imre Deak <imre.deak@intel.com>
>>> ---
>>> lib/igt_fb.c | 15 ++++++++++++
>>> lib/igt_fb.h | 4 ++++
>>> tests/kms_ccs.c | 62 ++++++++++++++++++++++++++++++++++++++++++++++++-
>>> 3 files changed, 80 insertions(+), 1 deletion(-)
>>>
>>> diff --git a/lib/igt_fb.c b/lib/igt_fb.c
>>> index e6a3ff07..c81b9de8 100644
>>> --- a/lib/igt_fb.c
>>> +++ b/lib/igt_fb.c
>>> @@ -502,6 +502,11 @@ static bool is_ccs_plane(const struct igt_fb *fb, int plane)
>>> return plane >= fb->num_planes / 2;
>>> }
>>> +bool igt_fb_is_ccs_plane(const struct igt_fb *fb, int plane)
>>> +{
>>> + return is_ccs_plane(fb, plane);
>>> +}
>>> +
>>> static bool is_gen12_ccs_plane(const struct igt_fb *fb, int plane)
>>> {
>>> return is_gen12_ccs_modifier(fb->modifier) && is_ccs_plane(fb, plane);
>>> @@ -513,6 +518,11 @@ static bool is_gen12_ccs_cc_plane(const struct igt_fb *fb, int plane)
>>> plane == 2;
>>> }
>>> +bool igt_fb_is_gen12_ccs_cc_plane(const struct igt_fb *fb, int plane)
>>> +{
>>> + return is_gen12_ccs_cc_plane(fb, plane);
>>> +}
>>> +
>>> static int ccs_to_main_plane(const struct igt_fb *fb, int plane)
>>> {
>>> if (is_gen12_ccs_cc_plane(fb, plane))
>>> @@ -521,6 +531,11 @@ static int ccs_to_main_plane(const struct igt_fb *fb, int plane)
>>> return plane - fb->num_planes / 2;
>>> }
>>> +int igt_fb_ccs_to_main_plane(const struct igt_fb *fb, int plane)
>>> +{
>>> + return ccs_to_main_plane(fb, plane);
>>> +}
>>> +
>>> static unsigned fb_plane_width(const struct igt_fb *fb, int plane)
>>> {
>>> const struct format_desc_struct *format = lookup_drm_format(fb->drm_format);
>>> diff --git a/lib/igt_fb.h b/lib/igt_fb.h
>>> index 69132b41..5ed9e35a 100644
>>> --- a/lib/igt_fb.h
>>> +++ b/lib/igt_fb.h
>>> @@ -170,6 +170,10 @@ void igt_fb_calc_crc(struct igt_fb *fb, igt_crc_t *crc);
>>> uint64_t igt_fb_mod_to_tiling(uint64_t modifier);
>>> uint64_t igt_fb_tiling_to_mod(uint64_t tiling);
>>> +bool igt_fb_is_ccs_plane(const struct igt_fb *fb, int plane);
>>> +bool igt_fb_is_gen12_ccs_cc_plane(const struct igt_fb *fb, int plane);
>>> +int igt_fb_ccs_to_main_plane(const struct igt_fb *fb, int ccs_plane);
>>> +
>>> /* cairo-based painting */
>>> cairo_surface_t *igt_get_cairo_surface(int fd, struct igt_fb *fb);
>>> cairo_surface_t *igt_cairo_image_surface_create_from_png(const char *filename);
>>> diff --git a/tests/kms_ccs.c b/tests/kms_ccs.c
>>> index 9e5bb559..34fb0138 100644
>>> --- a/tests/kms_ccs.c
>>> +++ b/tests/kms_ccs.c
>>> @@ -89,6 +89,8 @@ static const uint64_t ccs_modifiers[] = {
>>> LOCAL_I915_FORMAT_MOD_Y_TILED_GEN12_MC_CCS,
>>> };
>>> +static bool check_ccs_planes;
>>> +
>>> /*
>>> * Limit maximum used sprite plane width so this test will not mistakenly
>>> * fail on hardware limitations which are not interesting to this test.
>>> @@ -115,6 +117,44 @@ static void addfb_init(struct igt_fb *fb, struct drm_mode_fb_cmd2 *f)
>>> }
>>> }
>>> +static void check_ccs_plane(int drm_fd, igt_fb_t *fb, int plane)
>>> +{
>>> + void *map;
>>> + void *ccs_p;
>>> + size_t ccs_size;
>>> + int i;
>>> +
>>> + ccs_size = fb->strides[plane] * fb->plane_height[plane];
>>> + igt_assert(ccs_size);
>>> +
>>> + gem_set_domain(drm_fd, fb->gem_handle, I915_GEM_DOMAIN_CPU, 0);
>>> +
>>> + map = gem_mmap__cpu(drm_fd, fb->gem_handle, 0, fb->size, PROT_READ);
>>> +
>>> + ccs_size = fb->strides[plane] * fb->plane_height[plane];
>>> + ccs_p = map + fb->offsets[plane];
>>> + for (i = 0; i < ccs_size; i += sizeof(uint32_t))
>>> + if (*(uint32_t *)(ccs_p + i))
>>> + break;
>>
>> This check for uint32_t zeros myself I'd write more clear what is
>> happening..
>> maybe even with comment why there's wish it's not all zeros since
>> those fbs are coming from elsewhere. But that's just opinion.
>
> How about the following comment in front of the function?:
> """
> The CCS planes of compressed framebuffers have non-zero bytes if the
> engine compressed effectively the framebuffer. The actual encoding of
> these bytes is not specified, but we know that seeing an all-zero CCS
> plane means that the engine left the FB uncompressed, which is not what
> we expect in the test. Look for the first non-zero byte in the given CCS
> plane to get a minimal assurance that compression took place.
> """
Sound good to me. I don't know how CCS plane content should look like, I
only saw there was assumption it's not all zeros on passed in fb data in
this test.
>
>>
>>> +
>>> + munmap(map, fb->size);
>>> +
>>> + igt_assert_f(i < ccs_size,
>>> + "CCS plane %d (for main plane %d) lacks compression meta-data\n",
>>> + plane, igt_fb_ccs_to_main_plane(fb, plane));
>>> +}
>>> +
>>> +static void check_all_ccs_planes(int drm_fd, igt_fb_t *fb)
>>> +{
>>> + int i;
>>> +
>>> + for (i = 0; i < fb->num_planes; i++) {
>>> + if (igt_fb_is_ccs_plane(fb, i) &&
>>> + !igt_fb_is_gen12_ccs_cc_plane(fb, i))
>>> + check_ccs_plane(drm_fd, fb, i);
>>> + }
>>> +}
>>> +
>>> static void generate_fb(data_t *data, struct igt_fb *fb,
>>> int width, int height,
>>> enum test_fb_flags fb_flags)
>>> @@ -198,6 +238,9 @@ static void generate_fb(data_t *data, struct igt_fb *fb,
>>> } else
>>> igt_assert_eq(ret, 0);
>>> + if (check_ccs_planes)
>>> + check_all_ccs_planes(data->drm_fd, fb);
>>> +
>>> fb->fb_id = f.fb_id;
>>> }
>>> @@ -376,7 +419,24 @@ static void test_output(data_t *data)
>>> static data_t data;
>>> -igt_main
>>> +static int opt_handler(int opt, int opt_index, void *opt_data)
>>> +{
>>> + switch (opt) {
>>> + case 'c':
>>> + check_ccs_planes = true;
>>> + break;
>>> + default:
>>> + return IGT_OPT_HANDLER_ERROR;
>>> + }
>>> +
>>> + return IGT_OPT_HANDLER_SUCCESS;
>>> +}
>>> +
>>> +static const char *help_str =
>>> +" -c\tCheck the presence of compression meta-data\n"
>>> +;
>>> +
>>> +igt_main_args("c", NULL, help_str, opt_handler, NULL)
>>> {
>>> enum pipe pipe;
>>>
>>
_______________________________________________
igt-dev mailing list
igt-dev@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/igt-dev
next prev parent reply other threads:[~2019-12-30 13:34 UTC|newest]
Thread overview: 33+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-12-30 3:40 [igt-dev] [PATCH i-g-t 00/10] lib: Add support and coverage for MC YUV formats Imre Deak
2019-12-30 3:40 ` [igt-dev] [PATCH i-g-t 01/10] lib/igt_buf: Use compression type consistently Imre Deak
2019-12-30 12:00 ` Kahola, Mika
2019-12-30 3:40 ` [igt-dev] [PATCH i-g-t 02/10] lib/igt_buf: Extend igt_buf to include two CCS surfaces Imre Deak
2019-12-30 12:02 ` Kahola, Mika
2019-12-30 3:40 ` [igt-dev] [PATCH i-g-t 03/10] lib/igt_buf: Extend igt_buf to include two color surfaces Imre Deak
2019-12-30 12:06 ` Kahola, Mika
2019-12-30 12:58 ` Imre Deak
2019-12-30 17:58 ` [igt-dev] [PATCH i-g-t v2 " Imre Deak
2019-12-31 8:40 ` Kahola, Mika
2019-12-30 3:40 ` [igt-dev] [PATCH i-g-t 04/10] lib: Add engine copy support for YUV formats Imre Deak
2019-12-30 13:23 ` Kahola, Mika
2019-12-30 3:40 ` [igt-dev] [PATCH i-g-t 05/10] Revert "tests/kms_plane: Disable GEN12 media compression YUV tests" Imre Deak
2019-12-30 13:24 ` Kahola, Mika
2019-12-30 3:40 ` [igt-dev] [PATCH i-g-t 06/10] tests/kms_ccs: Add support for testing multiple formats Imre Deak
2019-12-30 3:40 ` [igt-dev] [PATCH i-g-t 07/10] tests/kms_ccs: Add GEN12 CCS media compression format modifier Imre Deak
2019-12-30 3:40 ` [igt-dev] [PATCH i-g-t 08/10] tests/kms_ccs: Work around CRC mismatch when mixing SDR/HDR planes Imre Deak
2019-12-30 3:40 ` [igt-dev] [PATCH i-g-t 09/10] tests/kms_ccs: Test YUV formats too Imre Deak
2019-12-30 3:40 ` [igt-dev] [PATCH i-g-t 10/10] tests/kms_ccs: Add option to check the CCS planes Imre Deak
2019-12-30 12:47 ` Juha-Pekka Heikkila
2019-12-30 13:12 ` Imre Deak
2019-12-30 13:34 ` Juha-Pekka Heikkila [this message]
2019-12-30 17:58 ` [igt-dev] [PATCH i-g-t v2 " Imre Deak
2019-12-30 4:12 ` [igt-dev] ✗ Fi.CI.BAT: failure for lib: Add support and coverage for MC YUV formats Patchwork
2019-12-30 9:00 ` Imre Deak
2019-12-30 9:22 ` Vudum, Lakshminarayana
2019-12-30 9:18 ` [igt-dev] ✓ Fi.CI.BAT: success " Patchwork
2019-12-30 12:50 ` [igt-dev] ✗ Fi.CI.IGT: failure " Patchwork
2019-12-30 13:23 ` Imre Deak
2019-12-30 15:53 ` [igt-dev] ✓ Fi.CI.IGT: success " Patchwork
2019-12-30 19:02 ` [igt-dev] ✓ Fi.CI.BAT: success for lib: Add support and coverage for MC YUV formats (rev3) Patchwork
2019-12-31 8:45 ` [igt-dev] ✓ Fi.CI.IGT: " Patchwork
2019-12-31 12:49 ` Imre Deak
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=56343d56-f300-7313-3856-c46169266e01@gmail.com \
--to=juhapekka.heikkila@gmail.com \
--cc=igt-dev@lists.freedesktop.org \
--cc=imre.deak@intel.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox