Commit 52826d3b authored by Linus Torvalds's avatar Linus Torvalds

kernel/utsname_sysctl.c: Fix hostname polling

Commit bfca3dd3 ("kernel/utsname_sysctl.c: print kernel arch") added
a new entry to the uts_kern_table[] array, but didn't update the
UTS_PROC_xyz enumerators of older entries, breaking anything that used
them.

Which is admittedly not many cases: it's really just the two uses of
uts_proc_notify() in kernel/sys.c.  But apparently journald-systemd
actually uses this to detect hostname changes.
Reported-by: default avatarTorsten Hilbrich <torsten.hilbrich@secunet.com>
Fixes: bfca3dd3 ("kernel/utsname_sysctl.c: print kernel arch")
Link: https://lore.kernel.org/lkml/0c2b92a6-0f25-9538-178f-eee3b06da23f@secunet.com/
Link: https://linux-regtracking.leemhuis.info/regzbot/regression/0c2b92a6-0f25-9538-178f-eee3b06da23f@secunet.com/
Cc: Petr Vorel <pvorel@suse.cz>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent a7038524
...@@ -10,6 +10,7 @@ ...@@ -10,6 +10,7 @@
#include <uapi/linux/utsname.h> #include <uapi/linux/utsname.h>
enum uts_proc { enum uts_proc {
UTS_PROC_ARCH,
UTS_PROC_OSTYPE, UTS_PROC_OSTYPE,
UTS_PROC_OSRELEASE, UTS_PROC_OSRELEASE,
UTS_PROC_VERSION, UTS_PROC_VERSION,
......
...@@ -74,6 +74,7 @@ static int proc_do_uts_string(struct ctl_table *table, int write, ...@@ -74,6 +74,7 @@ static int proc_do_uts_string(struct ctl_table *table, int write,
static DEFINE_CTL_TABLE_POLL(hostname_poll); static DEFINE_CTL_TABLE_POLL(hostname_poll);
static DEFINE_CTL_TABLE_POLL(domainname_poll); static DEFINE_CTL_TABLE_POLL(domainname_poll);
// Note: update 'enum uts_proc' to match any changes to this table
static struct ctl_table uts_kern_table[] = { static struct ctl_table uts_kern_table[] = {
{ {
.procname = "arch", .procname = "arch",
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment