Received: by 2002:a25:d7c1:0:0:0:0:0 with SMTP id o184csp1353336ybg; Fri, 18 Oct 2019 16:33:28 -0700 (PDT) X-Google-Smtp-Source: APXvYqwPsB/GoaogIlhsrPEa1UNUymP4pc16KzS0Tjqg/q1ms8zxQUqvH+rBkhrt9zvWylWEEknT X-Received: by 2002:a17:906:27c5:: with SMTP id k5mr11051768ejc.173.1571441608458; Fri, 18 Oct 2019 16:33:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1571441608; cv=none; d=google.com; s=arc-20160816; b=yEtvLef6G3TOc4PQrF8CqmgCL0ufWvULjH2a7NYtF1+EzmvIxAxBu20tsCYVDslRB8 4N+VHs+WHaHg2JGurg79RJzi8otWvFjwT//dZB6whtoKatB3UrAMJFH9UOkvxeo8xRut vIwuPDE3GSoBckvSuMF+IuweQPMIhSMhrFGATGyI7FXdqsV7kuvQnBUmEWm5m9t2CwSJ 3GHFTikMOx9TXSccbuGpRHOAemE3+udLIbBJHyE5dB7YytZJJayoQ1UsKsAwrSDWwuAz 9xV+To/MOiGKg2+v9fPk94vLLKmi3HIYlRm2bnL/ZnJyepW9rLf9B1TP6t4ZsaalHWD2 rUEw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:message-id:references :in-reply-to:subject:cc:to:from:date:content-transfer-encoding :mime-version:dkim-signature:dkim-signature; bh=2AYdINke4gWUrFy0mMZcOd9mIo07Yy+WXtLgctTYpw0=; b=hpYuOMRUjeazvyCuS0rC1lxIjktwhs4jrh26xsCvB30l1f0skD2FE/KdfQw3ZkmcUS U5OQqq03V3WnGgYpfrDCEnqnwnqKgnxCHVh2uUJGqjwCIPyGLET35eoWExEvOtX5KpLy mRXPb84FMB49oiMitDI1emjYqIN4tHg6mf0OlUt+UiTaHwcxRT3qRQcvrnLBTQAYZBa5 8w9fkLo3hZWsUVQxxqQRUPIs9QXW99LAhE+7B/bjP0v3rsrYYkco9bt2If1FdfsYa9xg EcYM1bm6xPEK5eF2T9d0t3pnuqGjlOVZ2YaAbeyt1A2iFJPOhD7gDDHd5Xn0o0f5G8RA lkUg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=XXpUDtHD; dkim=pass header.i=@codeaurora.org header.s=default header.b=gW0PUImE; 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 dv21si4359435ejb.241.2019.10.18.16.33.05; Fri, 18 Oct 2019 16:33:28 -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=@codeaurora.org header.s=default header.b=XXpUDtHD; dkim=pass header.i=@codeaurora.org header.s=default header.b=gW0PUImE; 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 S2407449AbfJRGm7 (ORCPT + 99 others); Fri, 18 Oct 2019 02:42:59 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:46322 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2393594AbfJRGm6 (ORCPT ); Fri, 18 Oct 2019 02:42:58 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 4EDDF610DC; Fri, 18 Oct 2019 06:42:57 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1571380977; bh=6TBlAdKQKJ2jvjGwgvWVKyvODqXx7MA+HnxHF0EkO/M=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=XXpUDtHDTlxK4+UvWEa/J0kS0HjwY2zBjFYE7YpXGJAmogZBuItNCDKOCCoKd9sHw j7laQYY1fc5Ie3Od2WNektEtPV7W7lVx9ovF5SOUdgYCEtFWEh42yQx1tkvgbpiQuc 9Q51u31cVnJSq1RadpOrTop88nLPI8gLZWDhFCiw= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.7 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_INVALID,DKIM_SIGNED autolearn=no autolearn_force=no version=3.4.0 Received: from mail.codeaurora.org (localhost.localdomain [127.0.0.1]) by smtp.codeaurora.org (Postfix) with ESMTP id 51E72610DC; Fri, 18 Oct 2019 06:42:56 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1571380976; bh=6TBlAdKQKJ2jvjGwgvWVKyvODqXx7MA+HnxHF0EkO/M=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=gW0PUImE+THwnpgh1sMlgBvC+wHvJgH2dfUwZPnMJQ7NXR8nLTHYG6kMHd7zke0fQ jsf4OF79koepY/K+yoYiF204JVVpAVxDfkKQO1EgSXeOjt2EQ9YxVRfGLagD86Oa+W CjGLZ6+0LYrwcuBryQpPZXdoJgNDTOYZwxCrAF/s= MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII; format=flowed Content-Transfer-Encoding: 7bit Date: Fri, 18 Oct 2019 12:12:56 +0530 From: kgunda@codeaurora.org To: Daniel Thompson Cc: bjorn.andersson@linaro.org, jingoohan1@gmail.com, lee.jones@linaro.org, b.zolnierkie@samsung.com, dri-devel@lists.freedesktop.org, jacek.anaszewski@gmail.com, pavel@ucw.cz, robh+dt@kernel.org, mark.rutland@arm.com, linux-leds@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Andy Gross , linux-arm-msm@vger.kernel.org, linux-fbdev@vger.kernel.org, linux-arm-msm-owner@vger.kernel.org Subject: Re: [PATCH V7 6/6] backlight: qcom-wled: Add auto string detection logic In-Reply-To: <20191017133954.7vgqjgwxojmjw446@holly.lan> References: <1571220826-7740-1-git-send-email-kgunda@codeaurora.org> <1571220826-7740-7-git-send-email-kgunda@codeaurora.org> <20191017112941.qqvgboyambzw63i3@holly.lan> <20191017133954.7vgqjgwxojmjw446@holly.lan> Message-ID: X-Sender: kgunda@codeaurora.org User-Agent: Roundcube Webmail/1.2.5 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2019-10-17 19:09, Daniel Thompson wrote: > On Thu, Oct 17, 2019 at 05:47:47PM +0530, kgunda@codeaurora.org wrote: >> On 2019-10-17 16:59, Daniel Thompson wrote: >> > On Wed, Oct 16, 2019 at 03:43:46PM +0530, Kiran Gunda wrote: >> > > The auto string detection algorithm checks if the current WLED >> > > sink configuration is valid. It tries enabling every sink and >> > > checks if the OVP fault is observed. Based on this information >> > > it detects and enables the valid sink configuration. >> > > Auto calibration will be triggered when the OVP fault interrupts >> > > are seen frequently thereby it tries to fix the sink configuration. >> > > >> > > The auto-detection also kicks in when the connected LED string >> > > of the display-backlight malfunctions (because of damage) and >> > > requires the damaged string to be turned off to prevent the >> > > complete panel and/or board from being damaged. >> > > >> > > Signed-off-by: Kiran Gunda >> > >> > It's a complex bit of code but I'm OK with it in principle. Everything >> > below is about small details and/or nitpicking. >> > >> > >> > > +static void wled_ovp_work(struct work_struct *work) >> > > +{ >> > > + struct wled *wled = container_of(work, >> > > + struct wled, ovp_work.work); >> > > + enable_irq(wled->ovp_irq); >> > > +} >> > > + >> > >> > A bit of commenting about why we have to wait 10ms before enabling the >> > OVP interrupt would be appreciated. >> > >> > >> Sure. Will add the comment in the next series. >> > > +static irqreturn_t wled_ovp_irq_handler(int irq, void *_wled) >> > > +{ >> > > + struct wled *wled = _wled; >> > > + int rc; >> > > + u32 int_sts, fault_sts; >> > > + >> > > + rc = regmap_read(wled->regmap, >> > > + wled->ctrl_addr + WLED3_CTRL_REG_INT_RT_STS, &int_sts); >> > > + if (rc < 0) { >> > > + dev_err(wled->dev, "Error in reading WLED3_INT_RT_STS rc=%d\n", >> > > + rc); >> > > + return IRQ_HANDLED; >> > > + } >> > > + >> > > + rc = regmap_read(wled->regmap, wled->ctrl_addr + >> > > + WLED3_CTRL_REG_FAULT_STATUS, &fault_sts); >> > > + if (rc < 0) { >> > > + dev_err(wled->dev, "Error in reading WLED_FAULT_STATUS rc=%d\n", >> > > + rc); >> > > + return IRQ_HANDLED; >> > > + } >> > > + >> > > + if (fault_sts & >> > > + (WLED3_CTRL_REG_OVP_FAULT_BIT | WLED3_CTRL_REG_ILIM_FAULT_BIT)) >> > > + dev_dbg(wled->dev, "WLED OVP fault detected, int_sts=%x >> > > fault_sts= %x\n", >> > > + int_sts, fault_sts); >> > > + >> > > + if (fault_sts & WLED3_CTRL_REG_OVP_FAULT_BIT) { >> > > + mutex_lock(&wled->lock); >> > > + disable_irq_nosync(wled->ovp_irq); >> > >> > We're currently running the threaded ISR for this irq. Do we really need >> > to disable it? >> > >> We need to disable this IRQ, during the auto string detection logic. >> Because >> in the auto string detection we configure the current sinks one by one >> and >> check the >> status register for the OVPs and set the right string configuration. >> We >> enable it later after >> the auto string detection is completed. > > This is a threaded oneshot interrupt handler. Why isn't the framework > masking sufficient for you here? > > > Daniel. Right .. I overlooked that it is a oneshot interrupt earlier. I will address it in the next series.