Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp5188937imm; Tue, 26 Jun 2018 07:19:32 -0700 (PDT) X-Google-Smtp-Source: ADUXVKJ8Go6l4uioJFMOv1nia4S044ol1Ta5AtGYfc9EowPTUAhdrP6y8UDvX493k+eBOzX2oX/3 X-Received: by 2002:a65:538e:: with SMTP id x14-v6mr1543944pgq.388.1530022772730; Tue, 26 Jun 2018 07:19:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530022772; cv=none; d=google.com; s=arc-20160816; b=tjqJYAo+1L3vYb+2ImDE2tSRqtaD+zIHlisdVeguz7Q9Waq8HKrPblXQFMM3PUUc0p Tbp92UZ9wXhyBAKNrn78bgQs0Hb3QhQ26NLgYT2XaYpgZdmDmF8alCP8BJNKAjOkZ67z mxrEeoSxOR65DyZ/RQIFH48Gl0ILS6B0eTQi79aFjceWlWFPEl8Q2xJR+brXwhGBViJ4 Njz9n4ST6dEYFB+PNaZwk6zvdZLdA4UBIC+rLdct9/Bs1RHK5Uxlmcuy2WMlwgVwF35f yJVTFk9Y+IPEdFHe1eUCEgG+/rkbBY6dJcOC4yRamQ7tPX53BGeISEQNCOx8MXj5kHtu QbjQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-transfer-encoding:content-disposition:mime-version :references:message-id:subject:cc:to:from:date :arc-authentication-results; bh=MoGt/id52zbH0On8Dd09sPYrQ6LY0VkFeC//ZWeIfgg=; b=OjAF7YpDtbnh6bt1qN7MRQzDPp4EOstItKaJXIj9VpEnQKlOFoCccLG6Febs4xpJ47 hZNDTovqB2XRCAxmYd7JSU0/WBjrsyHCSIXYMc4n/LvbcnG1DVl5lFwW5p2taqH2xIBN ma2JtkmMoOmeDxGc2Djc6Z/e0dOYfCRJX8KqGm9Erhj0Kk2rNmES0vs+G2nj7VYKWf5j nl+oPLHHkg7srIrXwofSwFBPx3RUj06SAJnlfFz+3E/HPP7PjzHGzVNdsamT6aIyAyYv +ioV8eGQdZpkUgUX+9HjEyl1Xoyu1MOBmy3VBZsrb+FQtl8mdbkJAt0apUV/aEjfz8Dh YoHQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f97-v6si1755947plb.291.2018.06.26.07.19.18; Tue, 26 Jun 2018 07:19:32 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S935707AbeFZNWD (ORCPT + 99 others); Tue, 26 Jun 2018 09:22:03 -0400 Received: from foss.arm.com ([217.140.101.70]:45710 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S934072AbeFZNWB (ORCPT ); Tue, 26 Jun 2018 09:22:01 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 0D24080D; Tue, 26 Jun 2018 06:22:01 -0700 (PDT) Received: from e110455-lin.cambridge.arm.com (usa-sjc-imap-foss1.foss.arm.com [10.72.51.249]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id A61C03F5AF; Tue, 26 Jun 2018 06:22:00 -0700 (PDT) Received: by e110455-lin.cambridge.arm.com (Postfix, from userid 1000) id F285868030C; Tue, 26 Jun 2018 14:21:58 +0100 (BST) Date: Tue, 26 Jun 2018 14:21:58 +0100 From: Liviu Dudau To: Ayan Kumar Halder Cc: liviu.dudau@arm.com, brian.starkey@arm.com, malidp@foss.arm.com, airlied@linux.ie, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, nd@arm.com Subject: Re: [RFC PATCH 4/4] drm/arm/malidp: Added support for AFBC modifiers for all layers except DE_SMART Message-ID: <20180626132158.GB14974@e110455-lin.cambridge.arm.com> References: <1529070694-21088-1-git-send-email-ayan.halder@arm.com> <1529070694-21088-5-git-send-email-ayan.halder@arm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <1529070694-21088-5-git-send-email-ayan.halder@arm.com> User-Agent: Mutt/1.10.0 (2018-05-17) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Jun 15, 2018 at 02:51:34PM +0100, Ayan Kumar Halder wrote: > On planes which support AFBC, expose an AFBC modifier for use with BGR888. > > Signed-off-by: Ayan Kumar halder > Reviewed-by: Brian Starkey > > Change-Id: I4739ff55c0f6d5715b268cb3947ed133a9ee7c2e Please remove the Change-Id > --- > drivers/gpu/drm/arm/malidp_drv.c | 1 + > drivers/gpu/drm/arm/malidp_planes.c | 46 +++++++++++++++++++++++++++++++++++-- > 2 files changed, 45 insertions(+), 2 deletions(-) > > diff --git a/drivers/gpu/drm/arm/malidp_drv.c b/drivers/gpu/drm/arm/malidp_drv.c > index 7b6a848..7bcd679 100644 > --- a/drivers/gpu/drm/arm/malidp_drv.c > +++ b/drivers/gpu/drm/arm/malidp_drv.c > @@ -392,6 +392,7 @@ static int malidp_init(struct drm_device *drm) > drm->mode_config.max_height = hwdev->max_line_size; > drm->mode_config.funcs = &malidp_mode_config_funcs; > drm->mode_config.helper_private = &malidp_mode_config_helpers; > + drm->mode_config.allow_fb_modifiers = true; > > ret = malidp_crtc_init(drm); > if (ret) { > diff --git a/drivers/gpu/drm/arm/malidp_planes.c b/drivers/gpu/drm/arm/malidp_planes.c > index 3950504..55c9a1f6 100644 > --- a/drivers/gpu/drm/arm/malidp_planes.c > +++ b/drivers/gpu/drm/arm/malidp_planes.c > @@ -124,6 +124,35 @@ static void malidp_plane_atomic_print_state(struct drm_printer *p, > drm_printf(p, "\tn_planes=%u\n", ms->n_planes); > } > > +static bool malidp_format_mod_supported(struct drm_plane *plane, > + u32 format, u64 modifier) > +{ > + if (WARN_ON(modifier == DRM_FORMAT_MOD_INVALID)) > + return false; > + > + /* All the pixel formats are supported without any modifier */ > + if (modifier == DRM_FORMAT_MOD_LINEAR) > + return true; > + > + if ((modifier >> 56) != DRM_FORMAT_MOD_VENDOR_ARM) > + return false; > + > + if (modifier & > + ~DRM_FORMAT_MOD_ARM_AFBC(AFBC_MOD_VALID_BITS)) { > + DRM_ERROR("Unsupported modifiers\n"); I don't think we should polute the kernel log buffers with this. Maybe a DRM_DEBUG() if you really want to get some notification? With those changes added: Reviewed-by: Liviu Dudau Best regards, Liviu > + return false; > + } > + > + switch (modifier) { > + case DRM_FORMAT_MOD_ARM_AFBC(AFBC_FORMAT_MOD_BLOCK_SIZE_16x16 | > + AFBC_FORMAT_MOD_YTR | > + AFBC_FORMAT_MOD_SPARSE): > + if (format == DRM_FORMAT_BGR888) > + return true; > + } > + return false; > +} > + > static const struct drm_plane_funcs malidp_de_plane_funcs = { > .update_plane = drm_atomic_helper_update_plane, > .disable_plane = drm_atomic_helper_disable_plane, > @@ -132,6 +161,7 @@ static const struct drm_plane_funcs malidp_de_plane_funcs = { > .atomic_duplicate_state = malidp_duplicate_plane_state, > .atomic_destroy_state = malidp_destroy_plane_state, > .atomic_print_state = malidp_plane_atomic_print_state, > + .format_mod_supported = malidp_format_mod_supported, > }; > > static int malidp_se_check_scaling(struct malidp_plane *mp, > @@ -524,6 +554,13 @@ int malidp_de_planes_init(struct drm_device *drm) > u32 *formats; > int ret, i, j, n; > > + static const u64 modifiers[] = { > + DRM_FORMAT_MOD_ARM_AFBC(AFBC_FORMAT_MOD_BLOCK_SIZE_16x16 | > + AFBC_FORMAT_MOD_YTR | AFBC_FORMAT_MOD_SPARSE), > + DRM_FORMAT_MOD_LINEAR, > + DRM_FORMAT_MOD_INVALID > + }; > + > formats = kcalloc(map->n_pixel_formats, sizeof(*formats), GFP_KERNEL); > if (!formats) { > ret = -ENOMEM; > @@ -547,9 +584,14 @@ int malidp_de_planes_init(struct drm_device *drm) > > plane_type = (i == 0) ? DRM_PLANE_TYPE_PRIMARY : > DRM_PLANE_TYPE_OVERLAY; > + > + /* > + * All the layers except smart layer supports AFBC modifiers. > + */ > ret = drm_universal_plane_init(drm, &plane->base, crtcs, > - &malidp_de_plane_funcs, formats, > - n, NULL, plane_type, NULL); > + &malidp_de_plane_funcs, formats, n, > + (id == DE_SMART) ? NULL : modifiers, plane_type, NULL); > + > if (ret < 0) > goto cleanup; > > -- > 2.7.4 > -- ==================== | I would like to | | fix the world, | | but they're not | | giving me the | \ source code! / --------------- ¯\_(ツ)_/¯