From: Baolin Wang <baolin.wang@linux.alibaba.com>
To: "David Hildenbrand (Arm)" <david@kernel.org>,
akpm@linux-foundation.org, hughd@google.com
Cc: willy@infradead.org, ziy@nvidia.com, ljs@kernel.org,
lance.yang@linux.dev, linux-mm@kvack.org,
linux-kernel@vger.kernel.org
Subject: Re: [PATCH v3] mm: shmem: always support large folios for internal shmem mount
Date: Tue, 21 Apr 2026 14:27:21 +0800 [thread overview]
Message-ID: <f9508e75-789e-4eb8-b09e-b66a8676a6b0@linux.alibaba.com> (raw)
In-Reply-To: <07e26d39-6155-4661-b3df-c2419535ed43@kernel.org>
On 4/21/26 3:00 AM, David Hildenbrand (Arm) wrote:
> On 4/17/26 14:45, Baolin Wang wrote:
>>
>>
>> On 4/17/26 5:52 PM, David Hildenbrand (Arm) wrote:
>>> On 4/17/26 11:27, Baolin Wang wrote:
>>>>
>>>>
>>>>
>>>> For tmpfs, yes.
>>>
>>> So, we could pass this check here, not setting
>>> mapping_set_large_folios(), but later someone toggles it and we missed
>>> to set mapping_set_large_folios()?
>>
>> Indeed. Good point.
>>
>>>
>>> Or would we always go through another __shmem_get_inode() after a
>>> remount?
>>
>> Not really. There could be files created before remount whose mappings
>> don't support large folios (with 'huge=never' option), while files
>> created after remount will have mappings that support large folios (if
>> remounted with 'huge=always' option).
>>
>> It looks like the previous commit 5a90c155defa was also problematic. The
>> huge mount option has introduced a lot of tricky issues:(
>>
>> Now I think Zi's previous suggestion should be able to clean up this
>> mess? That is, calling mapping_set_large_folios() unconditionally for
>> all shmem mounts, and revisiting Kefeng's first version to fix the
>> performance issue.
>
> Okay, so you'll send a patch to just set mapping_set_large_folios()
> unconditionally?
I'm still hesitating on this. If we set mapping_set_large_folios()
unconditionally, we need to re-fix the performance regression that was
addressed by commit 5a90c155defa.
But it's hard for me to convince myself to add a new flag similar to
IOCB_NO_LARGE_CHUNK for this hack (like the patch in [1] does).
>> [1] https://lore.kernel.org/all/20240914140613.2334139-1-
>> wangkefeng.wang@huawei.com/
>
> Is that really required? Which call path would be the problematic bit
> with the above?
>
> I'd say, we'd check in the large folio allocation code whether ->huge is
> set to never instead?
Yes, this is exactly our current logic. When allocating large folios,
we'll check the ->huge setting in shmem_huge_global_enabled(), which
means large folio allocations always respect the ->huge setting.
But as I mentioned earlier, the ->huge setting cannot keep the
mapping_set_large_folios() setting consistent across all mappings in the
entire tmpfs mount. My concern is that under the same tmpfs mount, after
remount, we might end up with some mappings supporting large folios
(calling mapping_set_large_folios()) while others don't.
However, I got some insights from
Documentation/admin-guide/mm/transhuge.rst. Does this mean that after
remount, whether the mappings of existing files support large folios
should remain unchanged?
“
``mount -o remount,huge= /mountpoint`` works fine after mount:
remounting ``huge=never`` will not attempt to break up huge pages at
all, just stop more from being allocated.
”
Do you think this makes sense?
prev parent reply other threads:[~2026-04-21 6:27 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-04-17 3:25 Baolin Wang
2026-04-17 9:21 ` David Hildenbrand (Arm)
2026-04-17 9:27 ` Baolin Wang
2026-04-17 9:52 ` David Hildenbrand (Arm)
2026-04-17 12:45 ` Baolin Wang
2026-04-20 19:00 ` David Hildenbrand (Arm)
2026-04-21 6:27 ` Baolin Wang [this message]
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=f9508e75-789e-4eb8-b09e-b66a8676a6b0@linux.alibaba.com \
--to=baolin.wang@linux.alibaba.com \
--cc=akpm@linux-foundation.org \
--cc=david@kernel.org \
--cc=hughd@google.com \
--cc=lance.yang@linux.dev \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=ljs@kernel.org \
--cc=willy@infradead.org \
--cc=ziy@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