Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp954422pxk; Fri, 25 Sep 2020 02:15:44 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwEbqFajjFxqcaNuV7OjM4aLkWdU/aet8/1AE1nAnCGr2xKkzr+tbnGfzlFtFZHNn7pXzpb X-Received: by 2002:a17:906:7f06:: with SMTP id d6mr1668705ejr.553.1601025344167; Fri, 25 Sep 2020 02:15:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601025344; cv=none; d=google.com; s=arc-20160816; b=MNZIZykMwRLJ4RSuXTsF1zhfMx25oaWMewaJ0HJJHjW4u8o3GAR7pz51Nx4BnSr1I1 xK95QL/vj2bru9n4Jsc/sa1d2LlUWbchgQmtOzjNe9rAaTTPTL2+NP8W2/Ue+2PSluX4 wHV9DKW7natEnoIJeyupjKOTNi8as5FjEWBLWNoCGCTXDMkThXUCxykqfJLJCT6ZO/4p tT//hCIUTaAN5pv6zlCbbukqQumj7cMHAPMC0+UJXGoSFDF9jU5Bz06WyhlABifOprmz R7ByeNwUiKsw0C6ield4sz/VeJ9XIi/r/gri5zi7QU3pwrxTpBzVO21mpmvjV9KB3EJh lAwA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:in-reply-to:subject :cc:to:from:user-agent:references:dkim-signature; bh=EINwdvc62tASjwpRJVndiLCvvVKWaOgZRLx0lxHJGdk=; b=ljrjyqw20oby2kUuugsMU8XmVcX2yrNRAr4DbNreDTkqaXwJGJ9ArOSe6Ui2lOM19I Pjgm7SBPDNOyFjrkYhN2rJZduXDSZfJ1H/RsilOIoHRGAmfQizfqSlH5xQBdkWhBedhI yEnSj8rcWCB1CKZWfQOi0Ss3gkbsSPTTSs29XvYpaVecerxaKEOPptU5DnB0pXHTvduL rLIOM2bEZ81MFkN0TXDWy21fntStBkk14EkiNfoxENp4puabLskMbGmIQk1EERct4B+K mtQ50ZBZqqb0JDMoAwc28hLnJMoQH0Wzk4uFiusTgefNEClFt+feDRImH+eySU0FxUdP Y/Qg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=DvuhcIhN; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id o4si1408666eje.545.2020.09.25.02.15.20; Fri, 25 Sep 2020 02:15:44 -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=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=DvuhcIhN; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727856AbgIYJLq (ORCPT + 99 others); Fri, 25 Sep 2020 05:11:46 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:32938 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727749AbgIYJLp (ORCPT ); Fri, 25 Sep 2020 05:11:45 -0400 Received: from mail-ej1-x643.google.com (mail-ej1-x643.google.com [IPv6:2a00:1450:4864:20::643]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 81B65C0613D4 for ; Fri, 25 Sep 2020 02:11:45 -0700 (PDT) Received: by mail-ej1-x643.google.com with SMTP id z23so2586771ejr.13 for ; Fri, 25 Sep 2020 02:11:45 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20150623.gappssmtp.com; s=20150623; h=references:user-agent:from:to:cc:subject:in-reply-to:date :message-id:mime-version; bh=EINwdvc62tASjwpRJVndiLCvvVKWaOgZRLx0lxHJGdk=; b=DvuhcIhNXBHXC334WLX00vfEFn96hpowAqa9NMof2QJfUe1SjYf+qgDyay7PihvEfa +Ne60c2JdxHEx5vqRl3r8SXZ9SOvXQzSVKMMhih9rabjBs26Sb4XOLQW6bt8H80rGIhD wN/oNtgtQmBbkOOca7lNc11ukpfbBjB7uImCLFIL5GZGNdx3aUQyTR02VsquFHzkWEJG Zbwl8jE8WNVSRBSWFDs6ZBmW/VfGORc5dEdx00GxT5CwrsUQEgZEn4Bhcxeg16tAX5oQ V3FmKPR8u6FAHm8DlAZCPQNXFw9xcQUOagHEgiOmEEp2ijY/riZUv3lFs9Z8KzHydV86 CcWg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:references:user-agent:from:to:cc:subject :in-reply-to:date:message-id:mime-version; bh=EINwdvc62tASjwpRJVndiLCvvVKWaOgZRLx0lxHJGdk=; b=KRIR7OAJA4bHIcKY1nW0LIFKwejla1/GodL68nKlZ+a1mFcFQBSUs4OYCELBBZeu94 ufk2f5a0U+sLF0chbZ45C34vjovp29Q5x9iTcc2BOMM10ghC6PNmchpSOWBILauXPU0M 1W6jDZNScEZ/W6HbocwkFURfreZOh4s21JzAiutwgvedp/JYfL8XShmDVCS1SeWjR7M7 YjI4NRtbEFq7Bmsn7bU6yh3HcllCnAWsaV1hKMxMSbrUWn8Va5+6o0b4yGIX7SIdm1Pq WlYUljCLIHou8oHjzm+eee4zBvppOhaAEvbRLJi8NdxB7Qgz8OSU8zeTQxvb+078j4xI v2AA== X-Gm-Message-State: AOAM531BWXgylWlcN4ElESBwXPpCx9ffBfyakeIVvolaEqlGROtqx6Da CxZMTq1tmPYkblJ79uP5zdHphA== X-Received: by 2002:a17:906:abc5:: with SMTP id kq5mr1707113ejb.284.1601025104165; Fri, 25 Sep 2020 02:11:44 -0700 (PDT) Received: from localhost (cag06-3-82-243-161-21.fbx.proxad.net. [82.243.161.21]) by smtp.gmail.com with ESMTPSA id i26sm1371709edq.47.2020.09.25.02.11.43 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 25 Sep 2020 02:11:43 -0700 (PDT) References: <24a844c3-c2e0-c735-ccb7-83736218b548@gmail.com> <7hk0wj9ki2.fsf@baylibre.com> User-agent: mu4e 1.3.3; emacs 26.3 From: Jerome Brunet To: Kevin Hilman , Brad Harper , linux-amlogic@lists.infradead.org, linux-mmc@vger.kernel.org Cc: linux-rt-users@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] mmc: host: meson-gx-mmc: fix possible deadlock condition for preempt_rt In-reply-to: <7hk0wj9ki2.fsf@baylibre.com> Date: Fri, 25 Sep 2020 11:11:42 +0200 Message-ID: <1jzh5e8bld.fsf@starbuckisacylon.baylibre.com> MIME-Version: 1.0 Content-Type: text/plain Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu 24 Sep 2020 at 19:01, Kevin Hilman wrote: > Hi Brad, > > Brad Harper writes: > >> Force threaded interrupts for meson_mmc_irq to prevent possible deadlock >> condition >> during mmc operations when using preempt_rt with 5.9.0-rc3-rt3 patches >> on arm64. >> >> Using meson-gx-mmc with an emmc device on Hardkernel Odroid N2+ >> configured with >> preempt_rt resulted in the soc becoming unresponsive. With lock >> checking enabled >> the below inconsistent lock state was observed during boot. >> >> After some discussions with tglx in IRC #linux-rt the attached patch was >> suggested >> to remove IRQF_ONESHOT from request_threaded_irq. >> This has been tested and confirmed by me to resolve both the >> unresponsive soc and >> the inconsistent lock state warning when using 5.9.0-rc3-rt3 on arm64 >> Odroid N2+. >> >> Further review and testing is required to ensure there are no adverse >> impacts or >> concerns and that is the correct method to resolve the problem. I will >> continue >> to test on various amlogic devices with both standard mainline low >> latency kernel >> and preempt_rt kernel with -rt patches. > > This looks right to me, thanks for sending a fix. > > For broader testing, I can add this to my testing branch so it gets > booted on a bunch more platform in KernelCI also. > > However... > > [...] > >> Signed-off-by: Brad Harper >> --- >> drivers/mmc/host/meson-gx-mmc.c | 2 +- >> 1 file changed, 1 insertion(+), 1 deletion(-) >> >> diff --git a/drivers/mmc/host/meson-gx-mmc.c >> b/drivers/mmc/host/meson-gx-mmc.c >> index 08a3b1c05..130ac134d 100644 >> --- a/drivers/mmc/host/meson-gx-mmc.c >> +++ b/drivers/mmc/host/meson-gx-mmc.c >> @@ -1139,7 +1139,7 @@ static int meson_mmc_probe(struct platform_device >> *pdev) >> host->regs + SD_EMMC_IRQ_EN); >> >> ret = request_threaded_irq(host->irq, meson_mmc_irq, >> - meson_mmc_irq_thread, IRQF_ONESHOT, >> + meson_mmc_irq_thread, 0, >> dev_name(&pdev->dev), host); I'm not sure about this. As you have explained on IRC, I understand that IRQF_ONESHOT is causing trouble with RT as the hard IRQ part of the thread will not be migrated to a thread. That was certainly not the intent when putting this flag. As described in include/linux/interrupt.h: * IRQF_ONESHOT - Interrupt is not reenabled after the hardirq handler finished. * Used by threaded interrupts which need to keep the * irq line disabled until the threaded handler has been run. The intent was only that, making sure the irq is not re-enabled until the threaded part is done. AFAIU, removing this flag would allow the hard irq handler to fire again while we are not done handling the previous IRQ in threaded part. This seems pretty unsafe to me. Maybe we could improve the driver so it copes with this case gracefully. ATM, I don't think it would. Maybe I missed something and I am happy to be enlightened if that is the case :) >> if (ret) >> goto err_init_clk; > > This patch has been mangled by your mailer, so it doesn't apply cleanly. > If you're using the gmail web UI, this is a common problem. > > I strongly recommend using git-send-email to send directly via gmail > SMTP. The git-send-email docs[1] give some examples on how to set this > up. > > Kevin > > [1] https://git-scm.com/docs/git-send-email#_examples > > _______________________________________________ > linux-amlogic mailing list > linux-amlogic@lists.infradead.org > http://lists.infradead.org/mailman/listinfo/linux-amlogic