Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp1304538imm; Fri, 12 Oct 2018 15:51:31 -0700 (PDT) X-Google-Smtp-Source: ACcGV60tTZM8EkN9b4nzhnw+vw042gZy/qUTNYrPkRGhGPqaVqP6keOPSeeHANglpcNsji03yot9 X-Received: by 2002:a17:902:b581:: with SMTP id a1-v6mr7625708pls.126.1539384691893; Fri, 12 Oct 2018 15:51:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539384691; cv=none; d=google.com; s=arc-20160816; b=Po0B2xnOOHw3wvPIvSTP+PvACZ5USZCVkEIrFqt3nidEdlmjj/biIyiRlFWA0ooonR MZf2yHwMMc2En0y4gP8MxmsfpgG6/qGH6YGpcGNmUdfVzv5GhrvTN0VZVlymlkGT8AYX R5IFCBx8FLx0qWpgbauhEWhouiXEIil7mEpG/6qhdNrwBR5aI2Swgqrx/S+yQ0wOl+Zn 8qG+/ABEqd7ZFj0OHQecYCETFnjM6Q8JwkCQhvkzxim5LWKYsoA029m7o+tVEAv8GBxK uwBnZ49SvrEuo8Z5UUzfzV8u6mVEtwVEYkA928U/mJzd+DUhGgdd4rXSXyywPgABu4nm DTDA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=PXPxEAFa7PXaYax53wsECKglwtEFxrchOWzNfu1zeoo=; b=GYEQ/luDmUGFXWwAP1v5dFAwT4SoK7li9/xwuENF8WXelqYXoKLUxbtfiKujelob4u yUmze092QI6fklJqOiYEQLTPfmCPdQsqkKs9eHJ8z2UQnIBOUYCuGjQX1k6586fQtnPH YkiCZ64j+XiZTGmtnT689SbYcK+PpZZQgCbD6q+nQ2JVL3kUldIuZyNFBHT+I2n+0iug sPd2ZFN5hUg+nDelOF/1mDO4w4zATs7HKxH3IJ8X/+T1iylUux4Ce2Kr1dEwutSFozzW XgAixFIDyOrIdxEk103m0RhmFDWynMTMbaMBYkoPz3I/+ziOMg0m1VdhzAYH3sidSv89 ZPcQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=BXUmM2jJ; 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=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c19-v6si2496518plo.357.2018.10.12.15.51.16; Fri, 12 Oct 2018 15:51:31 -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=pass header.i=@chromium.org header.s=google header.b=BXUmM2jJ; 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=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726017AbeJMGZa (ORCPT + 99 others); Sat, 13 Oct 2018 02:25:30 -0400 Received: from mail-vs1-f68.google.com ([209.85.217.68]:44094 "EHLO mail-vs1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725785AbeJMGZa (ORCPT ); Sat, 13 Oct 2018 02:25:30 -0400 Received: by mail-vs1-f68.google.com with SMTP id w194so13184438vsc.11 for ; Fri, 12 Oct 2018 15:50:52 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=PXPxEAFa7PXaYax53wsECKglwtEFxrchOWzNfu1zeoo=; b=BXUmM2jJQ2uW8Gj2Ya3t/5qmWfN1EJd0SbsnNK22F8xonPRR4XHX/LVhLcv7m/mtOE alPJv6tmR3Zv8wEivkes9FDPmOC56qBGLSFMMQcefm7VxjCJZSR77xY53qIV1KZRUQG7 6vvKK53tvk/Y7qoxe0urqmU1a3NETt5+DGa6E= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=PXPxEAFa7PXaYax53wsECKglwtEFxrchOWzNfu1zeoo=; b=abButgROCQR4OWwjS0LRoBPwFEJDdEU/Y9OU6P/1JqKGuntLgFhy6bcd+5XNoNSce1 +tsEM0Gl+o+8WF1+9vHkBAK9ZGPHtrYb18Du7ICrbSC/hPdrcpvYKuUf8gPHW8vp68zX xFL3JiV17gi/iwIBqLp4NADbViCJ27DzKn1iMr0AyfwVSuXs7B8bnZuP9Ng1T3pYaDmr 6yBIeAQyIrOBi/QdHEMS3pHHzcHi8Swq50zW44Ysz7dJRJAvHAgL9Z6iT9tJAZhfV5R4 tqc20xB8G0FBpu/V6ERJEjZt2SAuJBJUCuj2Gvjfgxi3RGGga8WwZolP76CjprQtjD2h 8whA== X-Gm-Message-State: ABuFfohB9oCaoO95MjsxsDlLRVjkkzxokFZTJ3uK0iEsBGL4homW2Qu5 Xhb2o9q4Fit6vtPMeOeBO9ouwCQlhYs= X-Received: by 2002:a67:e28f:: with SMTP id g15mr3220873vsf.115.1539384651891; Fri, 12 Oct 2018 15:50:51 -0700 (PDT) Received: from mail-vs1-f44.google.com (mail-vs1-f44.google.com. [209.85.217.44]) by smtp.gmail.com with ESMTPSA id x197sm630587vsc.3.2018.10.12.15.50.50 for (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 12 Oct 2018 15:50:51 -0700 (PDT) Received: by mail-vs1-f44.google.com with SMTP id c10so13216107vsk.2 for ; Fri, 12 Oct 2018 15:50:50 -0700 (PDT) X-Received: by 2002:a67:7988:: with SMTP id u130mr1477223vsc.119.1539384650320; Fri, 12 Oct 2018 15:50:50 -0700 (PDT) MIME-Version: 1.0 References: <1537770516-28410-1-git-send-email-sayalil@codeaurora.org> <1537770516-28410-2-git-send-email-sayalil@codeaurora.org> In-Reply-To: <1537770516-28410-2-git-send-email-sayalil@codeaurora.org> From: Doug Anderson Date: Fri, 12 Oct 2018 15:50:37 -0700 X-Gmail-Original-Message-ID: Message-ID: Subject: Re: [PATCH V14 1/2] scsi: ufs: set the device reference clock setting To: sayalil@codeaurora.org Cc: subhashj@codeaurora.org, cang@codeaurora.org, Vivek Gautam , Rajendra Nayak , Vinayak Holikatti , jejb@linux.vnet.ibm.com, "Martin K. Petersen" , Asutosh Das , Evan Green , riteshh@codeaurora.org, stummala@codeaurora.org, Adrian Hunter , jlbec@evilplan.org, linux-scsi@vger.kernel.org, LKML Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, On Sun, Sep 23, 2018 at 11:29 PM Sayali Lokhande wrote: > +static struct ufs_ref_clk ufs_ref_clk_freqs[] = { > + {19200000, REF_CLK_FREQ_19_2_MHZ}, > + {26000000, REF_CLK_FREQ_26_MHZ}, > + {38400000, REF_CLK_FREQ_38_4_MHZ}, > + {52000000, REF_CLK_FREQ_52_MHZ}, > + {0, REF_CLK_FREQ_INVAL}, > +}; > + > +static inline enum ufs_ref_clk_freq Please don't specify inline. Let the compiler decide whether inline is better. > +ufs_get_bref_clk_from_hz(u32 freq) > +{ > + int i = 0; > + > + while (ufs_ref_clk_freqs[i].freq_hz != freq) { > + if (!ufs_ref_clk_freqs[i].freq_hz) > + return REF_CLK_FREQ_INVAL; > + i++; > + } > + > + return ufs_ref_clk_freqs[i].val; I think you'll have less confusion if you write the above as this (untested): for (i = 0; ufs_ref_clk_freqs[i].freq_hz; i++) { if (ufs_ref_clk_freqs[i].freq_hz == freq) return ufs_ref_clk_freqs[i].val; } return REF_CLK_FREQ_INVAL; Now it looks like a normal iteration till a normal stop condition (NULL term array). > +void ufshcd_parse_dev_ref_clk_freq(struct ufs_hba *hba) Shouldn't this return an error code so that if there's a problem it can return back to the caller? Right now you print error messages but ufshcd_pltfrm_init() will plow merrily along after. > +{ > + struct device *dev = hba->dev; > + struct device_node *np = dev->of_node; > + struct clk *refclk = NULL; > + u32 freq = 0; "freq" should be "unsigned long" to match clk_get_rate(), not u32. Similarly all the places you pass it to and store it in should be "unsigned long" too. Save "u32" for values which are being programmed into 32-bit hardware registers. > + if (!np) > + return; You don't need to check for (!np). If you do clk_get() and there's no np you'll get get an error back. Handle it there. > + > + refclk = of_clk_get_by_name(np, "ref_clk"); > + if (!refclk) > + return; I can't quickly tell. Are you intending "ref_clk" to be optional or required? You check against "NULL" and return with no error message, so I'm kinda assuming it's optional. ...but: 1. of_clk_get_by_name() doesn't return NULL when the clock wasn't specified. It returns "-ENOENT". That means that (right now) anyone who doesn't specify a "ref_clk" will get a crash when you try calling clk_get_rate() on the error-code-clk. 2. It seems like it would be good to add a comment that "dev_ref_clk_freq" was already initted to "REF_CLK_FREQ_INVAL in ufshcd_alloc_host() to make it obvious how people are working that didn't specify "ref_clk". One note is that regardless of whether "ref_clk" is optional or required, something about "ref_clk" should be mentioned in "Documentation/devicetree/bindings/ufs/ufshcd-pltfrm.txt" so people know that's an important clock name. Yet another note here is that I'm confused why you'd want to use of_clk_get_by_name(). Why not use clk_get()? You've already got the "dev" node and clk_get() should be preferred since not everyone uses device tree. OK, one last note is that clk_get() could return -EPROBE_DEFER. In such a case you need to basically cancel your whole probe and propagate the -EPROBE_DEFER. Make sure you think about that when you're coding things up. OK, I lied about the previous one being the last note. Why don't you just add a bit of code in the ufshcd_init_clocks() loop. If you notice that the clock name is "ref_clk" (similar to how __ufshcd_setup_clocks() checks) then you can grab the frequency. Then you can avoid dealing with all my comments above about of_clk_get_by_name() and errors and -EPROBE_DEFER... > + freq = clk_get_rate(refclk); > + > + hba->dev_ref_clk_freq = > + ufs_get_bref_clk_from_hz(freq); > + > + if (hba->dev_ref_clk_freq == REF_CLK_FREQ_INVAL) > + dev_err(hba->dev, > + "%s: invalid ref_clk setting = %d\n", > + __func__, freq); nit: including "__func__" in dev_xxx() calls is discouraged. The "dev_xxx" calls already print the device name and the string within a given device driver should be unique enough so __func__ just adds crap to the logs. If you really feel that __func__ adds something for you, try posting up a patch to make all "dev_err" functions include __func__. ...but I think you'd probably be rejected. Also (more important): You're missing a clk_put(). Thus you're leaking a reference to "ref_clk". > +} > + > +static int ufshcd_set_dev_ref_clk(struct ufs_hba *hba) > +{ > + int err, ref_clk = -1; > + u32 freq = hba->dev_ref_clk_freq; Ugh, this is ugly. hba->dev_ref_clk_freq could be -1 but you're jamming it into a u32 here. That doesn't seem so ideal. Are you sure -1 was the best choice for REF_CLK_FREQ_INVAL? > + > + err = ufshcd_query_attr_retry(hba, UPIU_QUERY_OPCODE_READ_ATTR, > + QUERY_ATTR_IDN_REF_CLK_FREQ, 0, 0, &ref_clk); It's not so wonderful to be passing a pointer to an "int" to a function expecting a pointer to a "u32". Change "ref_clk" to "u32". > + > + if (err) { > + dev_err(hba->dev, "%s: failed reading bRefClkFreq. err = %d\n", > + __func__, err); Again, no __func__. > + goto out; > + } > + > + if (ref_clk == hba->dev_ref_clk_freq) nit: you already cached "hba->dev_ref_clk_freq in "freq". Use it. > + goto out; /* nothing to update */ > + > + err = ufshcd_query_attr_retry(hba, UPIU_QUERY_OPCODE_WRITE_ATTR, > + QUERY_ATTR_IDN_REF_CLK_FREQ, 0, 0, &freq); > + > + if (err) { > + dev_err(hba->dev, "%s: bRefClkFreq setting to %u Hz failed\n", > + __func__, ufs_ref_clk_freqs[freq].freq_hz); Again, no __func__. > + goto out; > + } > + > + dev_dbg(hba->dev, "%s: bRefClkFreq setting to %u Hz succeeded\n", > + __func__, ufs_ref_clk_freqs[freq].freq_hz); Again, no __func__.