Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp4825621iob; Mon, 9 May 2022 02:31:10 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy3PWDkvKJxP4UeLBSJFcyJyrXynZQ0iLXJsB8ML8xwMqvqljxH3XXKIV2BiKYmGeRoQld1 X-Received: by 2002:a17:90a:9311:b0:1dc:8d06:eb1b with SMTP id p17-20020a17090a931100b001dc8d06eb1bmr17405326pjo.41.1652088670424; Mon, 09 May 2022 02:31:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1652088670; cv=none; d=google.com; s=arc-20160816; b=bDqvlX3AJsQs+NIrBBKNeobO1Tzk6Wv5vYpQjz4ini2//pDgmfupOrki0ROUre/c3s M7WdzOKo59soMUDB8fcMB/3X0L8nFt4Qg2RlZeIqzjiSPckBOY3dFdg5AXGu2bVJHGDi IWJtRyzLcTRC3JBaFjP99dGZLzg+c56MXeiuJdzRjHnCdeev6jM/wqSy6PbgKs0N41d5 iY68MZ2koHgYMB6deKQ8yBkeYp9eJWRYWaMePvgiT9BXnnfHT4nfAlyE+lmrcLmoInQ8 OihQHQxP9gIN8GZUiwNXIx9mW1cd4mi2Anwvtj1ALNlGurFMl647SRsve25AoVs68sXO XzeQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=zEUiL1Va79a7neF6jCwtGiLHoOWzbQEi9AzwgJFBXSw=; b=wzAA3JJ0YgngnCdSvn6TUO/nESptjzzQ84QZGX3kRMqXsm/8OxMgSu1xFsFksBN848 eZe5mmjNPazLQqd1g+sI+RomvI+tHbZGvw4I38VyYMWqqFJEy05RqI2vd9rSxHBNTG9c eGnnOoONXa/uKggC+3g8cBGkhEGlG/oCxfeRzmOjXdI1KgM4IsO/tus8KD+RK9bTbyT0 1nY0J5lI+1pMALOqV/Hg1/ikDdPTkrip+wsfsB22uegpG+hbSs5MMp7h7ILxYNJ60rVN KB1olGOeYUYpavVin7BdXfpCz4W7MnY4jM91yTPfya5BbGPBw6SepAvIlBsO2yA4x6uj 8mMQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@posteo.de header.s=2017 header.b=Mj0ixB7C; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=posteo.de Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id q5-20020a638c45000000b0039d80004fcasi13084212pgn.221.2022.05.09.02.31.10 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 09 May 2022 02:31:10 -0700 (PDT) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@posteo.de header.s=2017 header.b=Mj0ixB7C; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=posteo.de Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 76A681E120B; Mon, 9 May 2022 02:18:59 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1350262AbiEDWJy (ORCPT + 99 others); Wed, 4 May 2022 18:09:54 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33394 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1379048AbiEDWJi (ORCPT ); Wed, 4 May 2022 18:09:38 -0400 Received: from mout02.posteo.de (mout02.posteo.de [185.67.36.66]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id AEB3011A30 for ; Wed, 4 May 2022 15:05:59 -0700 (PDT) Received: from submission (posteo.de [185.67.36.169]) by mout02.posteo.de (Postfix) with ESMTPS id 6554D240107 for ; Thu, 5 May 2022 00:05:57 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=posteo.de; s=2017; t=1651701957; bh=ULZZ+k26KKjcsFqAjZrCBvWd2aE7gAOo79lBw+9K7RA=; h=From:To:Cc:Subject:Date:From; b=Mj0ixB7Cx2Fo2Tjdg89gHmvZlpDrCkY1nH9NZpPSy5P1xzWWI0/fkQftmGPGtD9Sb U6U10z5b+uCJl5uWlzQLUXZy/O5ksv9xIf8+xgmWyUqcS16aeSULtYCv3iVLga3KtE S0GCawRfSrWEcnzduDG4dz1PqXNw1EqP8JHv6rAqHxFUFsHpR855fyBmqFoYtKw2bS o9hZT9Xy88pDuCc8sAUFAq2eS5aO73hGW/xlzJJGqy1mx3+3olE+zTbni9yKQprUor c10hoGCQh/UZJxHjoKFKpaGGUg8DChuG2VZ4lz30jC9zh7Im65ksazELNF5bb06AZ1 QHeP2Z3KS1NTw== Received: from customer (localhost [127.0.0.1]) by submission (posteo.de) with ESMTPSA id 4KtrW76HfFz6tmP; Thu, 5 May 2022 00:05:55 +0200 (CEST) From: Manuel Ullmann To: Igor Russkikh Cc: linux-kernel@vger.kernel.org, netdev@vger.kernel.org, regressions@lists.linux.dev, davem@davemloft.net, ndanilov@marvell.com, kuba@kernel.org, pabeni@redhat.com, Jordan Leppert , Holger =?utf-8?Q?Hoffst=C3=A4tte?= , koo5 Subject: [PATCH] net: atlantic: always deep reset on pm op, fixing null deref regression Date: Wed, 04 May 2022 22:06:12 +0000 Message-ID: <87czgt2bsb.fsf@posteo.de> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: quoted-printable X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no 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 From a3eccd32c618fe4b4f5c537cd83ba5611149623e Mon Sep 17 00:00:00 2001 Date: Wed, 4 May 2022 21:30:44 +0200 The impact of this regression is the same for resume that I saw on thaw: the kernel hangs and nothing except SysRq rebooting can be done. The null deref occurs at the same position as on thaw. BUG: kernel NULL pointer dereference RIP: aq_ring_rx_fill+0xcf/0x210 [atlantic] Fixes regression in cbe6c3a8f8f4 ("net: atlantic: invert deep par in pm functions, preventing null derefs"), where I disabled deep pm resets in suspend and resume, trying to make sense of the atl_resume_common deep parameter in the first place. It turns out, that atlantic always has to deep reset on pm operations and the parameter is useless. Even though I expected that and tested resume, I screwed up by kexec-rebooting into an unpatched kernel, thus missing the breakage. This fixup obsoletes the deep parameter of atl_resume_common, but I leave the cleanup for the maintainers to post to mainline. PS: I'm very sorry for this regression. Fixes: cbe6c3a8f8f4315b96e46e1a1c70393c06d95a4c Link: https://lore.kernel.org/regressions/9-Ehc_xXSwdXcvZqKD5aSqsqeNj5Izco4= MYEwnx5cySXVEc9-x_WC4C3kAoCqNTi-H38frroUK17iobNVnkLtW36V6VWGSQEOHXhmVMm5iQ= =3D@protonmail.com/ Reported-by: Jordan Leppert Reported-by: Holger Hoffst=C3=A4tte CC: # 5.17.5 CC: # 5.15.36 CC: # 5.10.113 Signed-off-by: Manuel ULlmann --- drivers/net/ethernet/aquantia/atlantic/aq_pci_func.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/net/ethernet/aquantia/atlantic/aq_pci_func.c b/drivers= /net/ethernet/aquantia/atlantic/aq_pci_func.c index 3a529ee8c834..831833911a52 100644 --- a/drivers/net/ethernet/aquantia/atlantic/aq_pci_func.c +++ b/drivers/net/ethernet/aquantia/atlantic/aq_pci_func.c @@ -449,7 +449,7 @@ static int aq_pm_freeze(struct device *dev) =20 static int aq_pm_suspend_poweroff(struct device *dev) { - return aq_suspend_common(dev, false); + return aq_suspend_common(dev, true); } =20 static int aq_pm_thaw(struct device *dev) @@ -459,7 +459,7 @@ static int aq_pm_thaw(struct device *dev) =20 static int aq_pm_resume_restore(struct device *dev) { - return atl_resume_common(dev, false); + return atl_resume_common(dev, true); } =20 static const struct dev_pm_ops aq_pm_ops =3D { base-commit: 672c0c5173427e6b3e2a9bbb7be51ceeec78093a --=20 2.35.1