From: Matthew Brost <matthew.brost@intel.com>
To: Mario Limonciello <mario.limonciello@amd.com>
Cc: Samuel Zhang <guoqing.zhang@amd.com>, <alexander.deucher@amd.com>,
<christian.koenig@amd.com>, <rafael@kernel.org>,
<len.brown@intel.com>, <pavel@kernel.org>,
<gregkh@linuxfoundation.org>, <dakr@kernel.org>,
<airlied@gmail.com>, <simona@ffwll.ch>, <ray.huang@amd.com>,
<matthew.auld@intel.com>, <maarten.lankhorst@linux.intel.com>,
<mripard@kernel.org>, <tzimmermann@suse.de>, <lijo.lazar@amd.com>,
<victor.zhao@amd.com>, <haijun.chang@amd.com>, <Qing.Ma@amd.com>,
<linux-pm@vger.kernel.org>, <linux-kernel@vger.kernel.org>,
<amd-gfx@lists.freedesktop.org>,
<dri-devel@lists.freedesktop.org>
Subject: Re: [PATCH v2 1/5] drm/ttm: add ttm_device_prepare_hibernation() api
Date: Sun, 6 Jul 2025 17:48:56 -0700 [thread overview]
Message-ID: <aGsZeOFhBcMAl341@lstrano-desk.jf.intel.com> (raw)
In-Reply-To: <5c4f5f0d-024a-46e5-9506-0b589f6cce5d@amd.com>
On Sun, Jul 06, 2025 at 04:44:27PM -0400, Mario Limonciello wrote:
> On 7/4/2025 6:12 AM, Samuel Zhang wrote:
> > This new api is used for hibernation to move GTT BOs to shmem after
> > VRAM eviction. shmem will be flushed to swap disk later to reduce
> > the system memory usage for hibernation.
> >
> > Signed-off-by: Samuel Zhang <guoqing.zhang@amd.com>
> > ---
> > drivers/gpu/drm/ttm/ttm_device.c | 29 +++++++++++++++++++++++++++++
> > include/drm/ttm/ttm_device.h | 1 +
> > 2 files changed, 30 insertions(+)
> >
> > diff --git a/drivers/gpu/drm/ttm/ttm_device.c b/drivers/gpu/drm/ttm/ttm_device.c
> > index 02e797fd1891..19ab35ffeead 100644
> > --- a/drivers/gpu/drm/ttm/ttm_device.c
> > +++ b/drivers/gpu/drm/ttm/ttm_device.c
> > @@ -123,6 +123,35 @@ static int ttm_global_init(void)
> > return ret;
> > }
> > +/**
> > + * move GTT BOs to shmem for hibernation.
> > + *
> > + * returns 0 on success, negative on failure.
> > + */
> > +int ttm_device_prepare_hibernation(void)
> > +{
> > + struct ttm_operation_ctx ctx = {
> > + .interruptible = false,
> > + .no_wait_gpu = false,
> > + .force_alloc = true
> > + };
> > + struct ttm_global *glob = &ttm_glob;
> > + struct ttm_device *bdev;
> > + int ret = 0;
> > +
> > + mutex_lock(&ttm_global_mutex);
> > + list_for_each_entry(bdev, &glob->device_list, device_list) {
> > + do {
> > + ret = ttm_device_swapout(bdev, &ctx, GFP_KERNEL);
> > + } while (ret > 0);
> > + if (ret < 0)
> > + break;
> > + }
> > + mutex_unlock(&ttm_global_mutex);
> > + return ret;
>
> I'd personally rather see scoped guard here so you can return immediately
> and the guard will clean up but up to Christian what he thinks.
>
> int ret;
>
> scoped_guard(mutex, &ttm_global_mutex) {
guard(mutex)(&ttm_global_mutex) would be more apporiate for this as the
scope of the guard is the entire function.
Matt
> list_for_each_entry(bdev, &glob->device_list, device_list) {
> do {
> ret = ttm_device_swapout(bdev, &ctx, GFP_KERNEL);
> } while (ret > 0);
> if (ret)
> return ret;
> }
>
> return 0;
>
> > +}
> > +EXPORT_SYMBOL(ttm_device_prepare_hibernation);
> > +
> > /*
> > * A buffer object shrink method that tries to swap out the first
> > * buffer object on the global::swap_lru list.
> > diff --git a/include/drm/ttm/ttm_device.h b/include/drm/ttm/ttm_device.h
> > index 39b8636b1845..b45498b398dd 100644
> > --- a/include/drm/ttm/ttm_device.h
> > +++ b/include/drm/ttm/ttm_device.h
> > @@ -272,6 +272,7 @@ struct ttm_device {
> > int ttm_global_swapout(struct ttm_operation_ctx *ctx, gfp_t gfp_flags);
> > int ttm_device_swapout(struct ttm_device *bdev, struct ttm_operation_ctx *ctx,
> > gfp_t gfp_flags);
> > +int ttm_device_prepare_hibernation(void);
> > static inline struct ttm_resource_manager *
> > ttm_manager_type(struct ttm_device *bdev, int mem_type)
>
next prev parent reply other threads:[~2025-07-07 0:47 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-07-04 10:12 [PATCH v2 0/5] reduce system memory requirement for hibernation Samuel Zhang
2025-07-04 10:12 ` [PATCH v2 1/5] drm/ttm: add ttm_device_prepare_hibernation() api Samuel Zhang
2025-07-06 20:44 ` Mario Limonciello
2025-07-07 0:48 ` Matthew Brost [this message]
2025-07-07 9:13 ` Christian König
2025-07-04 10:12 ` [PATCH v2 2/5] drm/amdgpu: move GTT to shmem after eviction for hibernation Samuel Zhang
2025-07-06 20:41 ` Mario Limonciello
2025-07-07 9:16 ` Christian König
2025-07-04 10:12 ` [PATCH v2 3/5] PM: hibernate: shrink shmem pages after dev_pm_ops.prepare() Samuel Zhang
2025-07-07 18:45 ` Rafael J. Wysocki
2025-07-04 10:12 ` [PATCH v2 4/5] PM: hibernate: export variable pm_transition Samuel Zhang
2025-07-06 20:40 ` Mario Limonciello
2025-07-07 19:17 ` Rafael J. Wysocki
2025-07-04 10:12 ` [PATCH v2 5/5] drm/amdgpu: do not resume device in thaw for normal hibernation Samuel Zhang
2025-07-06 20:34 ` Mario Limonciello
2025-07-07 2:28 ` Lazar, Lijo
2025-07-07 2:29 ` Mario Limonciello
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=aGsZeOFhBcMAl341@lstrano-desk.jf.intel.com \
--to=matthew.brost@intel.com \
--cc=Qing.Ma@amd.com \
--cc=airlied@gmail.com \
--cc=alexander.deucher@amd.com \
--cc=amd-gfx@lists.freedesktop.org \
--cc=christian.koenig@amd.com \
--cc=dakr@kernel.org \
--cc=dri-devel@lists.freedesktop.org \
--cc=gregkh@linuxfoundation.org \
--cc=guoqing.zhang@amd.com \
--cc=haijun.chang@amd.com \
--cc=len.brown@intel.com \
--cc=lijo.lazar@amd.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pm@vger.kernel.org \
--cc=maarten.lankhorst@linux.intel.com \
--cc=mario.limonciello@amd.com \
--cc=matthew.auld@intel.com \
--cc=mripard@kernel.org \
--cc=pavel@kernel.org \
--cc=rafael@kernel.org \
--cc=ray.huang@amd.com \
--cc=simona@ffwll.ch \
--cc=tzimmermann@suse.de \
--cc=victor.zhao@amd.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 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.