Received: by 2002:a05:6358:16cc:b0:ea:6187:17c9 with SMTP id r12csp736855rwl; Sun, 25 Dec 2022 06:13:57 -0800 (PST) X-Google-Smtp-Source: AMrXdXuNIIvF5INlqO1K7Hj9deoKSPEMjCofcGQZ+j//iUZopMaOwx4Q0nJWhSRkwA7wgu9D42NR X-Received: by 2002:a17:90a:c90d:b0:225:d280:5e12 with SMTP id v13-20020a17090ac90d00b00225d2805e12mr7748380pjt.43.1671977637040; Sun, 25 Dec 2022 06:13:57 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1671977637; cv=none; d=google.com; s=arc-20160816; b=rumZXb02BzoqluGDk/aV7Zdyld3jMC55scKJbFxiEdny9SbZMj1BLZ3rwVJjFgjSLW tOSQSfB+Z9LgG8lEJ6T5/fdXMd6HNAYru7X9d1arYrneVr7B1to2OjFigVM67WaTq+93 PvsFx1m0B2U5lA3ekOIUMRmNtplrkdJ7XQ2d8wmQKpREqYQpQ4m/boeSN36R2r0hA5Gd 8wIrMj2XIQAEiZwb+mMzqICaxUVWNMUgqTU+S7CfZqxcCrt5mJ5qnfZliPtmyddmTHkb 2lEmGy1uyFfJsRAUwI69FvUXKmB7z494pFjK3idxLL9onOdSR9yxh6XrH4hfOcJ8EMkV fltw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=5vGtw2h+bowuvSjh8g4+ZRsAkXMwjWUJCok9p6khI3E=; b=enE4jEwwwVUZINOAKo1vcRv9U8Sp/lEHFzbdvXMxm2Bb6evlnqNHoBIKBWbJyRolu6 DelLn6/MIaQoJzBlzSxqQjtVJYpC6tKkoRgNwHfVWUCpVZLhOFXQ3kY86lmvPPR0Qp0p V/M10tcqkNy26WNAX1i9Rsupc31TyIrxAggJnUVWUtcaILBA8Td8h5eZxUGrxx6Vj9wC RLYkNXCjRnChwZuDC0+dy0KhLnTMHhbr5ZnMd7uY89tChDmg+8ARq/lpf7frMCVtg7uR Loowy3kLL3TkSChGruv0hOyaNGIWCrYWAGiMIaWr8N9dxkJkV50FveUB/Uc4U7TOITvr Ad+A== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id x63-20020a638642000000b00499b89917casi37234pgd.782.2022.12.25.06.13.45; Sun, 25 Dec 2022 06:13:57 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229671AbiLYOHO (ORCPT + 67 others); Sun, 25 Dec 2022 09:07:14 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50762 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229489AbiLYOHM (ORCPT ); Sun, 25 Dec 2022 09:07:12 -0500 Received: from fudo.makrotopia.org (fudo.makrotopia.org [IPv6:2a07:2ec0:3002::71]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5071F62DA; Sun, 25 Dec 2022 06:07:11 -0800 (PST) Received: from local by fudo.makrotopia.org with esmtpsa (TLS1.3:TLS_AES_256_GCM_SHA384:256) (Exim 4.96) (envelope-from ) id 1p9ReY-0002Hy-1h; Sun, 25 Dec 2022 15:07:02 +0100 Date: Sun, 25 Dec 2022 14:06:59 +0000 From: Daniel Golle To: Ricardo Ribalda Cc: Matthias Brugger , Mark Brown , AngeloGioacchino Del Regno , linux-mediatek@lists.infradead.org, linux-arm-kernel@lists.infradead.org, linux-spi@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] spi: mediatek: Enable irq before the spi registration Message-ID: References: <20221225-mtk-spi-fixes-v1-0-bb6c14c232f8@chromium.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20221225-mtk-spi-fixes-v1-0-bb6c14c232f8@chromium.org> X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,SPF_HELO_NONE, SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, Dec 25, 2022 at 09:37:12AM +0100, Ricardo Ribalda wrote: > If the irq is enabled after the spi si registered, there can be a race > with the initialization of the devices on the spi bus. > > Eg: > mtk-spi 1100a000.spi: spi-mem transfer timeout > spi-nor: probe of spi0.0 failed with error -110 > Unable to handle kernel NULL pointer dereference at virtual address > 0000000000000010 > ... > Call trace: > mtk_spi_can_dma+0x0/0x2c > > Fixes: c6f7874687f7 ("spi: mediatek: Enable irq when pdata is ready") > Reported-by: Daniel Golle > Signed-off-by: Ricardo Ribalda > --- > spi: mediatek: Fix init order (again) > > Hi Mark > > Here is a fixup of the previous patch. Daniel, can you confirm that it > works on your hardware? Yes, this fixes the issue and SPI now works fine on MT7986 with the patch applied. Tested-by: Daniel Golle > > Thanks and sorry for annoyance. > > To: Mark Brown > To: Matthias Brugger > To: AngeloGioacchino Del Regno > Cc: linux-spi@vger.kernel.org > Cc: linux-arm-kernel@lists.infradead.org > Cc: linux-mediatek@lists.infradead.org > Cc: linux-kernel@vger.kernel.org > Cc: Daniel Golle > --- > drivers/spi/spi-mt65xx.c | 12 +++++------- > 1 file changed, 5 insertions(+), 7 deletions(-) > > diff --git a/drivers/spi/spi-mt65xx.c b/drivers/spi/spi-mt65xx.c > index 6de8360e5c2a..9eab6c20dbc5 100644 > --- a/drivers/spi/spi-mt65xx.c > +++ b/drivers/spi/spi-mt65xx.c > @@ -1253,6 +1253,11 @@ static int mtk_spi_probe(struct platform_device *pdev) > dev_notice(dev, "SPI dma_set_mask(%d) failed, ret:%d\n", > addr_bits, ret); > > + ret = devm_request_irq(dev, irq, mtk_spi_interrupt, > + IRQF_TRIGGER_NONE, dev_name(dev), master); > + if (ret) > + return dev_err_probe(dev, ret, "failed to register irq\n"); > + > pm_runtime_enable(dev); > > ret = devm_spi_register_master(dev, master); > @@ -1261,13 +1266,6 @@ static int mtk_spi_probe(struct platform_device *pdev) > return dev_err_probe(dev, ret, "failed to register master\n"); > } > > - ret = devm_request_irq(dev, irq, mtk_spi_interrupt, > - IRQF_TRIGGER_NONE, dev_name(dev), master); > - if (ret) { > - pm_runtime_disable(dev); > - return dev_err_probe(dev, ret, "failed to register irq\n"); > - } > - > return 0; > } > > > --- > base-commit: 45b3cd900bf8d1a3cd7cf48361df8c09ae5b4009 > change-id: 20221225-mtk-spi-fixes-99c863a6fdf1 > > Best regards, > -- > Ricardo Ribalda