Lines Matching refs:ctl_table
31 struct ctl_table sysctl_mount_point[] = {
37 return head->ctl_table[0].child == sysctl_mount_point; in is_empty_dir()
42 dir->header.ctl_table[0].child = sysctl_mount_point; in set_empty_dir()
48 dir->header.ctl_table[0].child = NULL; in clear_empty_dir()
60 static struct ctl_table root_table[] = {
71 .ctl_table = root_table }},
82 struct ctl_table **pentry);
90 pr_cont("%s/", dir->header.ctl_table[0].procname); in sysctl_print_dir()
109 static struct ctl_table *find_entry(struct ctl_table_header **phead, in find_entry()
113 struct ctl_table *entry; in find_entry()
124 entry = &head->ctl_table[ctl_node - head->node]; in find_entry()
140 static int insert_entry(struct ctl_table_header *head, struct ctl_table *entry) in insert_entry()
142 struct rb_node *node = &head->node[entry - head->ctl_table].node; in insert_entry()
150 struct ctl_table *parent_entry; in insert_entry()
158 parent_entry = &parent_head->ctl_table[parent_node - parent_head->node]; in insert_entry()
179 static void erase_entry(struct ctl_table_header *head, struct ctl_table *entry) in erase_entry()
181 struct rb_node *node = &head->node[entry - head->ctl_table].node; in erase_entry()
188 struct ctl_node *node, struct ctl_table *table) in init_header()
190 head->ctl_table = table; in init_header()
202 struct ctl_table *entry; in init_header()
210 struct ctl_table *entry; in erase_header()
211 for (entry = head->ctl_table; entry->procname; entry++) in erase_header()
217 struct ctl_table *entry; in insert_header()
225 if (header->ctl_table == sysctl_mount_point) { in insert_header()
236 for (entry = header->ctl_table; entry->procname; entry++) { in insert_header()
246 if (header->ctl_table == sysctl_mount_point) in insert_header()
367 static struct ctl_table *lookup_entry(struct ctl_table_header **phead, in lookup_entry()
372 struct ctl_table *entry; in lookup_entry()
397 struct ctl_table_header **phead, struct ctl_table **pentry) in first_entry()
400 struct ctl_table *entry = NULL; in first_entry()
408 entry = &head->ctl_table[ctl_node - head->node]; in first_entry()
414 static void next_entry(struct ctl_table_header **phead, struct ctl_table **pentry) in next_entry()
417 struct ctl_table *entry = *pentry; in next_entry()
418 struct ctl_node *ctl_node = &head->node[entry - head->ctl_table]; in next_entry()
428 entry = &head->ctl_table[ctl_node - head->node]; in next_entry()
450 static int sysctl_perm(struct ctl_table_header *head, struct ctl_table *table, int op) in sysctl_perm()
464 struct ctl_table_header *head, struct ctl_table *table) in proc_sys_make_inode()
537 struct ctl_table *p; in proc_sys_lookup()
580 struct ctl_table *table = PROC_I(inode)->sysctl_entry; in proc_sys_call_handler()
642 struct ctl_table *table = PROC_I(inode)->sysctl_entry; in proc_sys_open()
660 struct ctl_table *table = PROC_I(inode)->sysctl_entry; in proc_sys_poll()
691 struct ctl_table *table) in proc_sys_fill_cache()
740 struct ctl_table *table) in proc_sys_link_fill_cache()
758 static int scan(struct ctl_table_header *head, struct ctl_table *table, in scan()
782 struct ctl_table *entry; in proc_sys_readdir()
814 struct ctl_table *table; in proc_sys_permission()
857 struct ctl_table *table = PROC_I(inode)->sysctl_entry; in proc_sys_getattr()
954 struct ctl_table *entry; in find_subdir()
967 struct ctl_table *table; in new_dir()
973 sizeof(struct ctl_table)*2 + namelen + 1, in new_dir()
979 table = (struct ctl_table *)(node + 1); in new_dir()
1061 procname = dir->header.ctl_table[0].procname; in xlate_dir()
1066 struct ctl_table **pentry) in sysctl_follow_link()
1071 struct ctl_table *entry; in sysctl_follow_link()
1099 static int sysctl_err(const char *path, struct ctl_table *table, char *fmt, ...) in sysctl_err()
1115 static int sysctl_check_table_array(const char *path, struct ctl_table *table) in sysctl_check_table_array()
1128 static int sysctl_check_table(const char *path, struct ctl_table *table) in sysctl_check_table()
1162 static struct ctl_table_header *new_links(struct ctl_dir *dir, struct ctl_table *table, in new_links()
1165 struct ctl_table *link_table, *entry, *link; in new_links()
1180 sizeof(struct ctl_table)*(nr_entries + 1) + in new_links()
1188 link_table = (struct ctl_table *)(node + nr_entries); in new_links()
1206 struct ctl_table *table, struct ctl_table_root *link_root) in get_links()
1209 struct ctl_table *entry, *link; in get_links()
1247 if (get_links(core_parent, head->ctl_table, head->root)) in insert_links()
1253 links = new_links(core_parent, head->ctl_table, head->root); in insert_links()
1261 if (get_links(core_parent, head->ctl_table, head->root)) { in insert_links()
1318 const char *path, struct ctl_table *table) in __register_sysctl_table()
1324 struct ctl_table *entry; in __register_sysctl_table()
1393 struct ctl_table_header *register_sysctl(const char *path, struct ctl_table *table) in register_sysctl()
1413 static int count_subheaders(struct ctl_table *table) in count_subheaders()
1417 struct ctl_table *entry; in count_subheaders()
1434 struct ctl_table *table) in register_leaf_sysctl_tables()
1436 struct ctl_table *ctl_table_arg = NULL; in register_leaf_sysctl_tables()
1437 struct ctl_table *entry, *files; in register_leaf_sysctl_tables()
1452 struct ctl_table *new; in register_leaf_sysctl_tables()
1453 files = kcalloc(nr_files + 1, sizeof(struct ctl_table), in register_leaf_sysctl_tables()
1519 const struct ctl_path *path, struct ctl_table *table) in __register_sysctl_paths()
1521 struct ctl_table *ctl_table_arg = table; in __register_sysctl_paths()
1569 struct ctl_table *table = subh->ctl_table_arg; in __register_sysctl_paths()
1589 struct ctl_table *table) in register_sysctl_paths()
1605 struct ctl_table_header *register_sysctl_table(struct ctl_table *table) in register_sysctl_table()
1619 struct ctl_table *entry; in put_links()
1628 for (entry = header->ctl_table; entry->procname; entry++) { in put_links()
1630 struct ctl_table *link; in put_links()
1689 struct ctl_table *table = subh->ctl_table_arg; in unregister_sysctl_table()