Received: by 2002:a25:e7d8:0:0:0:0:0 with SMTP id e207csp3924439ybh; Tue, 17 Mar 2020 09:00:54 -0700 (PDT) X-Google-Smtp-Source: ADFU+vs/Zpdzt/TeH77wn85JnsiI8oA6awyYzC95Glkmq0H5wma+c7Xg5/utJwKKWuuySAExV11p X-Received: by 2002:a9d:6418:: with SMTP id h24mr4287004otl.172.1584460854174; Tue, 17 Mar 2020 09:00:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1584460854; cv=none; d=google.com; s=arc-20160816; b=AFQVzRV0GHnCd5t6B0ka7oFrCLO9UT6JWeVgC5SIOxccnWimY71aFGTYCt7SIwt76Q d3Xn+LM5Q4JleNmP60plRE0q55uX6olWQon57zS7rdCp4iYsCr1O4vKFGspFVWO2p0Px GCvBbvclSmurazVL2OiJMs2vqhcu8p/0X1q7Na14CDnXikDAJsB+6v5TYKTiAjSfnkAP +dTpN5dy78UHGfB5ePnqf/eqUgugne6xrivuQbboFgrYhGgqeZYApC9Ek2WYBBO66XZP BeHuKrkCzsO7fB6eY8uI29lbLwzwyzFHrQDj9hKSB7rW5/a54wViCvLyvL72VVwCkKCs 2byw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=H9LrRiFVN/DHzGg7tt6K3nT+T7r5Twb2pPaTqb+k2rM=; b=BsWd8GcAKVU0ugJM0/PVwSyGE/osq6oZC321FFQmfX+0TIBqMUxtXc+qipId/6B7hI Wu71jJyANFbZ3auQ6R1cvcxH02uaJlUVisZhlCNlMC154mcbabj3VuYzHIKROdxgtiJg iwZCe+qtjDwlqjt5xcujIYEB8hoph62ReEe/yL7aHD7szgn2wamil5n4rPpQlnO2qt5b l3NU8w1g7nNRytuszZddm8rBkOId9kFEiqjp0C3G5cy4P0GQ/iP7IiPxbz41gEPqKi0h 4POUK7Q48GQPP7s79Mj8pC8oM5eDfh3X+ZQeRTLu6AD/mfZ8swaGmVyfb3PHRsAJXO+t HXgA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@pascalroeleven.nl header.s=x header.b=IpjEpVM6; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=pascalroeleven.nl Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g9si1834621otp.89.2020.03.17.09.00.33; Tue, 17 Mar 2020 09:00:54 -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; dkim=fail header.i=@pascalroeleven.nl header.s=x header.b=IpjEpVM6; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=pascalroeleven.nl Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726822AbgCQQAD (ORCPT + 99 others); Tue, 17 Mar 2020 12:00:03 -0400 Received: from web0081.zxcs.nl ([185.104.29.10]:54908 "EHLO web0081.zxcs.nl" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726809AbgCQQAC (ORCPT ); Tue, 17 Mar 2020 12:00:02 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=pascalroeleven.nl; s=x; h=Content-Transfer-Encoding:MIME-Version:References :In-Reply-To:Message-Id:Date:Subject:Cc:To:From:Sender:Reply-To:Content-Type: Content-ID:Content-Description:Resent-Date:Resent-From:Resent-Sender: Resent-To:Resent-Cc:Resent-Message-ID:List-Id:List-Help:List-Unsubscribe: List-Subscribe:List-Post:List-Owner:List-Archive; bh=H9LrRiFVN/DHzGg7tt6K3nT+T7r5Twb2pPaTqb+k2rM=; b=IpjEpVM6M/Ap5GtnnbY2+ddG5c jZT3HfDBgt0Ja/5OS9rUGayxXlmLEvKMOLrpW1xZaPZnjMS+gYipvG2rrGBGvGd+S61CdB2ZYul7K ojAvrhr5b9ayIU5CBBToMo32i7v2brizj9lc9L+VbX7mlWyz7Zcfzjq9oPrj+s8va+y32RSNyabwi j3nre3ZReEVL0lzwmeSgb0sKHjy4q66b6p+GVYKj4PAcDefJxGpm13Y9waZy6sSHC2pEUD2cj7Wex Ct3Jd785VUo/AuUJRQR+B8gvMKZj66AOI9Ychs+qktGl8Erd3vJBxP2meNSb4mDlll4do92PdGU4a m5nmUKCQ==; Received: from ip565b1bc7.direct-adsl.nl ([86.91.27.199]:60802 helo=localhost.localdomain) by web0081.zxcs.nl with esmtpsa (TLSv1.2:ECDHE-RSA-AES128-GCM-SHA256:128) (Exim 4.92.3) (envelope-from ) id 1jEEdK-001IGT-0t; Tue, 17 Mar 2020 16:59:58 +0100 From: Pascal Roeleven To: Thierry Reding , =?UTF-8?q?Uwe=20Kleine-K=C3=B6nig?= , Maxime Ripard , Chen-Yu Tsai , Philipp Zabel , linux-pwm@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Cc: linux-sunxi@googlegroups.com, Pascal Roeleven Subject: [RFC PATCH 2/4] pwm: sun4i: Disable pwm before turning off clock gate Date: Tue, 17 Mar 2020 16:59:04 +0100 Message-Id: <20200317155906.31288-3-dev@pascalroeleven.nl> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200317155906.31288-1-dev@pascalroeleven.nl> References: <20200317155906.31288-1-dev@pascalroeleven.nl> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Authenticated-Id: dev@pascalroeleven.nl Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The clock gate must stay on when disabling to ensure proper turning off. After one period it will still be disabled anyway. Signed-off-by: Pascal Roeleven --- drivers/pwm/pwm-sun4i.c | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/drivers/pwm/pwm-sun4i.c b/drivers/pwm/pwm-sun4i.c index 5c677c563..56942036b 100644 --- a/drivers/pwm/pwm-sun4i.c +++ b/drivers/pwm/pwm-sun4i.c @@ -292,13 +292,12 @@ static int sun4i_pwm_apply(struct pwm_chip *chip, struct pwm_device *pwm, else ctrl |= BIT_CH(PWM_ACT_STATE, pwm->hwpwm); - ctrl |= BIT_CH(PWM_CLK_GATING, pwm->hwpwm); - if (state->enabled) { ctrl |= BIT_CH(PWM_EN, pwm->hwpwm); + ctrl |= BIT_CH(PWM_CLK_GATING, pwm->hwpwm); } else { + /* Turn gate off after delay to ensure proper turning off */ ctrl &= ~BIT_CH(PWM_EN, pwm->hwpwm); - ctrl &= ~BIT_CH(PWM_CLK_GATING, pwm->hwpwm); } sun4i_pwm_writel(sun4i_pwm, ctrl, PWM_CTRL_REG); -- 2.20.1