On 4/25/26 14:00, Zi Yan wrote:
> On 17 Apr 2026, at 22:44, Zi Yan wrote:
> 
>> Replace it with a check on the max folio order of the file's address space
>> mapping, making sure PMD THP is supported. Also remove the read-only fd
>> check, since collapse_file() now makes sure all to-be-collapsed folios are
>> clean and the created PMD file THP can be handled by FSes properly.
>>
>> Signed-off-by: Zi Yan <[email protected]>
>> ---
>>  mm/huge_memory.c | 8 ++++----
>>  1 file changed, 4 insertions(+), 4 deletions(-)
>>
>> diff --git a/mm/huge_memory.c b/mm/huge_memory.c
>> index 970e077019b7..7e9cf8c0985f 100644
>> --- a/mm/huge_memory.c
>> +++ b/mm/huge_memory.c
>> @@ -86,9 +86,6 @@ static inline bool file_thp_enabled(struct vm_area_struct 
>> *vma)
>>  {
>>      struct inode *inode;
>>
>> -    if (!IS_ENABLED(CONFIG_READ_ONLY_THP_FOR_FS))
>> -            return false;
>> -
>>      if (!vma->vm_file)
>>              return false;
>>
>> @@ -97,7 +94,10 @@ static inline bool file_thp_enabled(struct vm_area_struct 
>> *vma)
>>      if (IS_ANON_FILE(inode))
>>              return false;
>>
>> -    return !inode_is_open_for_write(inode) && S_ISREG(inode->i_mode);
> 
> Hi Matthew, David, and Lorenzo,
> 
> After some discussions on irc, I feel that we probably should not allow
> read-write fd for PMD THP collapse at the moment. Combining with the
> filemap_flush() under folio_dirty() check from collapse_file(), khugepaged
> would become a kwritebackd that scans pagecache folios and writes them back.
> If we limit it to read-only fds, at least khugepaged would only write
> back once for the pagecache folios from these fds.

Makes sense. The comment above the filemap_flush() is valuable :)

> 
> I am planning to restore inode_is_open_for_write() check in the next version.
> Let me know your thoughts.

That would be better. Do we plan on handling races with concurrent 
writable-opening?

Or could we simply gate the filemap_flush() by a inode_is_open_for_write(), to
not have it turn into a kwritebackd()?

-- 
Cheers,

David

Reply via email to