Received: by 2002:a05:6358:489b:b0:bb:da1:e618 with SMTP id x27csp7955332rwn; Wed, 14 Sep 2022 07:01:29 -0700 (PDT) X-Google-Smtp-Source: AA6agR7OdkwD6K1RYzCkzkuBTVnYbymHbcPsfJVJDP7whQAsWhXdE+6oj3ZyPuiRUzDFjOn/K05q X-Received: by 2002:a17:907:7d9e:b0:771:db66:7b7c with SMTP id oz30-20020a1709077d9e00b00771db667b7cmr23511575ejc.393.1663164088824; Wed, 14 Sep 2022 07:01:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1663164088; cv=none; d=google.com; s=arc-20160816; b=x2HlDxi5zFEVgQBswS0q8JStudImEk/8q9T6Ks0SEIb8fOaycAdfIHL5KiIFcIjyVb XZrqtuulBZEo9Ki3WldfuLPCzZuZ+1yEEiEFu7cD/D8YmPKhrkP3q99ajfm4WVtd/H/C U+J9wUz8iOKcsVGqLhSvBlWKH8IsbsCQUknLmJkhXaufcNoH/HNLLYoM46jEy8+Bpdoq kWd4Q1/dyHrp5V+rcKtJzvi/JwDFIa5Rv/OG7guQV3/xA2RVAisoR31UjWx4++47y0Hu dLzPuKci3aSwtO0mdANykrcvMStKR6LpCbHUKsUr4aUlL0ksE0I7PfK4XrE2t+L64Z7f okAw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=px7Xehz5yn0CjeKQO52tYdYlFCu/WlQJeKlG8nVps84=; b=wmtuvCjlFteKlSkO05M6zIJiMYfu5LEs/n//LekZnCPIfycIaiX3pxtt3+00bPry7r MgsO6VLZDbh9MFccPnEOpld5x2yzGIZHN1xTgTz3Zdf624Lq78P5KhVYqdwBLdGFJRt8 0WHNN8J37WzixdUodmhRIWcnDvYF4YaX9NOIShuM7XSK+5unAHGinQ7mgRv2nmEvTe+s 5D3/WnYKD219/k1/xpYZXvUm7J88QrRoTjGKTVQRl/4okg4Id1B1n2mkCF66/tM2wmYx jkYwqmt1ly4ILE/3Ls0tOfeDRw9WAmmXeOER7RfBz9fym2mEWwXuJWgzafDETENMzEfF /AsA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mediatek.com header.s=dk header.b=mbliTNAh; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=mediatek.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id dr13-20020a170907720d00b00778aa522d8fsi12404181ejc.350.2022.09.14.07.00.59; Wed, 14 Sep 2022 07:01:28 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@mediatek.com header.s=dk header.b=mbliTNAh; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=mediatek.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229575AbiINNVW (ORCPT + 99 others); Wed, 14 Sep 2022 09:21:22 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59074 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229585AbiINNVO (ORCPT ); Wed, 14 Sep 2022 09:21:14 -0400 Received: from mailgw02.mediatek.com (unknown [210.61.82.184]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 31FC14E637 for ; Wed, 14 Sep 2022 06:21:13 -0700 (PDT) X-UUID: f8c3a821125645fb98a4225e80d5b7a5-20220914 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=mediatek.com; s=dk; h=Content-Transfer-Encoding:Content-Type:MIME-Version:References:In-Reply-To:Message-ID:Date:Subject:CC:To:From; bh=px7Xehz5yn0CjeKQO52tYdYlFCu/WlQJeKlG8nVps84=; b=mbliTNAhImOi4lS92Wun0E15uAqaZrWbH7uOfB/5JZLspeib8HI6r4ttLIdUJ4GYBtscBINlwhZXIywzQkExnDL+m1slGv2l31s3f3IPDlZsXiSkeGYZvWguuZIxALLZ8ycj9pFXkWtsdP/mSenKBfoll19ax/bQ8iRXczPZQzs=; X-CID-P-RULE: Release_Ham X-CID-O-INFO: VERSION:1.1.11,REQID:28ff2d59-0e6c-4ef5-a0dc-f3a05673b08c,IP:0,U RL:0,TC:0,Content:-25,EDM:0,RT:0,SF:95,FILE:0,BULK:0,RULE:Release_Ham,ACTI ON:release,TS:70 X-CID-INFO: VERSION:1.1.11,REQID:28ff2d59-0e6c-4ef5-a0dc-f3a05673b08c,IP:0,URL :0,TC:0,Content:-25,EDM:0,RT:0,SF:95,FILE:0,BULK:0,RULE:Spam_GS981B3D,ACTI ON:quarantine,TS:70 X-CID-META: VersionHash:39a5ff1,CLOUDID:0a4a6cec-2856-4fce-b125-09d4c7ebe045,B ulkID:220914212111LHSLGOFV,BulkQuantity:0,Recheck:0,SF:28|17|19|48,TC:nil, Content:0,EDM:-3,IP:nil,URL:0,File:nil,Bulk:nil,QS:nil,BEC:nil,COL:0 X-UUID: f8c3a821125645fb98a4225e80d5b7a5-20220914 Received: from mtkcas11.mediatek.inc [(172.21.101.40)] by mailgw02.mediatek.com (envelope-from ) (Generic MTA with TLSv1.2 ECDHE-RSA-AES256-SHA384 256/256) with ESMTP id 1100693463; Wed, 14 Sep 2022 21:21:09 +0800 Received: from mtkcas10.mediatek.inc (172.21.101.39) by mtkmbs10n1.mediatek.inc (172.21.101.34) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384) id 15.2.792.15; Wed, 14 Sep 2022 21:21:08 +0800 Received: from mszsdaap41.gcn.mediatek.inc (10.16.6.141) by mtkcas10.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.0.1497.2 via Frontend Transport; Wed, 14 Sep 2022 21:21:07 +0800 From: To: , , , , , , , CC: , , , , , , Xinlei Lee Subject: [PATCH v6,1/3] soc: mediatek: Add mmsys func to adapt to dpi output for MT8186 Date: Wed, 14 Sep 2022 21:21:00 +0800 Message-ID: <1663161662-1598-2-git-send-email-xinlei.lee@mediatek.com> X-Mailer: git-send-email 2.6.4 In-Reply-To: <1663161662-1598-1-git-send-email-xinlei.lee@mediatek.com> References: <1663161662-1598-1-git-send-email-xinlei.lee@mediatek.com> MIME-Version: 1.0 Content-Type: text/plain; charset="yes" Content-Transfer-Encoding: 8bit X-MTK: N X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_MSPIKE_H2,SPF_HELO_PASS, SPF_PASS,T_SCC_BODY_TEXT_LINE,UNPARSEABLE_RELAY,URIBL_CSS autolearn=ham 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: X-Mailing-List: linux-kernel@vger.kernel.org From: Xinlei Lee Add mmsys func to manipulate dpi output format config for MT8186. Co-developed-by: Jitao Shi Signed-off-by: Jitao Shi Signed-off-by: Xinlei Lee Reviewed-by: Nís F. R. A. Prado --- drivers/soc/mediatek/mt8186-mmsys.h | 6 ++++++ drivers/soc/mediatek/mtk-mmsys.c | 20 ++++++++++++++++++++ include/linux/soc/mediatek/mtk-mmsys.h | 2 ++ 3 files changed, 28 insertions(+) diff --git a/drivers/soc/mediatek/mt8186-mmsys.h b/drivers/soc/mediatek/mt8186-mmsys.h index eb1ad9c37a9c..09b1ccbc0093 100644 --- a/drivers/soc/mediatek/mt8186-mmsys.h +++ b/drivers/soc/mediatek/mt8186-mmsys.h @@ -3,6 +3,12 @@ #ifndef __SOC_MEDIATEK_MT8186_MMSYS_H #define __SOC_MEDIATEK_MT8186_MMSYS_H +/* Values for DPI configuration in MMSYS address space */ +#define MT8186_MMSYS_DPI_OUTPUT_FORMAT 0x400 +#define DPI_FORMAT_MASK 0x1 +#define DPI_RGB888_DDR_CON BIT(0) +#define DPI_RGB565_SDR_CON BIT(1) + #define MT8186_MMSYS_OVL_CON 0xF04 #define MT8186_MMSYS_OVL0_CON_MASK 0x3 #define MT8186_MMSYS_OVL0_2L_CON_MASK 0xC diff --git a/drivers/soc/mediatek/mtk-mmsys.c b/drivers/soc/mediatek/mtk-mmsys.c index 06d8e83a2cb5..2e20b24da363 100644 --- a/drivers/soc/mediatek/mtk-mmsys.c +++ b/drivers/soc/mediatek/mtk-mmsys.c @@ -227,6 +227,26 @@ void mtk_mmsys_ddp_disconnect(struct device *dev, } EXPORT_SYMBOL_GPL(mtk_mmsys_ddp_disconnect); +static void mtk_mmsys_update_bits(struct mtk_mmsys *mmsys, u32 offset, u32 mask, u32 val) +{ + u32 tmp; + + tmp = readl_relaxed(mmsys->regs + offset); + tmp = (tmp & ~mask) | val; + writel_relaxed(tmp, mmsys->regs + offset); +} + +void mtk_mmsys_ddp_dpi_fmt_config(struct device *dev, u32 val) +{ + if (val) + mtk_mmsys_update_bits(dev_get_drvdata(dev), MT8186_MMSYS_DPI_OUTPUT_FORMAT, + DPI_RGB888_DDR_CON, DPI_FORMAT_MASK); + else + mtk_mmsys_update_bits(dev_get_drvdata(dev), MT8186_MMSYS_DPI_OUTPUT_FORMAT, + DPI_RGB565_SDR_CON, DPI_FORMAT_MASK); +} +EXPORT_SYMBOL_GPL(mtk_mmsys_ddp_dpi_fmt_config); + static int mtk_mmsys_reset_update(struct reset_controller_dev *rcdev, unsigned long id, bool assert) { diff --git a/include/linux/soc/mediatek/mtk-mmsys.h b/include/linux/soc/mediatek/mtk-mmsys.h index 59117d970daf..d2b02bb43768 100644 --- a/include/linux/soc/mediatek/mtk-mmsys.h +++ b/include/linux/soc/mediatek/mtk-mmsys.h @@ -65,4 +65,6 @@ void mtk_mmsys_ddp_disconnect(struct device *dev, enum mtk_ddp_comp_id cur, enum mtk_ddp_comp_id next); +void mtk_mmsys_ddp_dpi_fmt_config(struct device *dev, u32 val); + #endif /* __MTK_MMSYS_H */ -- 2.18.0