From: Alistair Popple <apopple@nvidia.com>
To: Eliot Courtney <ecourtney@nvidia.com>
Cc: Danilo Krummrich <dakr@kernel.org>,
Alexandre Courbot <acourbot@nvidia.com>,
Alice Ryhl <aliceryhl@google.com>,
David Airlie <airlied@gmail.com>,
Simona Vetter <simona@ffwll.ch>,
Benno Lossin <lossin@kernel.org>, Gary Guo <gary@garyguo.net>,
John Hubbard <jhubbard@nvidia.com>,
Timur Tabi <ttabi@nvidia.com>,
nova-gpu@lists.linux.dev, dri-devel@lists.freedesktop.org,
linux-kernel@vger.kernel.org, rust-for-linux@vger.kernel.org
Subject: Re: [PATCH 08/13] gpu: nova-core: gsp: ensure LibOS DMA allocation lives long enough
Date: Wed, 17 Jun 2026 16:11:00 +1000 [thread overview]
Message-ID: <ajI5QtrE3JHubMEd@nvdebian.thelocal> (raw)
In-Reply-To: <20260615-blackwell-fixes-v1-8-f2853e49ff7d@nvidia.com>
On 2026-06-16 at 00:40 +1000, Eliot Courtney <ecourtney@nvidia.com> wrote...
> Currently, `GspSequencer` stores a raw DMA handle. Instead, store a
> reference to `Coherent` to statically ensure that the allocation lives
> long enough.
I'm thinking it would be rather hard to hit this in practice as running the
GspSequencer takes a reference to the command queue which is contained within
the same data structure as the DMA handle anyway.
Still it's much nicer not to rely on this detail which could change and to be
explicit instead so:
Reviewed-by: Alistair Popple <apopple@nvidia.com>
> Signed-off-by: Eliot Courtney <ecourtney@nvidia.com>
> ---
> drivers/gpu/nova-core/gsp/hal/tu102.rs | 2 +-
> drivers/gpu/nova-core/gsp/sequencer.rs | 18 +++++++++++-------
> 2 files changed, 12 insertions(+), 8 deletions(-)
>
> diff --git a/drivers/gpu/nova-core/gsp/hal/tu102.rs b/drivers/gpu/nova-core/gsp/hal/tu102.rs
> index eb7166148cc9..1e08c482fd39 100644
> --- a/drivers/gpu/nova-core/gsp/hal/tu102.rs
> +++ b/drivers/gpu/nova-core/gsp/hal/tu102.rs
> @@ -344,7 +344,7 @@ fn post_boot(
> // Create and run the GSP sequencer.
> let seq_params = GspSequencerParams {
> bootloader_app_version: gsp_fw.bootloader.app_version,
> - libos_dma_handle: gsp.libos.dma_handle(),
> + libos: &gsp.libos,
> gsp_falcon,
> sec2_falcon,
> dev,
> diff --git a/drivers/gpu/nova-core/gsp/sequencer.rs b/drivers/gpu/nova-core/gsp/sequencer.rs
> index e0850d21adca..ddb6abc45a37 100644
> --- a/drivers/gpu/nova-core/gsp/sequencer.rs
> +++ b/drivers/gpu/nova-core/gsp/sequencer.rs
> @@ -6,6 +6,7 @@
>
> use kernel::{
> device,
> + dma::Coherent,
> io::{
> poll::read_poll_timeout,
> Io, //
> @@ -31,6 +32,7 @@
> MessageFromGsp, //
> },
> fw,
> + LibosMemoryRegionInitArgument, //
> },
> num::FromSafeCast,
> sbuffer::SBufferIter,
> @@ -136,8 +138,8 @@ pub(crate) struct GspSequencer<'a> {
> sec2_falcon: &'a Falcon<Sec2>,
> /// GSP falcon for core operations.
> gsp_falcon: &'a Falcon<Gsp>,
> - /// LibOS DMA handle address.
> - libos_dma_handle: u64,
> + /// LibOS memory region init arguments.
> + libos: &'a Coherent<[LibosMemoryRegionInitArgument]>,
> /// Bootloader application version.
> bootloader_app_version: u32,
> /// Device for logging.
> @@ -233,11 +235,13 @@ fn run(&self, seq: &GspSequencer<'_>) -> Result {
> // Reset the GSP to prepare it for resuming.
> seq.gsp_falcon.reset(seq.bar)?;
>
> + let libos_dma_handle = seq.libos.dma_handle();
> +
> // Write the libOS DMA handle to GSP mailboxes.
> seq.gsp_falcon.write_mailboxes(
> seq.bar,
> - Some(seq.libos_dma_handle as u32),
> - Some((seq.libos_dma_handle >> 32) as u32),
> + Some(libos_dma_handle as u32),
> + Some((libos_dma_handle >> 32) as u32),
> );
>
> // Start the SEC2 falcon which will trigger GSP-RM to resume on the GSP.
> @@ -342,8 +346,8 @@ fn iter(&self) -> GspSeqIter<'_> {
> pub(crate) struct GspSequencerParams<'a> {
> /// Bootloader application version.
> pub(crate) bootloader_app_version: u32,
> - /// LibOS DMA handle address.
> - pub(crate) libos_dma_handle: u64,
> + /// LibOS memory region init arguments.
> + pub(crate) libos: &'a Coherent<[LibosMemoryRegionInitArgument]>,
> /// GSP falcon for core operations.
> pub(crate) gsp_falcon: &'a Falcon<Gsp>,
> /// SEC2 falcon for core operations.
> @@ -369,7 +373,7 @@ pub(crate) fn run(cmdq: &Cmdq, params: GspSequencerParams<'a>) -> Result {
> bar: params.bar,
> sec2_falcon: params.sec2_falcon,
> gsp_falcon: params.gsp_falcon,
> - libos_dma_handle: params.libos_dma_handle,
> + libos: params.libos,
> bootloader_app_version: params.bootloader_app_version,
> dev: params.dev,
> };
>
> --
> 2.54.0
>
next prev parent reply other threads:[~2026-06-17 6:11 UTC|newest]
Thread overview: 30+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-06-15 14:40 [PATCH 00/13] gpu: nova-core: blackwell follow-ups and fixes Eliot Courtney
2026-06-15 14:40 ` [PATCH 01/13] gpu: nova-core: fsp: limit FSP receive message allocation size Eliot Courtney
2026-06-15 17:11 ` Gary Guo
2026-06-16 7:33 ` Alistair Popple
2026-06-15 14:40 ` [PATCH 02/13] gpu: nova-core: fsp: catch bogus queue pointer issues Eliot Courtney
2026-06-15 17:15 ` Gary Guo
2026-06-16 7:57 ` Alistair Popple
2026-06-16 10:57 ` Gary Guo
2026-06-17 3:51 ` Eliot Courtney
2026-06-17 4:31 ` Alistair Popple
2026-06-15 14:40 ` [PATCH 03/13] gpu: nova-core: fsp: try to enforce exclusive access to FSP channel Eliot Courtney
2026-06-15 17:16 ` Gary Guo
2026-06-17 2:55 ` Eliot Courtney
2026-06-17 3:12 ` John Hubbard
2026-06-15 14:40 ` [PATCH 04/13] gpu: nova-core: falcon: gsp: move PRIV target mask constants Eliot Courtney
2026-06-15 17:17 ` Gary Guo
2026-06-16 8:02 ` Alistair Popple
2026-06-15 14:40 ` [PATCH 05/13] gpu: nova-core: gsp: keep FMC boot params DMA region alive during error Eliot Courtney
2026-06-15 17:23 ` Gary Guo
2026-06-17 5:27 ` Eliot Courtney
2026-06-15 14:40 ` [PATCH 06/13] gpu: nova-core: fsp: move FMC firmware loading into wait_secure_boot Eliot Courtney
2026-06-15 17:24 ` Gary Guo
2026-06-15 14:40 ` [PATCH 07/13] gpu: nova-core: gsp: ensure lifetime for FMC boot DMA allocations Eliot Courtney
2026-06-15 14:40 ` [PATCH 08/13] gpu: nova-core: gsp: ensure LibOS DMA allocation lives long enough Eliot Courtney
2026-06-17 6:11 ` Alistair Popple [this message]
2026-06-15 14:40 ` [PATCH 09/13] gpu: nova-core: wait for FSP boot earlier Eliot Courtney
2026-06-15 14:40 ` [PATCH 10/13] gpu: nova-core: split FbLayout into FSP and non-FSP versions Eliot Courtney
2026-06-15 14:40 ` [PATCH 11/13] gpu: nova-core: correct FRTS vidmem offset calculation Eliot Courtney
2026-06-15 14:40 ` [PATCH 12/13] gpu: nova-core: rename heap size field Eliot Courtney
2026-06-15 14:40 ` [PATCH 13/13] gpu: nova-core: return non-WPR heap size as u64 from HALs Eliot Courtney
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=ajI5QtrE3JHubMEd@nvdebian.thelocal \
--to=apopple@nvidia.com \
--cc=acourbot@nvidia.com \
--cc=airlied@gmail.com \
--cc=aliceryhl@google.com \
--cc=dakr@kernel.org \
--cc=dri-devel@lists.freedesktop.org \
--cc=ecourtney@nvidia.com \
--cc=gary@garyguo.net \
--cc=jhubbard@nvidia.com \
--cc=linux-kernel@vger.kernel.org \
--cc=lossin@kernel.org \
--cc=nova-gpu@lists.linux.dev \
--cc=rust-for-linux@vger.kernel.org \
--cc=simona@ffwll.ch \
--cc=ttabi@nvidia.com \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox