Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp904018imm; Wed, 10 Oct 2018 06:13:00 -0700 (PDT) X-Google-Smtp-Source: ACcGV60NBkb9XCPNKiErYRxBxplyBfusPylhWSJVTPibGeTRdT/+bUgG9/q+A3V5X+4i3t5qPvog X-Received: by 2002:a63:6f45:: with SMTP id k66-v6mr28948746pgc.360.1539177180641; Wed, 10 Oct 2018 06:13:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539177180; cv=none; d=google.com; s=arc-20160816; b=jvX99s1C9CjW2ovgxZO6957N9Yy/uvRD+KpmHKLzvlK4iqnRBMqLeQZEciBC4Hffyp r2hCbpoKzl/h4mt2GvOfuGHwuZflngskTva6WXiPONrNnQOfHnzRmFs98svi3OTcE1ny rwOqSgoG5pEe22AaSqJ+sQa4VLq2r0EW7b7ktnxYQisDgdlZQRUlpFGNC9D/G/dwbo4o NJf6Rp/T0qy3gINGIrw19SCdZ7GQnsWo1LDwUW/uB3IdFZG4/LRoqlQqycTYqkmkMtwI iNvUaEvvgc3KWUVA9dXIkDZRyUeYH3sCBXMyJfS5jIlznTftWTQflzp3+adFXIH1M33m tmJQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=V1Or9IcvzPWoE3fjpS8sDUeLdeWlf74rJQF5TYKgC30=; b=tR0rx07obqUy50WdmaRBhbqzWDmogmV/ZeokqrKxr2N7nrY05pGL7oF1BSUkqWrxUo b4sIv+MA/PnRTrHsi+XchwyhjtB3f26VAbDw25qMrYzOHVJgjc3qMuPkV7vlnYrqS1rf WNpNQs9TGvbWlCPhwGy02JllMpjlQFPCW1tmnmLBJMBjOeWWEj32q9q+yoo8G1GpNSUs zWnpT9E21KKKnOo1N8e6yNVeHEfyAooWd8tdkxInXWAoobnWBZrPSSYrTB3nmoyUIDrQ xW+qiflx739NuuL9zR/TZJVrDRU2C/mh+67kgPmAL3s2IlRPwBVqEsLh8PwVi32ZFGwk s4Cw== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=nG8JEiXK; 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 t192-v6si22555309pgc.485.2018.10.10.06.12.45; Wed, 10 Oct 2018 06:13:00 -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=@infradead.org header.s=bombadil.20170209 header.b=nG8JEiXK; 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 S1727087AbeJJUdh (ORCPT + 99 others); Wed, 10 Oct 2018 16:33:37 -0400 Received: from bombadil.infradead.org ([198.137.202.133]:52164 "EHLO bombadil.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726206AbeJJUdh (ORCPT ); Wed, 10 Oct 2018 16:33:37 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20170209; h=In-Reply-To:Content-Type:MIME-Version :References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding: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=V1Or9IcvzPWoE3fjpS8sDUeLdeWlf74rJQF5TYKgC30=; b=nG8JEiXKat2wX9iutR968y2cA WicpTH3zWrGW9wzJ7Gep/kr8RQBRzNqTizlxUQTrIqm/EcNqNmH24Rm70dXnxnf7EzsUDWIhNEBBG LpDV8T/w4yCoZ2HcITw/2YWvCOVrwRXIfmJ9+dJxTQf3x3rmz44hpNcMsOtfiWPbr/mOI4OYJUBRY RZGwIsUZEHyvxqPAdVe7QADYE9U5i/KJlBm44ppRrSwrV/7XbjW3hA4qqsV8hrATTwzygIWbtVi6D 7e0V3G4tIN3zLlk1Ql5ieZlO2DTNK4NmRBu1j6TSUuDjX6fwszK/YSA1rrbOjRUmVIg/hijxu71Uo TKIq8JREQ==; Received: from hch by bombadil.infradead.org with local (Exim 4.90_1 #2 (Red Hat Linux)) id 1gAEGv-0001o7-6S; Wed, 10 Oct 2018 13:11:29 +0000 Date: Wed, 10 Oct 2018 06:11:29 -0700 From: Christoph Hellwig To: Atish Patra Cc: palmer@sifive.com, linux-riscv@lists.infradead.org, linux-pwm@vger.kernel.org, linux-gpio@vger.kernel.org, linus.walleij@linaro.org, robh+dt@kernel.org, thierry.reding@gmail.com, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, mark.rutland@arm.com, hch@infradead.org Subject: Re: [RFC 2/4] pwm: sifive: Add a driver for SiFive SoC PWM Message-ID: <20181010131128.GA29142@infradead.org> References: <1539111085-25502-1-git-send-email-atish.patra@wdc.com> <1539111085-25502-3-git-send-email-atish.patra@wdc.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1539111085-25502-3-git-send-email-atish.patra@wdc.com> User-Agent: Mutt/1.9.2 (2017-12-15) X-SRS-Rewrite: SMTP reverse-path rewritten from by bombadil.infradead.org. See http://www.infradead.org/rpr.html Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Thanks for getting these drivers submitted upstream! I don't really know anything about PWM, so just some random nitpicking below.. > + iowrite32(frac, pwm->regs + REG_PWMCMP0 + (dev->hwpwm * SIZE_PWMCMP)); * already has a higher precedence than +, so no need for the inner braces. > + duty = ioread32(pwm->regs + REG_PWMCMP0 + (dev->hwpwm * SIZE_PWMCMP)); Same here. > + /* (1 << (16+scale)) * 10^9/rate = real_period */ unsigned long scalePow = (pwm->approx_period * (u64)rate) / 1000000000; no camcel case, please. > + int scale = ilog2(scalePow) - 16; > + > + scale = clamp(scale, 0, 0xf); Why not: int scale = clamp(ilog2(scale_pow) - 16, 0, 0xf); > +static int sifive_pwm_clock_notifier(struct notifier_block *nb, > + unsigned long event, void *data) > +{ > + struct clk_notifier_data *ndata = data; > + struct sifive_pwm_device *pwm = container_of(nb, > + struct sifive_pwm_device, > + notifier); I don't think there are any guidlines, but I always prefer to just move the whole container_of onto a new line: struct sifive_pwm_device *pwm = container_of(nb, struct sifive_pwm_device, notifier); > +static struct platform_driver sifive_pwm_driver = { > + .probe = sifive_pwm_probe, > + .remove = sifive_pwm_remove, > + .driver = { > + .name = "pwm-sifivem", > + .of_match_table = of_match_ptr(sifive_pwm_of_match), > + }, > +}; What about using tabs to align this a little more nicely? static struct platform_driver sifive_pwm_driver = { .probe = sifive_pwm_probe, .remove = sifive_pwm_remove, .driver = { .name = "pwm-sifivem", .of_match_table = of_match_ptr(sifive_pwm_of_match), }, };