[PATCH v2 7/8] drm/fb-helper: Add support for DRM_FORMAT_R1

Thomas Zimmermann tzimmermann at suse.de
Thu Aug 31 08:57:28 UTC 2023


Hi

Am 24.08.23 um 17:08 schrieb Geert Uytterhoeven:
> Add support for the monochrome light-on-dark buffer format (R1) to the
> fb helper, so this format can be used for fbdev emulation and for the
> text console.  This avoids the overhead of using XR24 and the associated
> conversions on display hardware that supports only a simple monochrome
> format.
> 
> R1 is very similar to C1 (monochrome indexed color), and shares the same
> depth and bpp.  As drm_mode_legacy_fb_format() returns a format based on
> only depth and bpp, it cannot distinguish between R1 and C1.  Hence

Could we rather add another parameter to drm_mode_legacy_fb_format(); 
say 'bool indexed'. If set to true, it prefers _Cx formats, otherwise _Rx.

The parameter would be 'true' for most calls; except in 
drm_fb_helper_find_format(). There, we can go through the array of given 
formats and check if there's one that has is_color_indexed set. If so, 
we specify true, if not we specify false.

Best regards
Thomas

> drm_fb_helper_find_format() is modified to try to fall back to R1 if C1
> is not supported.
> 
> Signed-off-by: Geert Uytterhoeven <geert at linux-m68k.org>
> Reviewed-by: Javier Martinez Canillas <javierm at redhat.com>
> Tested-by: Javier Martinez Canillas <javierm at redhat.com>
> ---
> v2:
>    - Add Reviewed-by, Tested-by.
> ---
>   drivers/gpu/drm/drm_fb_helper.c | 41 ++++++++++++++++++++++++---------
>   1 file changed, 30 insertions(+), 11 deletions(-)
> 
> diff --git a/drivers/gpu/drm/drm_fb_helper.c b/drivers/gpu/drm/drm_fb_helper.c
> index 4dc28fdcc1e0a6a4..71baf8597516e9fd 100644
> --- a/drivers/gpu/drm/drm_fb_helper.c
> +++ b/drivers/gpu/drm/drm_fb_helper.c
> @@ -1130,7 +1130,7 @@ static void drm_fb_helper_fill_pixel_fmt(struct fb_var_screeninfo *var,
>   {
>   	u8 depth = format->depth;
>   
> -	if (format->is_color_indexed) {
> +	if (format->format == DRM_FORMAT_R1 || format->is_color_indexed) {
>   		var->red.offset = 0;
>   		var->green.offset = 0;
>   		var->blue.offset = 0;
> @@ -1236,6 +1236,7 @@ int drm_fb_helper_check_var(struct fb_var_screeninfo *var,
>   	case DRM_FORMAT_C1:
>   	case DRM_FORMAT_C2:
>   	case DRM_FORMAT_C4:
> +	case DRM_FORMAT_R1:
>   		/* supported format with sub-byte pixels */
>   		break;
>   
> @@ -1439,12 +1440,24 @@ int drm_fb_helper_pan_display(struct fb_var_screeninfo *var,
>   }
>   EXPORT_SYMBOL(drm_fb_helper_pan_display);
>   
> +static bool is_supported_format(uint32_t format, const uint32_t *formats,
> +				size_t format_count)
> +{
> +	size_t i;
> +
> +	for (i = 0; i < format_count; ++i) {
> +		if (formats[i] == format)
> +			return true;
> +	}
> +
> +	return false;
> +}
> +
>   static uint32_t drm_fb_helper_find_format(struct drm_fb_helper *fb_helper, const uint32_t *formats,
>   					  size_t format_count, uint32_t bpp, uint32_t depth)
>   {
>   	struct drm_device *dev = fb_helper->dev;
>   	uint32_t format;
> -	size_t i;
>   
>   	/*
>   	 * Do not consider YUV or other complicated formats
> @@ -1457,10 +1470,12 @@ static uint32_t drm_fb_helper_find_format(struct drm_fb_helper *fb_helper, const
>   	if (!format)
>   		goto err;
>   
> -	for (i = 0; i < format_count; ++i) {
> -		if (formats[i] == format)
> -			return format;
> -	}
> +	if (is_supported_format(format, formats, format_count))
> +		return format;
> +
> +	if (format == DRM_FORMAT_C1 &&
> +	    is_supported_format(DRM_FORMAT_R1, formats, format_count))
> +		return DRM_FORMAT_R1;
>   
>   err:
>   	/* We found nothing. */
> @@ -1680,11 +1695,15 @@ static int drm_fb_helper_single_fb_probe(struct drm_fb_helper *fb_helper)
>   }
>   
>   static void drm_fb_helper_fill_fix(struct fb_info *info, uint32_t pitch,
> -				   bool is_color_indexed)
> +				   const struct drm_format_info *format)
>   {
>   	info->fix.type = FB_TYPE_PACKED_PIXELS;
> -	info->fix.visual = is_color_indexed ? FB_VISUAL_PSEUDOCOLOR
> -					    : FB_VISUAL_TRUECOLOR;
> +	if (format->format == DRM_FORMAT_R1)
> +		info->fix.visual = FB_VISUAL_MONO10;
> +	else if (format->is_color_indexed)
> +		info->fix.visual = FB_VISUAL_PSEUDOCOLOR;
> +	else
> +		info->fix.visual = FB_VISUAL_TRUECOLOR;
>   	info->fix.mmio_start = 0;
>   	info->fix.mmio_len = 0;
>   	info->fix.type_aux = 0;
> @@ -1707,6 +1726,7 @@ static void drm_fb_helper_fill_var(struct fb_info *info,
>   	case DRM_FORMAT_C1:
>   	case DRM_FORMAT_C2:
>   	case DRM_FORMAT_C4:
> +	case DRM_FORMAT_R1:
>   		/* supported format with sub-byte pixels */
>   		break;
>   
> @@ -1747,8 +1767,7 @@ void drm_fb_helper_fill_info(struct fb_info *info,
>   {
>   	struct drm_framebuffer *fb = fb_helper->fb;
>   
> -	drm_fb_helper_fill_fix(info, fb->pitches[0],
> -			       fb->format->is_color_indexed);
> +	drm_fb_helper_fill_fix(info, fb->pitches[0], fb->format);
>   	drm_fb_helper_fill_var(info, fb_helper,
>   			       sizes->fb_width, sizes->fb_height);
>   

-- 
Thomas Zimmermann
Graphics Driver Developer
SUSE Software Solutions Germany GmbH
Frankenstrasse 146, 90461 Nuernberg, Germany
GF: Ivo Totev, Andrew Myers, Andrew McDonald, Boudien Moerman
HRB 36809 (AG Nuernberg)
-------------- next part --------------
A non-text attachment was scrubbed...
Name: OpenPGP_signature
Type: application/pgp-signature
Size: 840 bytes
Desc: OpenPGP digital signature
URL: <https://lists.freedesktop.org/archives/dri-devel/attachments/20230831/5760ced5/attachment-0001.sig>


More information about the dri-devel mailing list