Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp503059pxb; Wed, 27 Jan 2021 13:11:47 -0800 (PST) X-Google-Smtp-Source: ABdhPJyM94h21pladM84x84BLvXgFbNrhqWULntAqYOtRjmlzTeAbMUl5TIPaBkwy4j9nVUN6dhU X-Received: by 2002:aa7:d306:: with SMTP id p6mr11124271edq.351.1611781907200; Wed, 27 Jan 2021 13:11:47 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611781907; cv=none; d=google.com; s=arc-20160816; b=CM3u++wgeIRuM7eQI1bUjjFe6zHbo4+Z8MkGR/2OlgA5jHI8whgBX3Fx51NZwid20U n6l+SFki5zVHXafko1JcDC5sjNJ2Fp4bIed9ZEXlvfZH/xSGIt6Z7xQVE1y4+qBcWCFG IV5QkGiGQs8zB34yCntqTyI3kmogkIig3mmEoeRUH37m3SxdGQKTd0hSOP4KHU/I/hvE 3M+J9EQHUb0gf8XC9POq/sCEJFQT63tTFAkR5OmKyXgO6XZ/n2jTEsaSJx/c4YNe1sYs dMVdig7WFi3S2WIKDupQtXm953xBn+HzVEvTq6rEGalzomN0X2Phj0gUmJ/cNaB/VsCu b5Ow== 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=Vrn1EIPDQCV6JxTU+kz1dQgkwQ7HwcD+i4/it9ET80A=; b=olxU5gzny08sxU5Osm+jeZUchaAnbupGtEre7yavIa/bZRtQsp0i6vxYSD17DRn4NZ UTF+iaaqgs2hFEHRnyD44+xvlTqxiVZW4cfzmwsRsg3G7KMfW50jRUX+uoiKMuH3medB J06lSyCrsFOIMTpK6HuJG1Jrpv6yvXuyRmbQ71PLjigfvVpg5EK6D4H4Pwu/FOrva43b dXzfiySeorlDhnk3mOHzFvMwiCnPWgIakPUpWNk3R0li/8tjYrAUTiHkXfJevpOIXRos /1k4zqBDcx9cCbuiRiGLvxS9MIb0Szla+Iu6ssPljuAGk5hQDTyT4TTNi2zHFQe0AkuX S2Ig== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=GIfmPVWt; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r23si1661421edy.455.2021.01.27.13.11.22; Wed, 27 Jan 2021 13:11:47 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=GIfmPVWt; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234289AbhA0FUA (ORCPT + 99 others); Wed, 27 Jan 2021 00:20:00 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34330 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238865AbhA0E6B (ORCPT ); Tue, 26 Jan 2021 23:58:01 -0500 Received: from mail-pg1-x530.google.com (mail-pg1-x530.google.com [IPv6:2607:f8b0:4864:20::530]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B0BEEC061797 for ; Tue, 26 Jan 2021 20:54:50 -0800 (PST) Received: by mail-pg1-x530.google.com with SMTP id c132so768264pga.3 for ; Tue, 26 Jan 2021 20:54:50 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=Vrn1EIPDQCV6JxTU+kz1dQgkwQ7HwcD+i4/it9ET80A=; b=GIfmPVWtCArqU58hShfQRtp9JVW9Q5txh3wsHjzy5wEQHXSQ//q4qpWXPtjWa+BJ2q GNQbIHm8s3eJkN7XeMXPnpc3C8F7uAO5XK2tgoynWeNk5YWjYu0XwS35KjLAQOudnDTA 7KnJnXS3u10SfGwurLDpej70QUx8340bcwwI8= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=Vrn1EIPDQCV6JxTU+kz1dQgkwQ7HwcD+i4/it9ET80A=; b=nEW2Hc0MYBirsRjOmeBlr6dz8Am/QwIjENVN0PnlRF30VmzBzyZc69LAzWRvX4awzQ 4OZkEEfpV4XYTxWYSLuYV9pDWInDd8mHOxa5zj9It6mb2YKbJzFbLvyrMBSwDFqyWxtB ucbdZwdxXcGpa3JAV1uCVeB5hjN+qp4TxD352oM0aucEsTpZIIB4WQcuVjDcoOfHvJGd Kup2Hi6h/V9uXJSPTZXqb7CipocsR57SLtZboZBpC3/E3/3yRqnqM25vMhH5zijqWVlC eJ27Z2XjZXBMGcz6LljdzZqzIbqbicmyJaEf5bPrniPskIOoKcklJm3IHuqSItyeD0SO Lyxw== X-Gm-Message-State: AOAM530UkfALB36fXkUtVngZp1QMoC91wL0up1/S37kCWzQoIKJxjW5F /nuadca5EuoruuBAjNmcEf/bjg== X-Received: by 2002:a63:4d59:: with SMTP id n25mr9033962pgl.122.1611723290229; Tue, 26 Jan 2021 20:54:50 -0800 (PST) Received: from hsinyi-z840.tpe.corp.google.com ([2401:fa00:1:10:e0a5:d2fc:aaad:1e4a]) by smtp.gmail.com with ESMTPSA id a141sm684484pfa.189.2021.01.26.20.54.47 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 26 Jan 2021 20:54:49 -0800 (PST) From: Hsin-Yi Wang To: CK Hu , Philipp Zabel , Matthias Brugger Cc: David Airlie , Daniel Vetter , Mark Rutland , dri-devel@lists.freedesktop.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, Project_Global_Chrome_Upstream_Group@mediatek.com, Yongqiang Niu Subject: [PATCH v10 6/9] drm/mediatek: add has_dither private data for gamma Date: Wed, 27 Jan 2021 12:54:19 +0800 Message-Id: <20210127045422.2418917-7-hsinyi@chromium.org> X-Mailer: git-send-email 2.30.0.280.ga3ce27912f-goog In-Reply-To: <20210127045422.2418917-1-hsinyi@chromium.org> References: <20210127045422.2418917-1-hsinyi@chromium.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Yongqiang Niu Not all SoC has dither function in gamma module. Add private data to control this function setting. Signed-off-by: Yongqiang Niu Signed-off-by: Hsin-Yi Wang --- drivers/gpu/drm/mediatek/mtk_disp_gamma.c | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/drivers/gpu/drm/mediatek/mtk_disp_gamma.c b/drivers/gpu/drm/mediatek/mtk_disp_gamma.c index b5a499d7e472c..c98fe284265d0 100644 --- a/drivers/gpu/drm/mediatek/mtk_disp_gamma.c +++ b/drivers/gpu/drm/mediatek/mtk_disp_gamma.c @@ -25,7 +25,7 @@ #define LUT_10BIT_MASK 0x03ff struct mtk_disp_gamma_data { - u32 reserved; + bool has_dither; }; /** @@ -91,7 +91,8 @@ void mtk_gamma_config(struct device *dev, unsigned int w, mtk_ddp_write(cmdq_pkt, h << 16 | w, &gamma->cmdq_reg, gamma->regs, DISP_GAMMA_SIZE); - mtk_dither_set_common(gamma->regs, &gamma->cmdq_reg, bpc, DISP_GAMMA_CFG, cmdq_pkt); + if (gamma->data && gamma->data->has_dither) + mtk_dither_set_common(gamma->regs, &gamma->cmdq_reg, bpc, DISP_GAMMA_CFG, cmdq_pkt); } void mtk_gamma_start(struct device *dev) @@ -171,8 +172,13 @@ static int mtk_disp_gamma_remove(struct platform_device *pdev) return 0; } +static const struct mtk_disp_gamma_data mt8173_gamma_driver_data = { + .has_dither = true, +}; + static const struct of_device_id mtk_disp_gamma_driver_dt_match[] = { - { .compatible = "mediatek,mt8173-disp-gamma"}, + { .compatible = "mediatek,mt8173-disp-gamma", + .data = &mt8173_gamma_driver_data}, {}, }; MODULE_DEVICE_TABLE(of, mtk_disp_gamma_driver_dt_match); -- 2.30.0.280.ga3ce27912f-goog