On 17.09.25 20:51, Kyle Meyer wrote:
On Wed, Sep 17, 2025 at 09:02:55AM +0200, David Hildenbrand wrote:

+
+       0 - Enable soft offline
+       1 - Disable soft offline for HugeTLB pages
+
+Supported values::
+
+       0 - Soft offline is disabled
+       1 - Soft offline is enabled
+       3 - Soft offline is enabled (disabled for HugeTLB pages)

This looks very adhoc even though existing behavior is preserved.

- Are HugeTLB pages the only page types to be considered ?
- How the remaining bits here are going to be used later ?


What I proposed (that could be better documented here) is that all other
bits except the first one will be a disable mask when bit 0 is set.

2 - ... but yet disabled for hugetlb
4 - ... but yet disabled for $WHATEVER
8 - ... but yet disabled for $WHATEVERELSE

Also without a bit-wise usage roadmap, is not changing a procfs
interface (ABI) bit problematic ?

For now we failed setting it to values that are neither 0 or 1, IIUC
set_enable_soft_offline() correctly?

Yes, -EINVAL will be returned.

So there should not be any problem, or which scenario do you have in mind?

Here's an alternative approach.

Do not modify the existing sysctl parameter:

/proc/sys/vm/enable_soft_offline

0 - Soft offline is disabled
1 - Soft offline is enabled

Instead, introduce a new sysctl parameter:

/proc/sys/vm/enable_soft_offline_hugetlb

0 - Soft offline is disabled for HugeTLB pages
1 - Soft offline is enabled for HugeTLB pages

and note in documentation that this setting only takes effect if
enable_soft_offline is enabled.

Anshuman (and David), would you prefer this?

Hmm, at least I don't particularly like that. For each new exception we would create a new file, and the file has weird semantics such that it has no meaning when enable_soft_offline=0.

--
Cheers

David / dhildenb


Reply via email to