Re: [PATCH 3/3] kernel/hung_task convert hung_task_panic boot parameter to sysctl

From: Vlastimil Babka
Date: Tue Mar 31 2020 - 03:27:33 EST


On 3/31/20 2:34 AM, John Hubbard wrote:
> On 3/30/20 10:43 AM, Kees Cook wrote:
> ...
>>> diff --git a/Documentation/admin-guide/kernel-parameters.txt b/Documentation/admin-guide/kernel-parameters.txt
>>> index 81ff626fc700..e0b8840404a1 100644
>>> --- a/Documentation/admin-guide/kernel-parameters.txt
>>> +++ b/Documentation/admin-guide/kernel-parameters.txt
>>> @@ -1457,7 +1457,7 @@
>>> [KNL] Should the hung task detector generate panics.
>>> Format: <integer>
>>>
>>> - A nonzero value instructs the kernel to panic when a
>>> + A value of 1 instructs the kernel to panic when a
>>> hung task is detected. The default value is controlled
>>> by the CONFIG_BOOTPARAM_HUNG_TASK_PANIC build-time
>>> option. The value selected by this boot parameter can
>>> diff --git a/fs/proc/proc_sysctl.c b/fs/proc/proc_sysctl.c
>>> index 97eb0b552bf8..77b1b844b02b 100644
>>> --- a/fs/proc/proc_sysctl.c
>>> +++ b/fs/proc/proc_sysctl.c
>>> @@ -1743,6 +1743,7 @@ struct sysctl_alias {
>>> */
>>> static const struct sysctl_alias sysctl_aliases[] = {
>>> {"numa_zonelist_order", "vm.numa_zonelist_order" },
>
>
> Hi Vlastimil,
>
> Maybe best to delete the above line? Because:
>
> a) it was added as an example, and now that you have a real use case in this patch,
> the example is no longer required, and
>
> b) numa_zonelist_order is deprecated, as a boot param. Adding support to it in this
> brand-new mechanism seems to be going a bit in the opposite direction of deprecation.

Well, this aliases table is not the brand new mechanism, it's just for handling
sysctls that also have a legacy boot param. numa_zonelist_order is such legacy
boot param, so we can handle it here instead of its special handler. If we
decide to remove it later, we can do that, but there is no user-visible effect
on its deprecation by this series.

> And, I don't think you really want all the sysctls to be enabled as boot params, right? Your

The point of Patch 1 is very much so that all sysctls can be set using a boot
param in the form of sysctl.foo.bar=baz

> comment right above sysctl_aliases[] (shown in patch 2) sort of indicates that only some items
> are meant to be both sysctl's and boot params. And that makes sense.

Patches 2+3 are only about handling the legacy boot params that have a sysctl
counterpart.

> In fact, the sysctl_aliases[] is (or could be) effectively the whitelist that Luis Chamberlain
> was requesting in another thread. A whitelist makes good sense, for the reasons Luis listed.
> As such, keeping it limited to items that we want, seems like the way to go, IMHO.

See my reply there once I send it :)

> thanks,
>