Received: by 10.223.185.116 with SMTP id b49csp7154934wrg; Thu, 1 Mar 2018 00:20:13 -0800 (PST) X-Google-Smtp-Source: AG47ELs8Cr1RetLSycYv6Enlk+qHnuBspzj22gMu+QWnIAu7trkvrw7cpxUijrrYCOQNjbfbL1o9 X-Received: by 10.99.122.12 with SMTP id v12mr905050pgc.128.1519892413646; Thu, 01 Mar 2018 00:20:13 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519892413; cv=none; d=google.com; s=arc-20160816; b=V41sXvYZ7bVKWeu38mzFEL/nEeusynqrON5YjUNCGezNgBYmwxIV2dHPzvDbMnYP69 ZSNDsd2Gue4VOHTtfCMyj4LAiQPSmLzdFHNqWVCsC+LuCgQKQ7ovgeYRZUpjHP06Hnhq qJDqRV20gCoqJjjEhSidyTdjdbomwr9wXUgRDhJuxA2Ts6yIxJtD8q2BtIMAikVKLBfm 4XYW9R23GRxjE26Lm2Kfl7cUH+Rs8eMwL2rJpAle3A/aP5w531yXxbBCpQ1RbKia7fAn JoyWPWNY15sCMj8RKMA2FP8SJWtJygPG7HYmX3kE3JYIma0ejk7UXDudeNvFvmQqYwVQ V8ew== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:subject:cc :to:from:arc-authentication-results; bh=6pr8cugSgQs5x2COwdHgAc3mRiHyhkZQf6tpZuVOzdM=; b=FyCA4OeMA/E50NzVZThwiPgEHdmsPNLq0Asvmq6jyDEjXgmp7+2rz5Gi3YWLulEuoM EvlC3W72zQWJkNOZBgWSpYFffycmpLIHPAwf3gwnbzVlltZ2+wX66I2JTJJKUWDMeM2W 9+13VbR6XOWbqAM9t1QV80Q+iTQSo0IJCKaWKNBnUVCToA6FeSzqXkoL97uaEN1AHUx8 +meVTM86WdiqJ7tZir1EFfFLciojz1v9ABEY6qPZdWSpzIzPz7Xlw1QUYbBNCVy4bVMp kQMOy+bvzLMsrdk3GJZIkfbxMzRKTylo3DavfBaWB8+6w3uF9vO3SmQ0pDmu78fmsxKS OuZw== 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 j66si2620587pfj.181.2018.03.01.00.19.58; Thu, 01 Mar 2018 00:20:13 -0800 (PST) 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 S935794AbeCAITU (ORCPT + 99 others); Thu, 1 Mar 2018 03:19:20 -0500 Received: from mailgw01.mediatek.com ([210.61.82.183]:9264 "EHLO mailgw01.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S934985AbeCAITS (ORCPT ); Thu, 1 Mar 2018 03:19:18 -0500 X-UUID: dcb8cd33af694742aed8176349e80ae9-20180301 Received: from mtkexhb01.mediatek.inc [(172.21.101.102)] by mailgw01.mediatek.com (envelope-from ) (mhqrelay.mediatek.com ESMTP with TLS) with ESMTP id 922581942; Thu, 01 Mar 2018 16:19:14 +0800 Received: from mtkcas07.mediatek.inc (172.21.101.84) by mtkmbs08n1.mediatek.inc (172.21.101.55) with Microsoft SMTP Server (TLS) id 15.0.1210.3; Thu, 1 Mar 2018 16:19:13 +0800 Received: from mtkswgap22.mediatek.inc (172.21.77.33) by mtkcas07.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.0.1210.3 via Frontend Transport; Thu, 1 Mar 2018 16:19:13 +0800 From: To: , CC: , , , , Sean Wang , , Zhi Mao , John Crispin Subject: [PATCH v3] pwm: mediatek: fix up PWM4 and PWM5 malfunction on MT7623 Date: Thu, 1 Mar 2018 16:19:12 +0800 Message-ID: <051f401bcca48ece188023ccf10b2cedc7a25a64.1519891948.git.sean.wang@mediatek.com> X-Mailer: git-send-email 1.7.9.5 MIME-Version: 1.0 Content-Type: text/plain X-MTK: N Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Sean Wang Since the offset for both registers, PWMDWIDTH and PWMTHRES, used to control PWM4 or PWM5 are distinct from the other PWMs, whose wrong programming on PWM hardware causes waveform cannot be output as expected. Thus, the patch adds the extra condition for fixing up the weird case to let PWM4 or PWM5 able to work on MT7623. v1 -> v2: use pwm45_fixup naming instead of pwm45_quirk v2 -> v3: add more tags for Reviewed-by, Fixes, and Cc stable Cc: stable@vger.kernel.org Fixes: caf065f8fd58 ("pwm: Add MediaTek PWM support") Signed-off-by: Sean Wang Reviewed-by: Matthias Brugger Cc: Zhi Mao Cc: John Crispin Cc: Matthias Brugger --- drivers/pwm/pwm-mediatek.c | 24 +++++++++++++++++++++--- 1 file changed, 21 insertions(+), 3 deletions(-) diff --git a/drivers/pwm/pwm-mediatek.c b/drivers/pwm/pwm-mediatek.c index f5d97e0..796baea 100644 --- a/drivers/pwm/pwm-mediatek.c +++ b/drivers/pwm/pwm-mediatek.c @@ -29,7 +29,9 @@ #define PWMGDUR 0x0c #define PWMWAVENUM 0x28 #define PWMDWIDTH 0x2c +#define PWM45DWIDTH_FIXUP 0x30 #define PWMTHRES 0x30 +#define PWM45THRES_FIXUP 0x34 #define PWM_CLK_DIV_MAX 7 @@ -54,6 +56,7 @@ static const char * const mtk_pwm_clk_name[MTK_CLK_MAX] = { struct mtk_pwm_platform_data { unsigned int num_pwms; + bool pwm45_fixup; }; /** @@ -66,6 +69,7 @@ struct mtk_pwm_chip { struct pwm_chip chip; void __iomem *regs; struct clk *clks[MTK_CLK_MAX]; + const struct mtk_pwm_platform_data *soc; }; static const unsigned int mtk_pwm_reg_offset[] = { @@ -131,7 +135,8 @@ static int mtk_pwm_config(struct pwm_chip *chip, struct pwm_device *pwm, { struct mtk_pwm_chip *pc = to_mtk_pwm_chip(chip); struct clk *clk = pc->clks[MTK_CLK_PWM1 + pwm->hwpwm]; - u32 resolution, clkdiv = 0; + u32 resolution, clkdiv = 0, reg_width = PWMDWIDTH, + reg_thres = PWMTHRES; int ret; ret = mtk_pwm_clk_enable(chip, pwm); @@ -151,9 +156,18 @@ static int mtk_pwm_config(struct pwm_chip *chip, struct pwm_device *pwm, return -EINVAL; } + if (pc->soc->pwm45_fixup && pwm->hwpwm > 2) { + /* + * PWM[4,5] has distinct offset for PWMDWIDTH and PWMTHRES + * from the other PWMs on MT7623. + */ + reg_width = PWM45DWIDTH_FIXUP; + reg_thres = PWM45THRES_FIXUP; + } + mtk_pwm_writel(pc, pwm->hwpwm, PWMCON, BIT(15) | clkdiv); - mtk_pwm_writel(pc, pwm->hwpwm, PWMDWIDTH, period_ns / resolution); - mtk_pwm_writel(pc, pwm->hwpwm, PWMTHRES, duty_ns / resolution); + mtk_pwm_writel(pc, pwm->hwpwm, reg_width, period_ns / resolution); + mtk_pwm_writel(pc, pwm->hwpwm, reg_thres, duty_ns / resolution); mtk_pwm_clk_disable(chip, pwm); @@ -211,6 +225,7 @@ static int mtk_pwm_probe(struct platform_device *pdev) data = of_device_get_match_data(&pdev->dev); if (data == NULL) return -EINVAL; + pc->soc = data; res = platform_get_resource(pdev, IORESOURCE_MEM, 0); pc->regs = devm_ioremap_resource(&pdev->dev, res); @@ -251,14 +266,17 @@ static int mtk_pwm_remove(struct platform_device *pdev) static const struct mtk_pwm_platform_data mt2712_pwm_data = { .num_pwms = 8, + .pwm45_fixup = false, }; static const struct mtk_pwm_platform_data mt7622_pwm_data = { .num_pwms = 6, + .pwm45_fixup = false, }; static const struct mtk_pwm_platform_data mt7623_pwm_data = { .num_pwms = 5, + .pwm45_fixup = true, }; static const struct of_device_id mtk_pwm_of_match[] = { -- 2.7.4