From: "Loïc Molinari" <loic.molinari@collabora.com>
To: "Tvrtko Ursulin" <tursulin@ursulin.net>,
"Maarten Lankhorst" <maarten.lankhorst@linux.intel.com>,
"Maxime Ripard" <mripard@kernel.org>,
"Thomas Zimmermann" <tzimmermann@suse.de>,
"David Airlie" <airlied@gmail.com>,
"Simona Vetter" <simona@ffwll.ch>,
"Jani Nikula" <jani.nikula@linux.intel.com>,
"Joonas Lahtinen" <joonas.lahtinen@linux.intel.com>,
"Rodrigo Vivi" <rodrigo.vivi@intel.com>,
"Boris Brezillon" <boris.brezillon@collabora.com>,
"Rob Herring" <robh@kernel.org>,
"Steven Price" <steven.price@arm.com>,
"Liviu Dudau" <liviu.dudau@arm.com>,
"Melissa Wen" <mwen@igalia.com>,
"Maíra Canal" <mcanal@igalia.com>,
"Hugh Dickins" <hughd@google.com>,
"Baolin Wang" <baolin.wang@linux.alibaba.com>,
"Andrew Morton" <akpm@linux-foundation.org>,
"Al Viro" <viro@zeniv.linux.org.uk>,
"Mikołaj Wasiak" <mikolaj.wasiak@intel.com>,
"Christian Brauner" <brauner@kernel.org>,
"Nitin Gote" <nitin.r.gote@intel.com>,
"Andi Shyti" <andi.shyti@linux.intel.com>,
"Jonathan Corbet" <corbet@lwn.net>,
"Christopher Healy" <healych@amazon.com>,
"Matthew Wilcox" <willy@infradead.org>,
"Bagas Sanjaya" <bagasdotme@gmail.com>
Cc: linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org,
intel-gfx@lists.freedesktop.org, linux-mm@kvack.org,
linux-doc@vger.kernel.org, kernel@collabora.com
Subject: Re: [PATCH v4 05/13] drm/gem: Add huge tmpfs mount point helper
Date: Mon, 20 Oct 2025 16:13:28 +0200 [thread overview]
Message-ID: <8ba7350a-83a7-4c83-8d91-83803d0c06e8@collabora.com> (raw)
In-Reply-To: <7584abe7-0c3f-4022-b510-c2a57fd167bb@ursulin.net>
On 20/10/2025 11:10, Tvrtko Ursulin wrote:
>
> On 15/10/2025 16:30, Loïc Molinari wrote:
>> Add the drm_gem_huge_mnt_create() helper to avoid code duplication in
>> the i915, V3D, Panfrost and Panthor drivers. It creates and mounts a
>> dedicated huge tmpfs mountpoint, for the lifetime of a DRM device,
>> used at GEM object initialization.
>>
>> The next commits will port drivers to this helper.
>>
>> v3:
>> - store huge tmpfs mountpoint in drm_device
>>
>> v4:
>> - return 0 in builds with CONFIG_TRANSPARENT_HUGEPAGE=n
>> - return 0 when huge_mnt already exists
>>
>> Signed-off-by: Loïc Molinari <loic.molinari@collabora.com>
>> ---
>> drivers/gpu/drm/drm_gem.c | 58 +++++++++++++++++++++++++++++++++++++++
>> include/drm/drm_device.h | 11 ++++++++
>> include/drm/drm_gem.h | 1 +
>> 3 files changed, 70 insertions(+)
>>
>> diff --git a/drivers/gpu/drm/drm_gem.c b/drivers/gpu/drm/drm_gem.c
>> index a98d5744cc6c..db8c0a217add 100644
>> --- a/drivers/gpu/drm/drm_gem.c
>> +++ b/drivers/gpu/drm/drm_gem.c
>> @@ -29,6 +29,7 @@
>> #include <linux/export.h>
>> #include <linux/file.h>
>> #include <linux/fs.h>
>> +#include <linux/fs_context.h>
>> #include <linux/iosys-map.h>
>> #include <linux/mem_encrypt.h>
>> #include <linux/mm.h>
>> @@ -82,6 +83,63 @@
>> * up at a later date, and as our interface with shmfs for memory
>> allocation.
>> */
>> +static void drm_gem_huge_mnt_free(struct drm_device *dev, void *data)
>> +{
>> + drm_WARN_ON(dev, dev->huge_mnt == NULL);
>
> I don't see a benefit of adding this check but maybe I am missing
> something.
That was mostly to detect and warn drivers setting the drm_device's
huge_mnt pointer directly. I can remove that.
>> +
>> + kern_unmount(dev->huge_mnt);
>> + dev->huge_mnt = NULL;
>
> Ditto - device is going away, no? So why bother clearing the pointer?
This one is necessary to let drivers tear down and reload.
drm_gem_huge_mnt_create() returns if the pointer isn't NULL.
> Also, is the compiler smart enough to not compile or complain this
> function is unused in the !CONFIG_TRANSPARENT_HUGEPAGE case?
No compiler warnings, but this might not be the case with different
compilers/versions so I'll ifdef it out.
>> +}
>> +
>> +/**
>> + * drm_gem_huge_mnt_create - Create, mount and use a huge tmpfs
>> mountpoint
>> + * @dev: drm_device a huge tmpfs mountpoint should be used with
>> + * @value: huge tmpfs mount option value
>> + *
>> + * This function creates and mounts a dedicated huge tmpfs mountpoint
>> for the
>> + * lifetime of the drm device @dev which is used at GEM object
>> initialization
>> + * with drm_gem_object_init().
>> + *
>> + * The most common option value @value is "within_size" which only
>> allocates
>> + * huge pages if the page will be fully within the GEM object size.
>> "always",
>> + * "advise" and "never" are supported too but the latter would just
>> create a
>> + * mountpoint similar to the default one (`shm_mnt`). See shmemfs and
>> + * Transparent Hugepage for more information.
>> + *
>> + * Returns:
>> + * 0 on success or a negative error code on failure.
>> + */
>> +int drm_gem_huge_mnt_create(struct drm_device *dev, const char *value)
>> +{
>> + struct file_system_type *type;
>> + struct fs_context *fc;
>> + int ret;
>> +
>> + if (!IS_ENABLED(CONFIG_TRANSPARENT_HUGEPAGE))
>> + return 0;
>
> Is there a specific reason why the !CONFIG_TRANSPARENT_HUGEPAGE path is
> not implemented in the header as a static inline? That would enable
> those builds to avoid the pointless function in text and function call
> in the drivers.
Good point. I'll propose a new version with drm_gem_huge_mnt_create()
implemented as a static inline function that calls into
__drm_gem_huge_mnt_create() only for builds with
CONFIG_TRANSPARENT_HUGEPAGE=y.
>
>> + if (unlikely(dev->huge_mnt))
>> + return 0;
>
> Any special reason why it is allowed to call it multiple times with
> success?
That was initially returning -EEXIST in v3 but got changed after review
to simplify call sites.
>
>> +
>> + type = get_fs_type("tmpfs");
>> + if (unlikely(!type))
>> + return -EOPNOTSUPP;
>> + fc = fs_context_for_mount(type, SB_KERNMOUNT);
>> + if (IS_ERR(fc))
>> + return PTR_ERR(fc);
>> + ret = vfs_parse_fs_string(fc, "source", "tmpfs");
>> + if (unlikely(ret))
>> + return -ENOPARAM;
>> + ret = vfs_parse_fs_string(fc, "huge", value);
>> + if (unlikely(ret))
>> + return -ENOPARAM;
>> +
>> + dev->huge_mnt = fc_mount_longterm(fc);
>> + put_fs_context(fc);
>> +
>> + return drmm_add_action_or_reset(dev, drm_gem_huge_mnt_free, NULL);
>> +}
>> +EXPORT_SYMBOL_GPL(drm_gem_huge_mnt_create);
>> +
>> static void
>> drm_gem_init_release(struct drm_device *dev, void *ptr)
>> {
>> diff --git a/include/drm/drm_device.h b/include/drm/drm_device.h
>> index 778b2cca6c49..352e3db402d7 100644
>> --- a/include/drm/drm_device.h
>> +++ b/include/drm/drm_device.h
>> @@ -3,6 +3,7 @@
>> #include <linux/list.h>
>> #include <linux/kref.h>
>> +#include <linux/mount.h>
>> #include <linux/mutex.h>
>> #include <linux/idr.h>
>> #include <linux/sched.h>
>> @@ -168,6 +169,16 @@ struct drm_device {
>> */
>> struct drm_master *master;
>> + /**
>> + * @huge_mnt:
>> + *
>> + * Huge tmpfs mountpoint used at GEM object initialization
>> + * drm_gem_object_init(). Drivers can call
>> drm_gem_huge_mnt_create() to
>> + * create a huge tmfps mountpoint. The default tmpfs mountpoint
>> + * (`shm_mnt`) is used if NULL.
>> + */
>> + struct vfsmount *huge_mnt;
>
> Maybe it would be nice to hide this in the !CONFIG_TRANSPARENT_HUGEPAGE
> case? A bit ugly to add an ifdef but it is also a bit questionable to
> force the member on everyone.
It was initially stored in drivers' data structures but, as mentioned
above for v3, got put in drm_device to simplify call sites.
Both V3D and i915 are testing for that pointer in a few places and that
would require adding ifdefs there too. This would also be the same for
any drivers adding support for huge pages. Is that really worth it?
>
> Regards,
>
> Tvrtko
>
>> +
>> /**
>> * @driver_features: per-device driver features
>> *
>> diff --git a/include/drm/drm_gem.h b/include/drm/drm_gem.h
>> index 7c8bd67d087c..7285a62d9afc 100644
>> --- a/include/drm/drm_gem.h
>> +++ b/include/drm/drm_gem.h
>> @@ -492,6 +492,7 @@ struct drm_gem_object {
>> DRM_GEM_FOPS,\
>> }
>> +int drm_gem_huge_mnt_create(struct drm_device *dev, const char *value);
>> void drm_gem_object_release(struct drm_gem_object *obj);
>> void drm_gem_object_free(struct kref *kref);
>> int drm_gem_object_init(struct drm_device *dev,
>
next prev parent reply other threads:[~2025-10-20 14:13 UTC|newest]
Thread overview: 27+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-10-15 15:30 [PATCH v4 00/13] drm: Reduce page tables overhead with THP Loïc Molinari
2025-10-15 15:30 ` [PATCH v4 01/13] drm/shmem-helper: Simplify page offset calculation in fault handler Loïc Molinari
2025-10-15 15:30 ` [PATCH v4 02/13] drm/shmem-helper: Implement map_pages fault-around handler Loïc Molinari
2025-10-15 15:30 ` [PATCH v4 03/13] drm/shmem-helper: Map huge pages in fault handlers Loïc Molinari
2025-10-15 17:27 ` Matthew Wilcox
2025-10-16 11:17 ` Loïc Molinari
2025-10-17 21:42 ` Matthew Wilcox
2025-11-10 14:39 ` Loïc Molinari
2025-10-15 15:30 ` [PATCH v4 04/13] drm/gem: Introduce drm_gem_get_unmapped_area() fop Loïc Molinari
2025-10-15 15:30 ` [PATCH v4 05/13] drm/gem: Add huge tmpfs mount point helper Loïc Molinari
2025-10-20 9:10 ` Tvrtko Ursulin
2025-10-20 14:13 ` Loïc Molinari [this message]
2025-10-15 15:30 ` [PATCH v4 06/13] drm/i915: Use " Loïc Molinari
2025-10-15 15:30 ` [PATCH v4 07/13] drm/v3d: " Loïc Molinari
2025-10-20 9:33 ` Tvrtko Ursulin
2025-10-20 14:27 ` Loïc Molinari
2025-10-15 15:30 ` [PATCH v4 08/13] drm/v3d: Fix builds with CONFIG_TRANSPARENT_HUGEPAGE=n Loïc Molinari
2025-10-15 18:17 ` Boris Brezillon
2025-10-15 20:41 ` Loïc Molinari
2025-10-16 5:56 ` Boris Brezillon
2025-10-16 7:09 ` Loïc Molinari
2025-10-16 7:22 ` Boris Brezillon
2025-10-15 15:30 ` [PATCH v4 09/13] drm/gem: Get rid of *_with_mnt helpers Loïc Molinari
2025-10-15 15:30 ` [PATCH v4 10/13] drm/panthor: Introduce huge tmpfs mount point option Loïc Molinari
2025-10-15 15:30 ` [PATCH v4 11/13] drm/panthor: Improve IOMMU map/unmap debugging logs Loïc Molinari
2025-10-15 15:30 ` [PATCH v4 12/13] drm/panfrost: Introduce huge tmpfs mount point option Loïc Molinari
2025-10-15 15:30 ` [PATCH v4 13/13] Documentation/gpu/drm-mm: Add THP paragraph to GEM mapping section Loïc Molinari
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=8ba7350a-83a7-4c83-8d91-83803d0c06e8@collabora.com \
--to=loic.molinari@collabora.com \
--cc=airlied@gmail.com \
--cc=akpm@linux-foundation.org \
--cc=andi.shyti@linux.intel.com \
--cc=bagasdotme@gmail.com \
--cc=baolin.wang@linux.alibaba.com \
--cc=boris.brezillon@collabora.com \
--cc=brauner@kernel.org \
--cc=corbet@lwn.net \
--cc=dri-devel@lists.freedesktop.org \
--cc=healych@amazon.com \
--cc=hughd@google.com \
--cc=intel-gfx@lists.freedesktop.org \
--cc=jani.nikula@linux.intel.com \
--cc=joonas.lahtinen@linux.intel.com \
--cc=kernel@collabora.com \
--cc=linux-doc@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=liviu.dudau@arm.com \
--cc=maarten.lankhorst@linux.intel.com \
--cc=mcanal@igalia.com \
--cc=mikolaj.wasiak@intel.com \
--cc=mripard@kernel.org \
--cc=mwen@igalia.com \
--cc=nitin.r.gote@intel.com \
--cc=robh@kernel.org \
--cc=rodrigo.vivi@intel.com \
--cc=simona@ffwll.ch \
--cc=steven.price@arm.com \
--cc=tursulin@ursulin.net \
--cc=tzimmermann@suse.de \
--cc=viro@zeniv.linux.org.uk \
--cc=willy@infradead.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox