Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp270130yba; Fri, 12 Apr 2019 03:15:29 -0700 (PDT) X-Google-Smtp-Source: APXvYqz39FtHaJIZa0XuGOKa9g05apBhnm3TNhFRIqL/VfajhiUkBqX9xuRSYCwNojUU4HgYyEG2 X-Received: by 2002:a65:4302:: with SMTP id j2mr50019905pgq.291.1555064129423; Fri, 12 Apr 2019 03:15:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1555064129; cv=none; d=google.com; s=arc-20160816; b=c0nYHmK/stPVnVWzs7bMNM/X7xu8rDEd4mfVeHrOV5n5RNVDiqhSucpjyyHihJHlSH qEq3QsuKQoggdBk//zl1igM3p1xILzWLBMj6Hil6Ib4XgL4DUCx8evHAM0QlXGF7FaiI +kZ/qqUn3FvriVGYWgy2xQkl6eUqDgXmk5PI2scTrwFKpHsDIJK2kkfTjYrU4SFyqtfT iL5bBI6A8nxI7qXqfjCY+0/MaIAC15Vw5sJMta4heass1NTqdCpeFw28VDiHVrFT/3AZ bqv0qKVYv5vJhV4PEU2AaHBImAK94+sPpQEUlWtix8jMRpvuV0CcLfP0RKrsDTPAfDlj F3tw== 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; bh=U6kK5aZ3tlNMMU/62sPtedhFGRqccFIkNmr+zR+jMfs=; b=vPX7AMwtLGs+vc76hIguYPjYMhyUF/c0/YNw9W/IcOVgtNbY9MaN7J6vg2480Fu9Oq nuEAid6bVK2pSorXvKMrXT35Pzvhyt8NkqIEtoNy9qYN4H9zyIO4UMuUGqpoG9MliZjS EgIPlcgGQhGBf4j7Xg1Fbd3BNyOrXfNgPyo+WNAIiahSGbHXe/CtUqf7jxwVCBxoAcx2 X2lFeum4bcACR8JGgbMNEbAjxDw9oKcc3uipDMyiCn6EmeD4+57HbbkCKNy9Fpe/IhBE /O4xlmSGDFGqVrAcke88oH5dGrUE9bPruL8jkJfK+dYE8Wd3gX/rwrPR8bbVlcXUjz+f Rw0g== ARC-Authentication-Results: i=1; mx.google.com; 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 a5si16950810pla.230.2019.04.12.03.15.13; Fri, 12 Apr 2019 03:15:29 -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; 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 S1726953AbfDLKOW (ORCPT + 99 others); Fri, 12 Apr 2019 06:14:22 -0400 Received: from relay6-d.mail.gandi.net ([217.70.183.198]:47449 "EHLO relay6-d.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726727AbfDLKOV (ORCPT ); Fri, 12 Apr 2019 06:14:21 -0400 X-Originating-IP: 109.213.223.232 Received: from localhost (alyon-652-1-80-232.w109-213.abo.wanadoo.fr [109.213.223.232]) (Authenticated sender: alexandre.belloni@bootlin.com) by relay6-d.mail.gandi.net (Postfix) with ESMTPSA id 019A7C0019; Fri, 12 Apr 2019 10:14:18 +0000 (UTC) Date: Fri, 12 Apr 2019 12:14:18 +0200 From: Alexandre Belloni To: Thomas Bogendoerfer Cc: Joshua Kinard , Alessandro Zummo , linux-rtc@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 3/3] rtc: ds1685: disable interrupts when moving work to work queue Message-ID: <20190412101418.GV3578@piout.net> References: <20190411143323.20945-1-tbogendoerfer@suse.de> <20190411143323.20945-3-tbogendoerfer@suse.de> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190411143323.20945-3-tbogendoerfer@suse.de> User-Agent: Mutt/1.11.3 (2019-02-01) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 11/04/2019 16:33:23+0200, Thomas Bogendoerfer wrote: > Handling of extended interrupts (kickstart, wake-up, ram-clear) is > moved off to a work queue, but the interrupts aren't acknowledged > in the interrupt handler. This leads to a deadlock, if driver > is used with interrupts. To fix this we now disable in irq handler > and re-enable it after work queue is done. > The correct fix to that seems to switch to a threaded interrupt handler. Can you do that? > Fixes: aaaf5fbf56f1 ("rtc: add driver for DS1685 family of real time clocks") > Signed-off-by: Thomas Bogendoerfer > --- > drivers/rtc/rtc-ds1685.c | 2 ++ > 1 file changed, 2 insertions(+) > > diff --git a/drivers/rtc/rtc-ds1685.c b/drivers/rtc/rtc-ds1685.c > index 929f28375b87..5dabfa57bd2a 100644 > --- a/drivers/rtc/rtc-ds1685.c > +++ b/drivers/rtc/rtc-ds1685.c > @@ -635,6 +635,7 @@ ds1685_rtc_irq_handler(int irq, void *dev_id) > * to be minimized. Schedule them into a workqueue > * and inform the RTC core that the IRQs were handled. > */ > + disable_irq_nosync(rtc->irq_num); > spin_unlock(&rtc->lock); > schedule_work(&rtc->work); > rtc_update_irq(rtc->dev, 0, 0); > @@ -741,6 +742,7 @@ ds1685_rtc_work_queue(struct work_struct *work) > ds1685_rtc_switch_to_bank0(rtc); > > mutex_unlock(rtc_mutex); > + enable_irq(rtc->irq_num); > } > /* ----------------------------------------------------------------------- */ > > -- > 2.13.7 > -- Alexandre Belloni, Bootlin Embedded Linux and Kernel engineering https://bootlin.com