Commit eb32d3ad authored by Thomas Weißschuh's avatar Thomas Weißschuh Committed by Joel Granados

sysctl: drop sysctl_is_perm_empty_ctl_table

It is used only twice and those callers are simpler with
sysctl_is_perm_empty_ctl_header().
So use this sibling function.

This is part of an effort to constify definition of struct ctl_table.
For this effort the mutable member 'type' is moved from
struct ctl_table to struct ctl_table_header.
Unifying the macros sysctl_is_perm_empty_ctl_* makes this easier.
Signed-off-by: default avatarThomas Weißschuh <linux@weissschuh.net>
Signed-off-by: default avatarJoel Granados <j.granados@samsung.com>
parent 795f90c6
...@@ -48,10 +48,8 @@ struct ctl_table_header *register_sysctl_mount_point(const char *path) ...@@ -48,10 +48,8 @@ struct ctl_table_header *register_sysctl_mount_point(const char *path)
} }
EXPORT_SYMBOL(register_sysctl_mount_point); EXPORT_SYMBOL(register_sysctl_mount_point);
#define sysctl_is_perm_empty_ctl_table(tptr) \
(tptr[0].type == SYSCTL_TABLE_TYPE_PERMANENTLY_EMPTY)
#define sysctl_is_perm_empty_ctl_header(hptr) \ #define sysctl_is_perm_empty_ctl_header(hptr) \
(sysctl_is_perm_empty_ctl_table(hptr->ctl_table)) (hptr->ctl_table[0].type == SYSCTL_TABLE_TYPE_PERMANENTLY_EMPTY)
#define sysctl_set_perm_empty_ctl_header(hptr) \ #define sysctl_set_perm_empty_ctl_header(hptr) \
(hptr->ctl_table[0].type = SYSCTL_TABLE_TYPE_PERMANENTLY_EMPTY) (hptr->ctl_table[0].type = SYSCTL_TABLE_TYPE_PERMANENTLY_EMPTY)
#define sysctl_clear_perm_empty_ctl_header(hptr) \ #define sysctl_clear_perm_empty_ctl_header(hptr) \
...@@ -233,7 +231,7 @@ static int insert_header(struct ctl_dir *dir, struct ctl_table_header *header) ...@@ -233,7 +231,7 @@ static int insert_header(struct ctl_dir *dir, struct ctl_table_header *header)
/* Am I creating a permanently empty directory? */ /* Am I creating a permanently empty directory? */
if (header->ctl_table_size > 0 && if (header->ctl_table_size > 0 &&
sysctl_is_perm_empty_ctl_table(header->ctl_table)) { sysctl_is_perm_empty_ctl_header(header)) {
if (!RB_EMPTY_ROOT(&dir->root)) if (!RB_EMPTY_ROOT(&dir->root))
return -EINVAL; return -EINVAL;
sysctl_set_perm_empty_ctl_header(dir_h); sysctl_set_perm_empty_ctl_header(dir_h);
...@@ -1204,7 +1202,7 @@ static bool get_links(struct ctl_dir *dir, ...@@ -1204,7 +1202,7 @@ static bool get_links(struct ctl_dir *dir,
struct ctl_table *entry, *link; struct ctl_table *entry, *link;
if (header->ctl_table_size == 0 || if (header->ctl_table_size == 0 ||
sysctl_is_perm_empty_ctl_table(header->ctl_table)) sysctl_is_perm_empty_ctl_header(header))
return true; return true;
/* Are there links available for every entry in table? */ /* Are there links available for every entry in table? */
......
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