Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp425825pxf; Wed, 31 Mar 2021 06:57:52 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwmdUG17Jv54rKWp2y23yh3hxB/xOypnjDrW5nlTAfQ8uPUvpfxbBVek6G2uCP0xt8OZjUI X-Received: by 2002:aa7:df86:: with SMTP id b6mr3909456edy.294.1617199072065; Wed, 31 Mar 2021 06:57:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617199072; cv=none; d=google.com; s=arc-20160816; b=fuQjfhNsmycWy9Lj64bKl7hTCjHeREtEggw/VZJHEXAsrMBOeGtzGpnmNvl0B0nezr OvXKyq4gkwZYbebriDNcpfPM/D9C+Hl9S5HvGdz2on0ZNamkQdZyUdu5JK3Fyh91i3zY 4/cZegET8aQItb/+96d6bF8WNc7W/6HXkzOYaUhLegl30oI0TEf8m51M8dRX8TmJZj7Z pYZOT4Fj9Xik6N9SiA8UJZF18fkTFXuI4qG+AuYcyJy2Zbw6X5OiQjfFHclBwx4+7rhn XbnV+aaefbZpXvcznUb9CoRgkfTk/Rgn1R5n+E6GypOSLHiYLiCgJhWXDW1o3Ge5t2yR FzPA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-transfer-encoding :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=Y0xdWzFcCQq/5i4uMGqo4QBYg0zzLN54QQF0lLP/b2c=; b=UFaF/y13cecttgPfNIsBBRpIbxZ3uJrq/WneLgVxee4QonWzHPNyQIwbcY+B96PeK+ NlaTZk81C2/qYPHOMIfo418HIBJi7C0LZMrheIpzMMDjTsTdG4Yrk3yLqKq9V7ZpAR3e kYaqIvrsIF3CQJEVD9eiz2l0tnlFT2NjVQMGZJlcLWTTm2bqDK5VwvQ4mFxoxeExunSQ u5JiHfu5FtLQ/3VUMwCCLrr7DGM0JBoHka2qmV1Y17iP76jqko0kSLbMonG06o7M8031 6uO02Ueuku1PBMc2E1fqoRCLbDe16UwxROIYsmz64NbwqVCqfFdwfgDVDA35GACn0jhH W45A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@pqgruber.com header.s=mail header.b=cBVkNc1P; 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=REJECT sp=NONE dis=NONE) header.from=pqgruber.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w26si1550509ejn.699.2021.03.31.06.57.28; Wed, 31 Mar 2021 06:57:52 -0700 (PDT) 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=@pqgruber.com header.s=mail header.b=cBVkNc1P; 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=REJECT sp=NONE dis=NONE) header.from=pqgruber.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235787AbhCaN4F (ORCPT + 99 others); Wed, 31 Mar 2021 09:56:05 -0400 Received: from mail.pqgruber.com ([52.59.78.55]:49264 "EHLO mail.pqgruber.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235630AbhCaNzx (ORCPT ); Wed, 31 Mar 2021 09:55:53 -0400 Received: from workstation.tuxnet (213-47-165-233.cable.dynamic.surfer.at [213.47.165.233]) by mail.pqgruber.com (Postfix) with ESMTPSA id 0E61FC729F1; Wed, 31 Mar 2021 15:55:51 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=pqgruber.com; s=mail; t=1617198951; bh=Y0xdWzFcCQq/5i4uMGqo4QBYg0zzLN54QQF0lLP/b2c=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=cBVkNc1PYw5zKARifei1SZMMU9kLm4ZDmqL3O7m22xcVLp1X2hZ2erCnhy0EMuQmm qLp1YVOl1/tEoEaehSBkVvZ0FneFOqQDJp9MaxKcPoDmbnMXNrV0MswDBzf1croou8 nE9/VEMV9Jx5F4rZgiyDXS6UI76rxNkZhegZluBE= Date: Wed, 31 Mar 2021 15:55:49 +0200 From: Clemens Gruber To: Uwe =?iso-8859-1?Q?Kleine-K=F6nig?= Cc: linux-pwm@vger.kernel.org, Thierry Reding , Sven Van Asbroeck , linux-kernel@vger.kernel.org Subject: Re: [PATCH v6 4/7] pwm: pca9685: Support staggered output ON times Message-ID: References: <20210329125707.182732-1-clemens.gruber@pqgruber.com> <20210329125707.182732-4-clemens.gruber@pqgruber.com> <20210329170357.par7c3izvtmtovlj@pengutronix.de> <20210329180206.rejl32uajslpvbgi@pengutronix.de> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Mar 31, 2021 at 02:26:14PM +0200, Clemens Gruber wrote: > On Mon, Mar 29, 2021 at 08:02:06PM +0200, Uwe Kleine-K?nig wrote: > > On Mon, Mar 29, 2021 at 07:16:38PM +0200, Clemens Gruber wrote: > > > On Mon, Mar 29, 2021 at 07:03:57PM +0200, Uwe Kleine-K?nig wrote: > > > > On Mon, Mar 29, 2021 at 02:57:04PM +0200, Clemens Gruber wrote: > > > > > The PCA9685 supports staggered LED output ON times to minimize current > > > > > surges and reduce EMI. > > > > > When this new option is enabled, the ON times of each channel are > > > > > delayed by channel number x counter range / 16, which avoids asserting > > > > > all enabled outputs at the same counter value while still maintaining > > > > > the configured duty cycle of each output. > > > > > > > > > > Signed-off-by: Clemens Gruber > > > > > > > > Is there a reason to not want this staggered output? If it never hurts I > > > > suggest to always stagger and drop the dt property. > > > > > > There might be applications where you want multiple outputs to assert at > > > the same time / to be synchronized. > > > With staggered outputs mode always enabled, this would no longer be > > > possible as they are spread out according to their channel number. > > > > > > Not sure how often that usecase is required, but just enforcing the > > > staggered mode by default sounds risky to me. > > > > There is no such guarantee in the PWM framework, so I don't think we > > need to fear breaking setups. Thierry? > > Still, someone might rely on it? But let's wait for Thierry's opinion. > > > > > One reason we might not want staggering is if we have a consumer who > > cares about config transitions. (This however is moot it the hardware > > doesn't provide sane transitions even without staggering.) > > > > Did I already ask about races in this driver? I assume there is a > > free running counter and the ON and OFF registers just define where in > > the period the transitions happen, right? Given that changing ON and OFF > > needs two register writes probably all kind of strange things can > > happen, right? (Example thought: for simplicity's sake I assume ON is > > always 0. Then if you want to change from OFF = 0xaaa to OFF = 0xccc we > > might see a period with 0xacc. Depending on how the hardware works we > > might even see 4 edges in a single period then.) > > Yes, there is a free running counter from 0 to 4095. > And it is probably true, that there can be short intermediate states > with our two register writes. > > There is a separate mode "Update on ACK" (MODE2 register, bit 3 "OCH"), > which is 0 by default (Outputs change on STOP command) but could be set > to 1 (Outputs change on ACK): > "Update on ACK requires all 4 PWM channel registers to be loaded before > outputs will change on the last ACK." This would require the auto-increment feature to be enabled, then multiple registers could be written before the STOP condition: LEDn_ON_L, LEDn_ON_H, LEDn_OFF_L & LEDn_OFF_H (With OCH=0 in MODE2) But I think this should be done in a separate improvement patch/series to reduce glitches. > The chip datasheet also states: > "Because the loading of the LEDn_ON and LEDn_OFF registers is via the > I2C-bus, and asynchronous to the internal oscillator, we want to ensure > that we do not see any visual artifacts of changing the ON and OFF > values. This is achieved by updating the changes at the end of the LOW > cycle." > > We could look into this in a future patch series, however I would like > to keep the register updating as-is for this series (otherwise I would > have to do all the tests with the oscilloscope again and the transitions > were like this since the driver was first implemented). > > Thanks, > Clemens