From: Janne Grunau <j@jannau.net>
To: gregkh@linuxfoundation.org
Cc: hch@lst.de, stable@vger.kernel.org
Subject: Re: FAILED: patch "[PATCH] nvme-apple: reset controller during shutdown" failed to apply to 6.1-stable tree
Date: Mon, 20 Feb 2023 17:45:59 +0100 [thread overview]
Message-ID: <20230220164559.GA24656@jannau.net> (raw)
In-Reply-To: <1676893225104207@kroah.com>
Hej,
On 2023-02-20 12:40:25 +0100, gregkh@linuxfoundation.org wrote:
>
> The patch below does not apply to the 6.1-stable tree.
> If someone wants it applied there, or to any other stable or longterm
> tree, then please email the backport, including the original git commit
> id to <stable@vger.kernel.org>.
Why was this patch even considered for the 6.1-stable tree? Its "Fixes:"
tag references a commit which only appeared in v6.2-rc1.
There is no need to backport this to any stable tree.
The message suggest that ignoring this would have been fine but it seems
worthwhile to report a potential bug or ommission in the stable backport
tooling.
> Possible dependencies:
>
> c06ba7b892a5 ("nvme-apple: reset controller during shutdown")
certainly doesn't depend on itself
...
> c76b8308e4c9 ("nvme-apple: fix controller shutdown in apple_nvme_disable")
commit from "Fixes:"
...
If this is intended since "Fixes:" tags are in general not relieable
enough to decide to which trees regression fixes have to be applied to
that's acceptable
ciao
Janne
> ------------------ original commit in Linus's tree ------------------
>
> From c06ba7b892a50b48522ad441a40053f483dfee9e Mon Sep 17 00:00:00 2001
> From: Janne Grunau <j@jannau.net>
> Date: Tue, 17 Jan 2023 19:25:00 +0100
> Subject: [PATCH] nvme-apple: reset controller during shutdown
>
> This is a functional revert of c76b8308e4c9 ("nvme-apple: fix controller
> shutdown in apple_nvme_disable").
>
> The commit broke suspend/resume since apple_nvme_reset_work() tries to
> disable the controller on resume. This does not work for the apple NVMe
> controller since register access only works while the co-processor
> firmware is running.
>
> Disabling the NVMe controller in the shutdown path is also required
> for shutting the co-processor down. The original code was appropriate
> for this hardware. Add a comment to prevent a similar breaking changes
> in the future.
>
> Fixes: c76b8308e4c9 ("nvme-apple: fix controller shutdown in apple_nvme_disable")
> Reported-by: Janne Grunau <j@jannau.net>
> Link: https://lore.kernel.org/all/20230110174745.GA3576@jannau.net/
> Signed-off-by: Janne Grunau <j@jannau.net>
> [hch: updated with a more descriptive comment from Hector Martin]
> Signed-off-by: Christoph Hellwig <hch@lst.de>
>
> diff --git a/drivers/nvme/host/apple.c b/drivers/nvme/host/apple.c
> index bf1c60edb7f9..146c9e63ce77 100644
> --- a/drivers/nvme/host/apple.c
> +++ b/drivers/nvme/host/apple.c
> @@ -829,7 +829,23 @@ static void apple_nvme_disable(struct apple_nvme *anv, bool shutdown)
> apple_nvme_remove_cq(anv);
> }
>
> - nvme_disable_ctrl(&anv->ctrl, shutdown);
> + /*
> + * Always disable the NVMe controller after shutdown.
> + * We need to do this to bring it back up later anyway, and we
> + * can't do it while the firmware is not running (e.g. in the
> + * resume reset path before RTKit is initialized), so for Apple
> + * controllers it makes sense to unconditionally do it here.
> + * Additionally, this sequence of events is reliable, while
> + * others (like disabling after bringing back the firmware on
> + * resume) seem to run into trouble under some circumstances.
> + *
> + * Both U-Boot and m1n1 also use this convention (i.e. an ANS
> + * NVMe controller is handed off with firmware shut down, in an
> + * NVMe disabled state, after a clean shutdown).
> + */
> + if (shutdown)
> + nvme_disable_ctrl(&anv->ctrl, shutdown);
> + nvme_disable_ctrl(&anv->ctrl, false);
> }
>
> WRITE_ONCE(anv->ioq.enabled, false);
>
next prev parent reply other threads:[~2023-02-20 16:47 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-02-20 11:40 FAILED: patch "[PATCH] nvme-apple: reset controller during shutdown" failed to apply to 6.1-stable tree gregkh
2023-02-20 16:45 ` Janne Grunau [this message]
2023-02-20 18:09 ` Greg KH
2023-02-20 21:06 ` Janne Grunau
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20230220164559.GA24656@jannau.net \
--to=j@jannau.net \
--cc=gregkh@linuxfoundation.org \
--cc=hch@lst.de \
--cc=stable@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.