Message ID | 20231124100052.18599-2-shawn.sung@mediatek.com |
---|---|
State | New |
Headers |
Return-Path: <linux-kernel-owner@vger.kernel.org> Delivered-To: ouuuleilei@gmail.com Received: by 2002:a59:ce62:0:b0:403:3b70:6f57 with SMTP id o2csp1047785vqx; Fri, 24 Nov 2023 02:03:00 -0800 (PST) X-Google-Smtp-Source: AGHT+IE/kXekGbmnhc2MLrKZyW0ws+JYdhJkIhoV/qUc0XDOWHSlKY4lAQtkTOKDsF0HAXFSqT4W X-Received: by 2002:a05:6870:5591:b0:1f9:6dc6:4a4 with SMTP id qj17-20020a056870559100b001f96dc604a4mr2792499oac.28.1700820180045; Fri, 24 Nov 2023 02:03:00 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1700820180; cv=none; d=google.com; s=arc-20160816; b=HqE2OKKrb5WxK4w2Z3qRIvwqmwqkYf2SJjKRamCynGgvoKfVD59bxzoM3v41Dl/AnH prx4fjxyYsvqSxA94nVY9Cd1y9pxL6DdILjAmydzNeo5O2drzBFoDmLVWN1J2cVPgPTe UcwX7cUUR1N7qZikWxnpav22XRMwhYkWewbYod1FIIlFWAyaCNUy02U8FVVduYYlnVdI VYdHoFuk94Tn3iFrUSsA58RQXCev9soaTpvmSRXQOb5u93Wd52tyCJsZ8sVlwWrpCy/s nQYBRcQBlxQMK5+YePIhZmBByEkKriCsK1X/NV8R46Y1+JInDIINQUEvrzUXpp4LgBLp UUaA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=SU7L7WaD7sBigt9DbsfsMwQVKx3h/ibBHRUjvMnQfYg=; fh=R6yg+Y1Ss0Rvs9KVi8OkEW/Jv+KOV7+wNGtCGGXsMRE=; b=zLKaeAY4R9sXMzyFdfNKue5E8VMhnA/rDIjvghrtmcAVOZ8a6LHx7/+6XApLc/jXCw ASsCY+dYNckukVqhIZQwVn80awNQ6wuyfQ7vtpEfuD0naZpweHAiQeHGi1UIR+qLX6Xf NbWrp2WRNzdTeUMq32zMRE/Qb0UBrKAP7azUA5uNM/VEyCY9jOvpaUPvbgriuY4eH7B+ 54jP8+7Of5Nwm32jBH8B5zhvsduXYnDdNfKE7b08Twwl4QAbFmhaOX1I7PO9xIzVv7/8 JreF26rVDwGbL542jpE0cyWW6J1KRrro70I8+g1FgNr4yNqg2rFd5SOXPLAKARTZeqt9 k84g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mediatek.com header.s=dk header.b=AwP9qZvX; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:7 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=mediatek.com Received: from snail.vger.email (snail.vger.email. [2620:137:e000::3:7]) by mx.google.com with ESMTPS id l12-20020a05687014cc00b001f9575cb42bsi1157373oab.211.2023.11.24.02.02.59 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 24 Nov 2023 02:03:00 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:7 as permitted sender) client-ip=2620:137:e000::3:7; Authentication-Results: mx.google.com; dkim=pass header.i=@mediatek.com header.s=dk header.b=AwP9qZvX; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:7 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=mediatek.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by snail.vger.email (Postfix) with ESMTP id 1ADBD802FBB3; Fri, 24 Nov 2023 02:01:14 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at snail.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235257AbjKXKA7 (ORCPT <rfc822;ouuuleilei@gmail.com> + 99 others); Fri, 24 Nov 2023 05:00:59 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49252 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235234AbjKXKA4 (ORCPT <rfc822;linux-kernel@vger.kernel.org>); Fri, 24 Nov 2023 05:00:56 -0500 Received: from mailgw02.mediatek.com (unknown [210.61.82.184]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id DD5CED4E for <linux-kernel@vger.kernel.org>; Fri, 24 Nov 2023 02:01:01 -0800 (PST) X-UUID: 5b79a7e48ab011ee8051498923ad61e6-20231124 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=mediatek.com; s=dk; h=Content-Type:MIME-Version:References:In-Reply-To:Message-ID:Date:Subject:CC:To:From; bh=SU7L7WaD7sBigt9DbsfsMwQVKx3h/ibBHRUjvMnQfYg=; b=AwP9qZvX2pPhw8cUnWYeS3IJxtkgDvaGlO/At6XM+YGon0/CNqwaY/kscp511stCzzmaP/8SvICbdABS5UVgy84irX1N7S34H0R65h+Ipmq+SfCkPMrDnxrVkcw57T3EHaMwIirXkypJ4TypdvItXcIe69+zHy4n8Qioe/eFSTA=; X-CID-P-RULE: Release_Ham X-CID-O-INFO: VERSION:1.1.33,REQID:f575a636-b49d-4a3f-9899-2ebedf29c8a9,IP:0,U RL:0,TC:0,Content:-5,EDM:0,RT:0,SF:0,FILE:0,BULK:0,RULE:Release_Ham,ACTION :release,TS:-5 X-CID-META: VersionHash:364b77b,CLOUDID:a4d6e8fc-4a48-46e2-b946-12f04f20af8c,B ulkID:nil,BulkQuantity:0,Recheck:0,SF:102,TC:nil,Content:0,EDM:-3,IP:nil,U RL:0,File:nil,Bulk:nil,QS:nil,BEC:nil,COL:0,OSI:0,OSA:0,AV:0,LES:1,SPR:NO, DKR:0,DKP:0,BRR:0,BRE:0 X-CID-BVR: 0 X-CID-BAS: 0,_,0,_ X-CID-FACTOR: TF_CID_SPAM_SNR X-UUID: 5b79a7e48ab011ee8051498923ad61e6-20231124 Received: from mtkmbs14n2.mediatek.inc [(172.21.101.76)] by mailgw02.mediatek.com (envelope-from <shawn.sung@mediatek.com>) (Generic MTA with TLSv1.2 ECDHE-RSA-AES256-GCM-SHA384 256/256) with ESMTP id 194510323; Fri, 24 Nov 2023 18:00:54 +0800 Received: from mtkmbs13n2.mediatek.inc (172.21.101.108) by mtkmbs13n1.mediatek.inc (172.21.101.193) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1118.26; Fri, 24 Nov 2023 18:00:53 +0800 Received: from mtksdccf07.mediatek.inc (172.21.84.99) by mtkmbs13n2.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.2.1118.26 via Frontend Transport; Fri, 24 Nov 2023 18:00:53 +0800 From: Hsiao Chien Sung <shawn.sung@mediatek.com> To: Chun-Kuang Hu <chunkuang.hu@kernel.org>, AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com> CC: Philipp Zabel <p.zabel@pengutronix.de>, David Airlie <airlied@gmail.com>, Daniel Vetter <daniel@ffwll.ch>, Matthias Brugger <matthias.bgg@gmail.com>, Sean Paul <seanpaul@chromium.org>, CK Hu <ck.hu@mediatek.com>, <dri-devel@lists.freedesktop.org>, <linux-mediatek@lists.infradead.org>, <linux-arm-kernel@lists.infradead.org>, <linux-kernel@vger.kernel.org>, Hsiao Chien Sung <shawn.sung@mediatek.com> Subject: [PATCH v4 1/1] drm/mediatek: Fix errors when reporting rotation capability Date: Fri, 24 Nov 2023 18:00:52 +0800 Message-ID: <20231124100052.18599-2-shawn.sung@mediatek.com> X-Mailer: git-send-email 2.18.0 In-Reply-To: <20231124100052.18599-1-shawn.sung@mediatek.com> References: <20231124100052.18599-1-shawn.sung@mediatek.com> MIME-Version: 1.0 Content-Type: text/plain X-MTK: N X-Spam-Status: No, score=-1.3 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_BLOCKED, RCVD_IN_MSPIKE_H4,RCVD_IN_MSPIKE_WL,RDNS_NONE,SPF_HELO_PASS,SPF_PASS, T_SCC_BODY_TEXT_LINE,UNPARSEABLE_RELAY,URIBL_BLOCKED autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: <linux-kernel.vger.kernel.org> X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (snail.vger.email [0.0.0.0]); Fri, 24 Nov 2023 02:01:14 -0800 (PST) X-getmail-retrieved-from-mailbox: INBOX X-GMAIL-THRID: 1783439221114672827 X-GMAIL-MSGID: 1783439221114672827 |
Series |
Fix errors when reporting rotation capability
|
|
Commit Message
Shawn Sung (宋孝謙)
Nov. 24, 2023, 10 a.m. UTC
Create rotation property according to the hardware capability. Since currently OVL of all chips support same rotation, no need to define it in the driver data. Fixes: 84d805753983 ("drm/mediatek: Support reflect-y plane rotation") Reviewed-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com> Signed-off-by: Hsiao Chien Sung <shawn.sung@mediatek.com> --- drivers/gpu/drm/mediatek/mtk_disp_drv.h | 1 + drivers/gpu/drm/mediatek/mtk_disp_ovl.c | 18 ++++++------------ .../gpu/drm/mediatek/mtk_disp_ovl_adaptor.c | 9 +++++++++ drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c | 1 + drivers/gpu/drm/mediatek/mtk_drm_plane.c | 2 +- 5 files changed, 18 insertions(+), 13 deletions(-) -- 2.39.2
Comments
Hi, Hsiao-chien: On Fri, 2023-11-24 at 18:00 +0800, Hsiao Chien Sung wrote: > Create rotation property according to the hardware capability. > Since currently OVL of all chips support same rotation, > no need to define it in the driver data. > > Fixes: 84d805753983 ("drm/mediatek: Support reflect-y plane > rotation") > > Reviewed-by: AngeloGioacchino Del Regno < > angelogioacchino.delregno@collabora.com> > Signed-off-by: Hsiao Chien Sung <shawn.sung@mediatek.com> > --- > drivers/gpu/drm/mediatek/mtk_disp_drv.h | 1 + > drivers/gpu/drm/mediatek/mtk_disp_ovl.c | 18 ++++++-------- > ---- > .../gpu/drm/mediatek/mtk_disp_ovl_adaptor.c | 9 +++++++++ > drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c | 1 + > drivers/gpu/drm/mediatek/mtk_drm_plane.c | 2 +- > 5 files changed, 18 insertions(+), 13 deletions(-) > > diff --git a/drivers/gpu/drm/mediatek/mtk_disp_drv.h > b/drivers/gpu/drm/mediatek/mtk_disp_drv.h > index 4d6e8b667bc3..c5afeb7c5527 100644 > --- a/drivers/gpu/drm/mediatek/mtk_disp_drv.h > +++ b/drivers/gpu/drm/mediatek/mtk_disp_drv.h > @@ -127,6 +127,7 @@ void mtk_ovl_adaptor_register_vblank_cb(struct > device *dev, void (*vblank_cb)(vo > void mtk_ovl_adaptor_unregister_vblank_cb(struct device *dev); > void mtk_ovl_adaptor_enable_vblank(struct device *dev); > void mtk_ovl_adaptor_disable_vblank(struct device *dev); > +unsigned int mtk_ovl_adaptor_supported_rotations(struct device > *dev); > void mtk_ovl_adaptor_start(struct device *dev); > void mtk_ovl_adaptor_stop(struct device *dev); > unsigned int mtk_ovl_adaptor_layer_nr(struct device *dev); > diff --git a/drivers/gpu/drm/mediatek/mtk_disp_ovl.c > b/drivers/gpu/drm/mediatek/mtk_disp_ovl.c > index ecc38932fd44..319bbfde5cf9 100644 > --- a/drivers/gpu/drm/mediatek/mtk_disp_ovl.c > +++ b/drivers/gpu/drm/mediatek/mtk_disp_ovl.c > @@ -415,6 +415,10 @@ unsigned int mtk_ovl_layer_nr(struct device > *dev) > > unsigned int mtk_ovl_supported_rotations(struct device *dev) > { > + /* > + * although currently OVL can only do reflection, > + * reflect x + reflect y = rotate 180 > + */ > return DRM_MODE_ROTATE_0 | DRM_MODE_ROTATE_180 | > DRM_MODE_REFLECT_X | DRM_MODE_REFLECT_Y; > } > @@ -423,27 +427,17 @@ int mtk_ovl_layer_check(struct device *dev, > unsigned int idx, > struct mtk_plane_state *mtk_state) > { > struct drm_plane_state *state = &mtk_state->base; > - unsigned int rotation = 0; > > - rotation = drm_rotation_simplify(state->rotation, > - DRM_MODE_ROTATE_0 | > - DRM_MODE_REFLECT_X | > - DRM_MODE_REFLECT_Y); > - rotation &= ~DRM_MODE_ROTATE_0; > - > - /* We can only do reflection, not rotation */ > - if ((rotation & DRM_MODE_ROTATE_MASK) != 0) > + if (state->rotation & ~mtk_ovl_supported_rotations(dev)) > return -EINVAL; The commit message of this patch is "Create rotation property according to the hardware capability". I think this modification is not related to create property, so separate this to another patch. > > /* > * TODO: Rotating/reflecting YUV buffers is not supported at > this time. > * Only RGB[AX] variants are supported. > */ > - if (state->fb->format->is_yuv && rotation != 0) > + if (state->fb->format->is_yuv && (state->rotation & > ~DRM_MODE_ROTATE_0)) > return -EINVAL; > > - state->rotation = rotation; > - > return 0; > } > > diff --git a/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c > b/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c > index 4398db9a6276..273c79d37bef 100644 > --- a/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c > +++ b/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c > @@ -383,6 +383,15 @@ void mtk_ovl_adaptor_register_vblank_cb(struct > device *dev, void (*vblank_cb)(vo > vblank_cb, vblank_cb_data); > } > > +unsigned int mtk_ovl_adaptor_supported_rotations(struct device *dev) > +{ > + /* > + * should still return DRM_MODE_ROTATE_0 if rotation is not > supported, > + * or IGT will fail. > + */ > + return DRM_MODE_ROTATE_0; > +} > + > void mtk_ovl_adaptor_unregister_vblank_cb(struct device *dev) > { > struct mtk_disp_ovl_adaptor *ovl_adaptor = > dev_get_drvdata(dev); > diff --git a/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c > b/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c > index ffa4868b1222..206dd6f6f99e 100644 > --- a/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c > +++ b/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c > @@ -422,6 +422,7 @@ static const struct mtk_ddp_comp_funcs > ddp_ovl_adaptor = { > .remove = mtk_ovl_adaptor_remove_comp, > .get_formats = mtk_ovl_adaptor_get_formats, > .get_num_formats = mtk_ovl_adaptor_get_num_formats, > + .supported_rotations = mtk_ovl_adaptor_supported_rotations, > }; > > static const char * const mtk_ddp_comp_stem[MTK_DDP_COMP_TYPE_MAX] = > { > diff --git a/drivers/gpu/drm/mediatek/mtk_drm_plane.c > b/drivers/gpu/drm/mediatek/mtk_drm_plane.c > index e2ec61b69618..894c39a38a58 100644 > --- a/drivers/gpu/drm/mediatek/mtk_drm_plane.c > +++ b/drivers/gpu/drm/mediatek/mtk_drm_plane.c > @@ -344,7 +344,7 @@ int mtk_plane_init(struct drm_device *dev, struct > drm_plane *plane, > return err; > } > > - if (supported_rotations & ~DRM_MODE_ROTATE_0) { > + if (supported_rotations) { Why need this modification? Before Sean's patch [1], only support rotate 0 and does not create property and it works. Why does it must create property for only support rotate 0? [1] https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/drivers/gpu/drm/mediatek/mtk_drm_plane.c?h=v6.7-rc6&id=ef87d3e2dd251374c5c9fa3b6502aeff8fe29da9 Regards, CK > err = drm_plane_create_rotation_property(plane, > DRM_MODE_ROTAT > E_0, > supported_rota > tions); > -- > 2.39.2 >
Hi CK, On Tue, 2023-12-19 at 02:35 +0000, CK Hu (胡俊光) wrote: > Hi, Hsiao-chien: > > On Fri, 2023-11-24 at 18:00 +0800, Hsiao Chien Sung wrote: > > Create rotation property according to the hardware capability. > > Since currently OVL of all chips support same rotation, > > no need to define it in the driver data. > > > > Fixes: 84d805753983 ("drm/mediatek: Support reflect-y plane > > rotation") > > > > Reviewed-by: AngeloGioacchino Del Regno < > > angelogioacchino.delregno@collabora.com> > > Signed-off-by: Hsiao Chien Sung <shawn.sung@mediatek.com> > > --- > > drivers/gpu/drm/mediatek/mtk_disp_drv.h | 1 + > > drivers/gpu/drm/mediatek/mtk_disp_ovl.c | 18 ++++++-------- > > ---- > > .../gpu/drm/mediatek/mtk_disp_ovl_adaptor.c | 9 +++++++++ > > drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c | 1 + > > drivers/gpu/drm/mediatek/mtk_drm_plane.c | 2 +- > > 5 files changed, 18 insertions(+), 13 deletions(-) > > > > diff --git a/drivers/gpu/drm/mediatek/mtk_disp_drv.h > > b/drivers/gpu/drm/mediatek/mtk_disp_drv.h > > index 4d6e8b667bc3..c5afeb7c5527 100644 > > --- a/drivers/gpu/drm/mediatek/mtk_disp_drv.h > > +++ b/drivers/gpu/drm/mediatek/mtk_disp_drv.h > > @@ -127,6 +127,7 @@ void mtk_ovl_adaptor_register_vblank_cb(struct > > device *dev, void (*vblank_cb)(vo > > void mtk_ovl_adaptor_unregister_vblank_cb(struct device *dev); > > void mtk_ovl_adaptor_enable_vblank(struct device *dev); > > void mtk_ovl_adaptor_disable_vblank(struct device *dev); > > +unsigned int mtk_ovl_adaptor_supported_rotations(struct device > > *dev); > > void mtk_ovl_adaptor_start(struct device *dev); > > void mtk_ovl_adaptor_stop(struct device *dev); > > unsigned int mtk_ovl_adaptor_layer_nr(struct device *dev); > > diff --git a/drivers/gpu/drm/mediatek/mtk_disp_ovl.c > > b/drivers/gpu/drm/mediatek/mtk_disp_ovl.c > > index ecc38932fd44..319bbfde5cf9 100644 > > --- a/drivers/gpu/drm/mediatek/mtk_disp_ovl.c > > +++ b/drivers/gpu/drm/mediatek/mtk_disp_ovl.c > > @@ -415,6 +415,10 @@ unsigned int mtk_ovl_layer_nr(struct device > > *dev) > > > > unsigned int mtk_ovl_supported_rotations(struct device *dev) > > { > > + /* > > + * although currently OVL can only do reflection, > > + * reflect x + reflect y = rotate 180 > > + */ > > return DRM_MODE_ROTATE_0 | DRM_MODE_ROTATE_180 | > > DRM_MODE_REFLECT_X | DRM_MODE_REFLECT_Y; > > } > > @@ -423,27 +427,17 @@ int mtk_ovl_layer_check(struct device *dev, > > unsigned int idx, > > struct mtk_plane_state *mtk_state) > > { > > struct drm_plane_state *state = &mtk_state->base; > > - unsigned int rotation = 0; > > > > - rotation = drm_rotation_simplify(state->rotation, > > - DRM_MODE_ROTATE_0 | > > - DRM_MODE_REFLECT_X | > > - DRM_MODE_REFLECT_Y); > > - rotation &= ~DRM_MODE_ROTATE_0; > > - > > - /* We can only do reflection, not rotation */ > > - if ((rotation & DRM_MODE_ROTATE_MASK) != 0) > > + if (state->rotation & ~mtk_ovl_supported_rotations(dev)) > > return -EINVAL; > > The commit message of this patch is "Create rotation property > according > to the hardware capability". I think this modification is not related > to create property, so separate this to another patch. Since these modifications are all related to rotation property, or should I change the title and commit message to "Modify roation property for passing IGT"? > > > > > /* > > * TODO: Rotating/reflecting YUV buffers is not supported at > > this time. > > * Only RGB[AX] variants are supported. > > */ > > - if (state->fb->format->is_yuv && rotation != 0) > > + if (state->fb->format->is_yuv && (state->rotation & > > ~DRM_MODE_ROTATE_0)) > > return -EINVAL; > > > > - state->rotation = rotation; > > - > > return 0; > > } > > > > diff --git a/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c > > b/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c > > index 4398db9a6276..273c79d37bef 100644 > > --- a/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c > > +++ b/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c > > @@ -383,6 +383,15 @@ void mtk_ovl_adaptor_register_vblank_cb(struct > > device *dev, void (*vblank_cb)(vo > > vblank_cb, vblank_cb_data); > > } > > > > +unsigned int mtk_ovl_adaptor_supported_rotations(struct device > > *dev) > > +{ > > + /* > > + * should still return DRM_MODE_ROTATE_0 if rotation is not > > supported, > > + * or IGT will fail. > > + */ > > + return DRM_MODE_ROTATE_0; > > +} > > + > > void mtk_ovl_adaptor_unregister_vblank_cb(struct device *dev) > > { > > struct mtk_disp_ovl_adaptor *ovl_adaptor = > > dev_get_drvdata(dev); > > diff --git a/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c > > b/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c > > index ffa4868b1222..206dd6f6f99e 100644 > > --- a/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c > > +++ b/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c > > @@ -422,6 +422,7 @@ static const struct mtk_ddp_comp_funcs > > ddp_ovl_adaptor = { > > .remove = mtk_ovl_adaptor_remove_comp, > > .get_formats = mtk_ovl_adaptor_get_formats, > > .get_num_formats = mtk_ovl_adaptor_get_num_formats, > > + .supported_rotations = mtk_ovl_adaptor_supported_rotations, > > }; > > > > static const char * const mtk_ddp_comp_stem[MTK_DDP_COMP_TYPE_MAX] > > = > > { > > diff --git a/drivers/gpu/drm/mediatek/mtk_drm_plane.c > > b/drivers/gpu/drm/mediatek/mtk_drm_plane.c > > index e2ec61b69618..894c39a38a58 100644 > > --- a/drivers/gpu/drm/mediatek/mtk_drm_plane.c > > +++ b/drivers/gpu/drm/mediatek/mtk_drm_plane.c > > @@ -344,7 +344,7 @@ int mtk_plane_init(struct drm_device *dev, > > struct > > drm_plane *plane, > > return err; > > } > > > > - if (supported_rotations & ~DRM_MODE_ROTATE_0) { > > + if (supported_rotations) { > > Why need this modification? > Before Sean's patch [1], only support rotate 0 and does not create > property and it works. Why does it must create property for only > support rotate 0? Yes, as long as the user doesn't check rotation properties before commiting the pitures, there will be no problem. But IGT somehow checked this DRM_MODE_ROTATE_0 flag before executing the tests (not all of them), and leads to failures in these test itmes. > > > [1] > https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/drivers/gpu/drm/mediatek/mtk_drm_plane.c?h=v6.7-rc6&id=ef87d3e2dd251374c5c9fa3b6502aeff8fe29da9 > > Regards, > CK > > > err = drm_plane_create_rotation_property(plane, > > DRM_MODE_ROTAT > > E_0, > > supported_rota > > tions); > > -- > > 2.39.2 > > Thanks, Shawn
Hi, Hsiao-chien: On Tue, 2023-12-19 at 03:45 +0000, Shawn Sung (宋孝謙) wrote: > Hi CK, > > On Tue, 2023-12-19 at 02:35 +0000, CK Hu (胡俊光) wrote: > > Hi, Hsiao-chien: > > > > On Fri, 2023-11-24 at 18:00 +0800, Hsiao Chien Sung wrote: > > > Create rotation property according to the hardware capability. > > > Since currently OVL of all chips support same rotation, > > > no need to define it in the driver data. > > > > > > Fixes: 84d805753983 ("drm/mediatek: Support reflect-y plane > > > rotation") > > > > > > Reviewed-by: AngeloGioacchino Del Regno < > > > angelogioacchino.delregno@collabora.com> > > > Signed-off-by: Hsiao Chien Sung <shawn.sung@mediatek.com> > > > --- > > > drivers/gpu/drm/mediatek/mtk_disp_drv.h | 1 + > > > drivers/gpu/drm/mediatek/mtk_disp_ovl.c | 18 ++++++---- > > > ---- > > > ---- > > > .../gpu/drm/mediatek/mtk_disp_ovl_adaptor.c | 9 +++++++++ > > > drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c | 1 + > > > drivers/gpu/drm/mediatek/mtk_drm_plane.c | 2 +- > > > 5 files changed, 18 insertions(+), 13 deletions(-) > > > > > > diff --git a/drivers/gpu/drm/mediatek/mtk_disp_drv.h > > > b/drivers/gpu/drm/mediatek/mtk_disp_drv.h > > > index 4d6e8b667bc3..c5afeb7c5527 100644 > > > --- a/drivers/gpu/drm/mediatek/mtk_disp_drv.h > > > +++ b/drivers/gpu/drm/mediatek/mtk_disp_drv.h > > > @@ -127,6 +127,7 @@ void > > > mtk_ovl_adaptor_register_vblank_cb(struct > > > device *dev, void (*vblank_cb)(vo > > > void mtk_ovl_adaptor_unregister_vblank_cb(struct device *dev); > > > void mtk_ovl_adaptor_enable_vblank(struct device *dev); > > > void mtk_ovl_adaptor_disable_vblank(struct device *dev); > > > +unsigned int mtk_ovl_adaptor_supported_rotations(struct device > > > *dev); > > > void mtk_ovl_adaptor_start(struct device *dev); > > > void mtk_ovl_adaptor_stop(struct device *dev); > > > unsigned int mtk_ovl_adaptor_layer_nr(struct device *dev); > > > diff --git a/drivers/gpu/drm/mediatek/mtk_disp_ovl.c > > > b/drivers/gpu/drm/mediatek/mtk_disp_ovl.c > > > index ecc38932fd44..319bbfde5cf9 100644 > > > --- a/drivers/gpu/drm/mediatek/mtk_disp_ovl.c > > > +++ b/drivers/gpu/drm/mediatek/mtk_disp_ovl.c > > > @@ -415,6 +415,10 @@ unsigned int mtk_ovl_layer_nr(struct device > > > *dev) > > > > > > unsigned int mtk_ovl_supported_rotations(struct device *dev) > > > { > > > + /* > > > + * although currently OVL can only do reflection, > > > + * reflect x + reflect y = rotate 180 > > > + */ > > > return DRM_MODE_ROTATE_0 | DRM_MODE_ROTATE_180 | > > > DRM_MODE_REFLECT_X | DRM_MODE_REFLECT_Y; > > > } > > > @@ -423,27 +427,17 @@ int mtk_ovl_layer_check(struct device *dev, > > > unsigned int idx, > > > struct mtk_plane_state *mtk_state) > > > { > > > struct drm_plane_state *state = &mtk_state->base; > > > - unsigned int rotation = 0; > > > > > > - rotation = drm_rotation_simplify(state->rotation, > > > - DRM_MODE_ROTATE_0 | > > > - DRM_MODE_REFLECT_X | > > > - DRM_MODE_REFLECT_Y); > > > - rotation &= ~DRM_MODE_ROTATE_0; > > > - > > > - /* We can only do reflection, not rotation */ > > > - if ((rotation & DRM_MODE_ROTATE_MASK) != 0) > > > + if (state->rotation & ~mtk_ovl_supported_rotations(dev)) > > > return -EINVAL; > > > > The commit message of this patch is "Create rotation property > > according > > to the hardware capability". I think this modification is not > > related > > to create property, so separate this to another patch. > > Since these modifications are all related to rotation property, or > should I change the title and commit message to "Modify roation > property for passing IGT"? OK. But I don't know why do this, so describe more about this. > > > > > > > > > /* > > > * TODO: Rotating/reflecting YUV buffers is not supported at > > > this time. > > > * Only RGB[AX] variants are supported. > > > */ > > > - if (state->fb->format->is_yuv && rotation != 0) > > > + if (state->fb->format->is_yuv && (state->rotation & > > > ~DRM_MODE_ROTATE_0)) > > > return -EINVAL; > > > > > > - state->rotation = rotation; > > > - > > > return 0; > > > } > > > > > > diff --git a/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c > > > b/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c > > > index 4398db9a6276..273c79d37bef 100644 > > > --- a/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c > > > +++ b/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c > > > @@ -383,6 +383,15 @@ void > > > mtk_ovl_adaptor_register_vblank_cb(struct > > > device *dev, void (*vblank_cb)(vo > > > vblank_cb, vblank_cb_data); > > > } > > > > > > +unsigned int mtk_ovl_adaptor_supported_rotations(struct device > > > *dev) > > > +{ > > > + /* > > > + * should still return DRM_MODE_ROTATE_0 if rotation is not > > > supported, > > > + * or IGT will fail. > > > + */ > > > + return DRM_MODE_ROTATE_0; > > > +} > > > + > > > void mtk_ovl_adaptor_unregister_vblank_cb(struct device *dev) > > > { > > > struct mtk_disp_ovl_adaptor *ovl_adaptor = > > > dev_get_drvdata(dev); > > > diff --git a/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c > > > b/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c > > > index ffa4868b1222..206dd6f6f99e 100644 > > > --- a/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c > > > +++ b/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c > > > @@ -422,6 +422,7 @@ static const struct mtk_ddp_comp_funcs > > > ddp_ovl_adaptor = { > > > .remove = mtk_ovl_adaptor_remove_comp, > > > .get_formats = mtk_ovl_adaptor_get_formats, > > > .get_num_formats = mtk_ovl_adaptor_get_num_formats, > > > + .supported_rotations = mtk_ovl_adaptor_supported_rotations, > > > }; > > > > > > static const char * const > > > mtk_ddp_comp_stem[MTK_DDP_COMP_TYPE_MAX] > > > = > > > { > > > diff --git a/drivers/gpu/drm/mediatek/mtk_drm_plane.c > > > b/drivers/gpu/drm/mediatek/mtk_drm_plane.c > > > index e2ec61b69618..894c39a38a58 100644 > > > --- a/drivers/gpu/drm/mediatek/mtk_drm_plane.c > > > +++ b/drivers/gpu/drm/mediatek/mtk_drm_plane.c > > > @@ -344,7 +344,7 @@ int mtk_plane_init(struct drm_device *dev, > > > struct > > > drm_plane *plane, > > > return err; > > > } > > > > > > - if (supported_rotations & ~DRM_MODE_ROTATE_0) { > > > + if (supported_rotations) { > > > > Why need this modification? > > Before Sean's patch [1], only support rotate 0 and does not create > > property and it works. Why does it must create property for only > > support rotate 0? > > Yes, as long as the user doesn't check rotation properties before > commiting the pitures, there will be no problem. But IGT somehow > checked this DRM_MODE_ROTATE_0 flag before executing the tests (not > all > of them), and leads to failures in these test itmes. OK, so, when supported_rotations == NULL (mtk_disp_rdma), it should also create rotation property. But I'm confused that if IGT assume that all drm driver should have rotation property, why drm core does not add this property for all drm driver? Regards, CK > > > > > > > [1] > > > > https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/drivers/gpu/drm/mediatek/mtk_drm_plane.c?h=v6.7-rc6&id=ef87d3e2dd251374c5c9fa3b6502aeff8fe29da9 > > > > Regards, > > CK > > > > > err = drm_plane_create_rotation_property(plane, > > > DRM_MODE_ROTAT > > > E_0, > > > supported_rota > > > tions); > > > -- > > > 2.39.2 > > > > > Thanks, > Shawn
Hi CK, On Tue, 2023-12-19 at 05:24 +0000, CK Hu (胡俊光) wrote: > Hi, Hsiao-chien: > > On Tue, 2023-12-19 at 03:45 +0000, Shawn Sung (宋孝謙) wrote: > > Hi CK, > > > > On Tue, 2023-12-19 at 02:35 +0000, CK Hu (胡俊光) wrote: > > > Hi, Hsiao-chien: > > > > > > On Fri, 2023-11-24 at 18:00 +0800, Hsiao Chien Sung wrote: > > > > Create rotation property according to the hardware capability. > > > > Since currently OVL of all chips support same rotation, > > > > no need to define it in the driver data. > > > > > > > > Fixes: 84d805753983 ("drm/mediatek: Support reflect-y plane > > > > rotation") > > > > > > > > Reviewed-by: AngeloGioacchino Del Regno < > > > > angelogioacchino.delregno@collabora.com> > > > > Signed-off-by: Hsiao Chien Sung <shawn.sung@mediatek.com> > > > > --- > > > > drivers/gpu/drm/mediatek/mtk_disp_drv.h | 1 + > > > > drivers/gpu/drm/mediatek/mtk_disp_ovl.c | 18 ++++++---- > > > > ---- > > > > ---- > > > > .../gpu/drm/mediatek/mtk_disp_ovl_adaptor.c | 9 +++++++++ > > > > drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c | 1 + > > > > drivers/gpu/drm/mediatek/mtk_drm_plane.c | 2 +- > > > > 5 files changed, 18 insertions(+), 13 deletions(-) > > > > > > > > diff --git a/drivers/gpu/drm/mediatek/mtk_disp_drv.h > > > > b/drivers/gpu/drm/mediatek/mtk_disp_drv.h > > > > index 4d6e8b667bc3..c5afeb7c5527 100644 > > > > --- a/drivers/gpu/drm/mediatek/mtk_disp_drv.h > > > > +++ b/drivers/gpu/drm/mediatek/mtk_disp_drv.h > > > > @@ -127,6 +127,7 @@ void > > > > mtk_ovl_adaptor_register_vblank_cb(struct > > > > device *dev, void (*vblank_cb)(vo > > > > void mtk_ovl_adaptor_unregister_vblank_cb(struct device *dev); > > > > void mtk_ovl_adaptor_enable_vblank(struct device *dev); > > > > void mtk_ovl_adaptor_disable_vblank(struct device *dev); > > > > +unsigned int mtk_ovl_adaptor_supported_rotations(struct device > > > > *dev); > > > > void mtk_ovl_adaptor_start(struct device *dev); > > > > void mtk_ovl_adaptor_stop(struct device *dev); > > > > unsigned int mtk_ovl_adaptor_layer_nr(struct device *dev); > > > > diff --git a/drivers/gpu/drm/mediatek/mtk_disp_ovl.c > > > > b/drivers/gpu/drm/mediatek/mtk_disp_ovl.c > > > > index ecc38932fd44..319bbfde5cf9 100644 > > > > --- a/drivers/gpu/drm/mediatek/mtk_disp_ovl.c > > > > +++ b/drivers/gpu/drm/mediatek/mtk_disp_ovl.c > > > > @@ -415,6 +415,10 @@ unsigned int mtk_ovl_layer_nr(struct > > > > device > > > > *dev) > > > > > > > > unsigned int mtk_ovl_supported_rotations(struct device *dev) > > > > { > > > > + /* > > > > + * although currently OVL can only do reflection, > > > > + * reflect x + reflect y = rotate 180 > > > > + */ > > > > return DRM_MODE_ROTATE_0 | DRM_MODE_ROTATE_180 | > > > > DRM_MODE_REFLECT_X | DRM_MODE_REFLECT_Y; > > > > } > > > > @@ -423,27 +427,17 @@ int mtk_ovl_layer_check(struct device > > > > *dev, > > > > unsigned int idx, > > > > struct mtk_plane_state *mtk_state) > > > > { > > > > struct drm_plane_state *state = &mtk_state->base; > > > > - unsigned int rotation = 0; > > > > > > > > - rotation = drm_rotation_simplify(state->rotation, > > > > - DRM_MODE_ROTATE_0 | > > > > - DRM_MODE_REFLECT_X | > > > > - DRM_MODE_REFLECT_Y); > > > > - rotation &= ~DRM_MODE_ROTATE_0; > > > > - > > > > - /* We can only do reflection, not rotation */ > > > > - if ((rotation & DRM_MODE_ROTATE_MASK) != 0) > > > > + if (state->rotation & > > > > ~mtk_ovl_supported_rotations(dev)) > > > > return -EINVAL; > > > > > > The commit message of this patch is "Create rotation property > > > according > > > to the hardware capability". I think this modification is not > > > related > > > to create property, so separate this to another patch. > > > > Since these modifications are all related to rotation property, or > > should I change the title and commit message to "Modify roation > > property for passing IGT"? > > OK. But I don't know why do this, so describe more about this. > Got it, thanks. Will add more information to the commit message. > > > > > > > > > > > > > /* > > > > * TODO: Rotating/reflecting YUV buffers is not > > > > supported at > > > > this time. > > > > * Only RGB[AX] variants are supported. > > > > */ > > > > - if (state->fb->format->is_yuv && rotation != 0) > > > > + if (state->fb->format->is_yuv && (state->rotation & > > > > ~DRM_MODE_ROTATE_0)) > > > > return -EINVAL; > > > > > > > > - state->rotation = rotation; > > > > - > > > > return 0; > > > > } > > > > > > > > diff --git a/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c > > > > b/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c > > > > index 4398db9a6276..273c79d37bef 100644 > > > > --- a/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c > > > > +++ b/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c > > > > @@ -383,6 +383,15 @@ void > > > > mtk_ovl_adaptor_register_vblank_cb(struct > > > > device *dev, void (*vblank_cb)(vo > > > > vblank_cb, > > > > vblank_cb_data); > > > > } > > > > > > > > +unsigned int mtk_ovl_adaptor_supported_rotations(struct device > > > > *dev) > > > > +{ > > > > + /* > > > > + * should still return DRM_MODE_ROTATE_0 if rotation is > > > > not > > > > supported, > > > > + * or IGT will fail. > > > > + */ > > > > + return DRM_MODE_ROTATE_0; > > > > +} > > > > + > > > > void mtk_ovl_adaptor_unregister_vblank_cb(struct device *dev) > > > > { > > > > struct mtk_disp_ovl_adaptor *ovl_adaptor = > > > > dev_get_drvdata(dev); > > > > diff --git a/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c > > > > b/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c > > > > index ffa4868b1222..206dd6f6f99e 100644 > > > > --- a/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c > > > > +++ b/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c > > > > @@ -422,6 +422,7 @@ static const struct mtk_ddp_comp_funcs > > > > ddp_ovl_adaptor = { > > > > .remove = mtk_ovl_adaptor_remove_comp, > > > > .get_formats = mtk_ovl_adaptor_get_formats, > > > > .get_num_formats = mtk_ovl_adaptor_get_num_formats, > > > > + .supported_rotations = > > > > mtk_ovl_adaptor_supported_rotations, > > > > }; > > > > > > > > static const char * const > > > > mtk_ddp_comp_stem[MTK_DDP_COMP_TYPE_MAX] > > > > = > > > > { > > > > diff --git a/drivers/gpu/drm/mediatek/mtk_drm_plane.c > > > > b/drivers/gpu/drm/mediatek/mtk_drm_plane.c > > > > index e2ec61b69618..894c39a38a58 100644 > > > > --- a/drivers/gpu/drm/mediatek/mtk_drm_plane.c > > > > +++ b/drivers/gpu/drm/mediatek/mtk_drm_plane.c > > > > @@ -344,7 +344,7 @@ int mtk_plane_init(struct drm_device *dev, > > > > struct > > > > drm_plane *plane, > > > > return err; > > > > } > > > > > > > > - if (supported_rotations & ~DRM_MODE_ROTATE_0) { > > > > + if (supported_rotations) { > > > > > > Why need this modification? > > > Before Sean's patch [1], only support rotate 0 and does not > > > create > > > property and it works. Why does it must create property for only > > > support rotate 0? > > > > Yes, as long as the user doesn't check rotation properties before > > commiting the pitures, there will be no problem. But IGT somehow > > checked this DRM_MODE_ROTATE_0 flag before executing the tests (not > > all > > of them), and leads to failures in these test itmes. > > OK, so, when supported_rotations == NULL (mtk_disp_rdma), it should > also create rotation property. But I'm confused that if IGT assume > that > all drm driver should have rotation property, why drm core does not > add > this property for all drm driver? > After checking the report, only "graphics.IgtKms.kms_flip_unstable" has such a constraint. However, since IGT version is still keep updating, there are not guarantees about this behavior. I did search for "DRM_MODE_ROTATE_0" in the kernel to check if there is any rule or even suggestion about setting this property, but the flag is rarely even mentioned. Maybe we could also report this issue to IGT team instead of changing the behavior of our driver. > Regards, > CK > > > > > > > > > > > > [1] > > > > > > > > > https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/drivers/gpu/drm/mediatek/mtk_drm_plane.c?h=v6.7-rc6&id=ef87d3e2dd251374c5c9fa3b6502aeff8fe29da9 > > > > > > Regards, > > > CK > > > > > > > err = drm_plane_create_rotation_property(plane, > > > > DRM_MO > > > > DE_ROTAT > > > > E_0, > > > > suppor > > > > ted_rota > > > > tions); > > > > -- > > > > 2.39.2 > > > > > > > > Thanks, > > Shawn
diff --git a/drivers/gpu/drm/mediatek/mtk_disp_drv.h b/drivers/gpu/drm/mediatek/mtk_disp_drv.h index 4d6e8b667bc3..c5afeb7c5527 100644 --- a/drivers/gpu/drm/mediatek/mtk_disp_drv.h +++ b/drivers/gpu/drm/mediatek/mtk_disp_drv.h @@ -127,6 +127,7 @@ void mtk_ovl_adaptor_register_vblank_cb(struct device *dev, void (*vblank_cb)(vo void mtk_ovl_adaptor_unregister_vblank_cb(struct device *dev); void mtk_ovl_adaptor_enable_vblank(struct device *dev); void mtk_ovl_adaptor_disable_vblank(struct device *dev); +unsigned int mtk_ovl_adaptor_supported_rotations(struct device *dev); void mtk_ovl_adaptor_start(struct device *dev); void mtk_ovl_adaptor_stop(struct device *dev); unsigned int mtk_ovl_adaptor_layer_nr(struct device *dev); diff --git a/drivers/gpu/drm/mediatek/mtk_disp_ovl.c b/drivers/gpu/drm/mediatek/mtk_disp_ovl.c index ecc38932fd44..319bbfde5cf9 100644 --- a/drivers/gpu/drm/mediatek/mtk_disp_ovl.c +++ b/drivers/gpu/drm/mediatek/mtk_disp_ovl.c @@ -415,6 +415,10 @@ unsigned int mtk_ovl_layer_nr(struct device *dev) unsigned int mtk_ovl_supported_rotations(struct device *dev) { + /* + * although currently OVL can only do reflection, + * reflect x + reflect y = rotate 180 + */ return DRM_MODE_ROTATE_0 | DRM_MODE_ROTATE_180 | DRM_MODE_REFLECT_X | DRM_MODE_REFLECT_Y; } @@ -423,27 +427,17 @@ int mtk_ovl_layer_check(struct device *dev, unsigned int idx, struct mtk_plane_state *mtk_state) { struct drm_plane_state *state = &mtk_state->base; - unsigned int rotation = 0; - rotation = drm_rotation_simplify(state->rotation, - DRM_MODE_ROTATE_0 | - DRM_MODE_REFLECT_X | - DRM_MODE_REFLECT_Y); - rotation &= ~DRM_MODE_ROTATE_0; - - /* We can only do reflection, not rotation */ - if ((rotation & DRM_MODE_ROTATE_MASK) != 0) + if (state->rotation & ~mtk_ovl_supported_rotations(dev)) return -EINVAL; /* * TODO: Rotating/reflecting YUV buffers is not supported at this time. * Only RGB[AX] variants are supported. */ - if (state->fb->format->is_yuv && rotation != 0) + if (state->fb->format->is_yuv && (state->rotation & ~DRM_MODE_ROTATE_0)) return -EINVAL; - state->rotation = rotation; - return 0; } diff --git a/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c b/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c index 4398db9a6276..273c79d37bef 100644 --- a/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c +++ b/drivers/gpu/drm/mediatek/mtk_disp_ovl_adaptor.c @@ -383,6 +383,15 @@ void mtk_ovl_adaptor_register_vblank_cb(struct device *dev, void (*vblank_cb)(vo vblank_cb, vblank_cb_data); } +unsigned int mtk_ovl_adaptor_supported_rotations(struct device *dev) +{ + /* + * should still return DRM_MODE_ROTATE_0 if rotation is not supported, + * or IGT will fail. + */ + return DRM_MODE_ROTATE_0; +} + void mtk_ovl_adaptor_unregister_vblank_cb(struct device *dev) { struct mtk_disp_ovl_adaptor *ovl_adaptor = dev_get_drvdata(dev); diff --git a/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c b/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c index ffa4868b1222..206dd6f6f99e 100644 --- a/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c +++ b/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c @@ -422,6 +422,7 @@ static const struct mtk_ddp_comp_funcs ddp_ovl_adaptor = { .remove = mtk_ovl_adaptor_remove_comp, .get_formats = mtk_ovl_adaptor_get_formats, .get_num_formats = mtk_ovl_adaptor_get_num_formats, + .supported_rotations = mtk_ovl_adaptor_supported_rotations, }; static const char * const mtk_ddp_comp_stem[MTK_DDP_COMP_TYPE_MAX] = { diff --git a/drivers/gpu/drm/mediatek/mtk_drm_plane.c b/drivers/gpu/drm/mediatek/mtk_drm_plane.c index e2ec61b69618..894c39a38a58 100644 --- a/drivers/gpu/drm/mediatek/mtk_drm_plane.c +++ b/drivers/gpu/drm/mediatek/mtk_drm_plane.c @@ -344,7 +344,7 @@ int mtk_plane_init(struct drm_device *dev, struct drm_plane *plane, return err; } - if (supported_rotations & ~DRM_MODE_ROTATE_0) { + if (supported_rotations) { err = drm_plane_create_rotation_property(plane, DRM_MODE_ROTATE_0, supported_rotations);