Igt-dev Archive on lore.kernel.org
 help / color / mirror / Atom feed
From: Harry Wentland <harry.wentland@amd.com>
To: Maxime Ripard <maxime@cerno.tech>
Cc: igt-dev@lists.freedesktop.org, brian.starkey@arm.com
Subject: Re: [igt-dev] [PATCH 3/3] tests/kms_writeback: support DRM_FORMAT_XRGB2101010 for writeback
Date: Tue, 22 Aug 2023 10:51:39 -0400	[thread overview]
Message-ID: <c18ff50d-d06e-4037-9adc-2a89507f76f1@amd.com> (raw)
In-Reply-To: <z63pwygl73s6tdiusqx7vxu7ara6eung3l6bkaa4ffy4twwau2@iidh6mhtqq7c>



On 2023-08-22 09:26, Maxime Ripard wrote:
> On Thu, Aug 17, 2023 at 10:15:04AM -0400, Harry Wentland wrote:
>>
>>
>> On 2023-08-17 03:50, Maxime Ripard wrote:
>>> On Thu, Aug 17, 2023 at 01:09:44AM -0600, Alex Hung wrote:
>>>>
>>>>
>>>> On 2023-08-17 00:32, Maxime Ripard wrote:
>>>>> Hi,
>>>>>
>>>>> On Wed, Aug 16, 2023 at 02:53:16PM -0600, Alex Hung wrote:
>>>>>> Allow kms_writeback to run with DRM_FORMAT_XRGB8888 if supported
>>>>>> or to try DRM_FORMAT_XRGB2101010 if DRM_FORMAT_XRGB8888 is not
>>>>>> available.
>>>>>
>>>>> XRGB8888 is always supposed to be available, if it's not, it's a driver
>>>>> issue. Which means that XRGB2101010 will never actually be tested.
>>>>
>>>> It is up to a device driver to support specific format(s), not necessary an
>>>> issue. At least for now amdgpu won't support XRGB8888 but XRGB2101010.
>>>
>>> I guess it's unrelated to that patch in particular, but it's not ok from
>>> a KMS standpoint. It was poorly documented before, but see
>>>
>>> https://elixir.bootlin.com/linux/latest/source/drivers/gpu/drm/drm_fb_helper.c#L430
>>> https://lore.kernel.org/dri-devel/20230807140317.26146-2-jfalempe@redhat.com/
>>>
>>
>> Our HW writeback can't do 8888. This would be a silly reason to not be
>> able to use it for testing purposes.
> 
> Ah, right, sorry for the brainfart.
> 
>> I don't even understand what "SW Color Conversion" means here. Is it
>> expected that drivers use CPU code in kernel to walk the buffer and
>> "color convert" from XRGB8888 to whatever the HW supports (and the
>> inverse for the writeback buffer)? That seems a bit ridiculous.
> 
> That's exactly what that means. We have a bunch of helpers to do that
> already, used for example by simpledrm if it's backed by a different
> format. See:
> https://elixir.bootlin.com/linux/latest/source/drivers/gpu/drm/drm_format_helper.c#L914
> 

Huh, I wasn't aware of that. Thanks for pointing that out.

In our case the driver supports XRGB8888 on a plane's framebuffer. The only
limitation is on the writeback connector's fb. But I guess the way the kernel
doc talks about this it would apply to either.

What do you think would the right approach? Implement a
drm_fb_xrgb2101010_to_xrgb8888 variant in drm_fb_blit and call that on
the output buffer?

I got to say I'm not at all a fan of forcing compatibility with XRGB8888 if
this means a CPU blit. I feel this is misleading DRM clients, giving them
the impression XRGB8888 is supported by HW even though it requires a (terribly
slow and costly) CPU blit.

Harry

> Maxime

  reply	other threads:[~2023-08-22 14:51 UTC|newest]

Thread overview: 15+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-08-16 20:53 [igt-dev] [PATCH 1/3] lib/igt_fb: use the entire 32 bit for fnv1a_crc Alex Hung
2023-08-16 20:53 ` [igt-dev] [PATCH 2/3] lib/igt_fb: add 10 bits (XRGB2101010) supports in fnv1a_crc Alex Hung
2023-08-16 20:53 ` [igt-dev] [PATCH 3/3] tests/kms_writeback: support DRM_FORMAT_XRGB2101010 for writeback Alex Hung
2023-08-17  6:32   ` Maxime Ripard
2023-08-17  7:09     ` Alex Hung
2023-08-17  7:50       ` Maxime Ripard
2023-08-17 14:15         ` Harry Wentland
2023-08-17 16:22           ` Alex Hung
2023-08-22 14:14             ` Maxime Ripard
2023-08-22 14:34               ` Harry Wentland
2023-08-22 13:26           ` Maxime Ripard
2023-08-22 14:51             ` Harry Wentland [this message]
2023-08-16 23:41 ` [igt-dev] ○ CI.xeBAT: info for series starting with [1/3] lib/igt_fb: use the entire 32 bit for fnv1a_crc Patchwork
2023-08-16 23:47 ` [igt-dev] ✓ Fi.CI.BAT: success " Patchwork
2023-08-17 11:13 ` [igt-dev] ✓ Fi.CI.IGT: " Patchwork

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=c18ff50d-d06e-4037-9adc-2a89507f76f1@amd.com \
    --to=harry.wentland@amd.com \
    --cc=brian.starkey@arm.com \
    --cc=igt-dev@lists.freedesktop.org \
    --cc=maxime@cerno.tech \
    /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