diff options
-rw-r--r-- | fs/proc/proc_sysctl.c | 4 | ||||
-rw-r--r-- | include/linux/sysctl.h | 17 | ||||
-rw-r--r-- | kernel/sysctl.c | 29 |
3 files changed, 11 insertions, 39 deletions
diff --git a/fs/proc/proc_sysctl.c b/fs/proc/proc_sysctl.c index f667e8aeabd..6ff9981f0a1 100644 --- a/fs/proc/proc_sysctl.c +++ b/fs/proc/proc_sysctl.c | |||
@@ -48,7 +48,7 @@ out: | |||
48 | static struct ctl_table *find_in_table(struct ctl_table *p, struct qstr *name) | 48 | static struct ctl_table *find_in_table(struct ctl_table *p, struct qstr *name) |
49 | { | 49 | { |
50 | int len; | 50 | int len; |
51 | for ( ; p->ctl_name || p->procname; p++) { | 51 | for ( ; p->procname; p++) { |
52 | 52 | ||
53 | if (!p->procname) | 53 | if (!p->procname) |
54 | continue; | 54 | continue; |
@@ -218,7 +218,7 @@ static int scan(struct ctl_table_header *head, ctl_table *table, | |||
218 | void *dirent, filldir_t filldir) | 218 | void *dirent, filldir_t filldir) |
219 | { | 219 | { |
220 | 220 | ||
221 | for (; table->ctl_name || table->procname; table++, (*pos)++) { | 221 | for (; table->procname; table++, (*pos)++) { |
222 | int res; | 222 | int res; |
223 | 223 | ||
224 | /* Can't do anything without a proc name */ | 224 | /* Can't do anything without a proc name */ |
diff --git a/include/linux/sysctl.h b/include/linux/sysctl.h index 82c32b89932..7c4aabc0467 100644 --- a/include/linux/sysctl.h +++ b/include/linux/sysctl.h | |||
@@ -1005,8 +1005,8 @@ extern ctl_handler sysctl_ms_jiffies; | |||
1005 | 1005 | ||
1006 | /* | 1006 | /* |
1007 | * Register a set of sysctl names by calling register_sysctl_table | 1007 | * Register a set of sysctl names by calling register_sysctl_table |
1008 | * with an initialised array of struct ctl_table's. An entry with zero | 1008 | * with an initialised array of struct ctl_table's. An entry with |
1009 | * ctl_name and NULL procname terminates the table. table->de will be | 1009 | * NULL procname terminates the table. table->de will be |
1010 | * set up by the registration and need not be initialised in advance. | 1010 | * set up by the registration and need not be initialised in advance. |
1011 | * | 1011 | * |
1012 | * sysctl names can be mirrored automatically under /proc/sys. The | 1012 | * sysctl names can be mirrored automatically under /proc/sys. The |
@@ -1019,24 +1019,11 @@ extern ctl_handler sysctl_ms_jiffies; | |||
1019 | * under /proc; non-leaf nodes will be represented by directories. A | 1019 | * under /proc; non-leaf nodes will be represented by directories. A |
1020 | * null procname disables /proc mirroring at this node. | 1020 | * null procname disables /proc mirroring at this node. |
1021 | * | 1021 | * |
1022 | * sysctl entries with a zero ctl_name will not be available through | ||
1023 | * the binary sysctl interface. | ||
1024 | * | ||
1025 | * sysctl(2) can automatically manage read and write requests through | 1022 | * sysctl(2) can automatically manage read and write requests through |
1026 | * the sysctl table. The data and maxlen fields of the ctl_table | 1023 | * the sysctl table. The data and maxlen fields of the ctl_table |
1027 | * struct enable minimal validation of the values being written to be | 1024 | * struct enable minimal validation of the values being written to be |
1028 | * performed, and the mode field allows minimal authentication. | 1025 | * performed, and the mode field allows minimal authentication. |
1029 | * | 1026 | * |
1030 | * More sophisticated management can be enabled by the provision of a | ||
1031 | * strategy routine with the table entry. This will be called before | ||
1032 | * any automatic read or write of the data is performed. | ||
1033 | * | ||
1034 | * The strategy routine may return: | ||
1035 | * <0: Error occurred (error is passed to user process) | ||
1036 | * 0: OK - proceed with automatic read or write. | ||
1037 | * >0: OK - read or write has been done by the strategy routine, so | ||
1038 | * return immediately. | ||
1039 | * | ||
1040 | * There must be a proc_handler routine for any terminal nodes | 1027 | * There must be a proc_handler routine for any terminal nodes |
1041 | * mirrored under /proc/sys (non-terminals are handled by a built-in | 1028 | * mirrored under /proc/sys (non-terminals are handled by a built-in |
1042 | * directory handler). Several default handlers are available to | 1029 | * directory handler). Several default handlers are available to |
diff --git a/kernel/sysctl.c b/kernel/sysctl.c index f6dacc383c1..b6b6eb1abeb 100644 --- a/kernel/sysctl.c +++ b/kernel/sysctl.c | |||
@@ -1618,7 +1618,7 @@ int sysctl_perm(struct ctl_table_root *root, struct ctl_table *table, int op) | |||
1618 | 1618 | ||
1619 | static void sysctl_set_parent(struct ctl_table *parent, struct ctl_table *table) | 1619 | static void sysctl_set_parent(struct ctl_table *parent, struct ctl_table *table) |
1620 | { | 1620 | { |
1621 | for (; table->ctl_name || table->procname; table++) { | 1621 | for (; table->procname; table++) { |
1622 | table->parent = parent; | 1622 | table->parent = parent; |
1623 | if (table->child) | 1623 | if (table->child) |
1624 | sysctl_set_parent(table, table->child); | 1624 | sysctl_set_parent(table, table->child); |
@@ -1650,11 +1650,11 @@ static struct ctl_table *is_branch_in(struct ctl_table *branch, | |||
1650 | return NULL; | 1650 | return NULL; |
1651 | 1651 | ||
1652 | /* ... and nothing else */ | 1652 | /* ... and nothing else */ |
1653 | if (branch[1].procname || branch[1].ctl_name) | 1653 | if (branch[1].procname) |
1654 | return NULL; | 1654 | return NULL; |
1655 | 1655 | ||
1656 | /* table should contain subdirectory with the same name */ | 1656 | /* table should contain subdirectory with the same name */ |
1657 | for (p = table; p->procname || p->ctl_name; p++) { | 1657 | for (p = table; p->procname; p++) { |
1658 | if (!p->child) | 1658 | if (!p->child) |
1659 | continue; | 1659 | continue; |
1660 | if (p->procname && strcmp(p->procname, s) == 0) | 1660 | if (p->procname && strcmp(p->procname, s) == 0) |
@@ -1699,8 +1699,7 @@ static void try_attach(struct ctl_table_header *p, struct ctl_table_header *q) | |||
1699 | * | 1699 | * |
1700 | * The members of the &struct ctl_table structure are used as follows: | 1700 | * The members of the &struct ctl_table structure are used as follows: |
1701 | * | 1701 | * |
1702 | * ctl_name - This is the numeric sysctl value used by sysctl(2). The number | 1702 | * ctl_name - Dead |
1703 | * must be unique within that level of sysctl | ||
1704 | * | 1703 | * |
1705 | * procname - the name of the sysctl file under /proc/sys. Set to %NULL to not | 1704 | * procname - the name of the sysctl file under /proc/sys. Set to %NULL to not |
1706 | * enter a sysctl file | 1705 | * enter a sysctl file |
@@ -1716,7 +1715,7 @@ static void try_attach(struct ctl_table_header *p, struct ctl_table_header *q) | |||
1716 | * | 1715 | * |
1717 | * proc_handler - the text handler routine (described below) | 1716 | * proc_handler - the text handler routine (described below) |
1718 | * | 1717 | * |
1719 | * strategy - the strategy routine (described below) | 1718 | * strategy - Dead |
1720 | * | 1719 | * |
1721 | * de - for internal use by the sysctl routines | 1720 | * de - for internal use by the sysctl routines |
1722 | * | 1721 | * |
@@ -1730,19 +1729,6 @@ static void try_attach(struct ctl_table_header *p, struct ctl_table_header *q) | |||
1730 | * struct enable minimal validation of the values being written to be | 1729 | * struct enable minimal validation of the values being written to be |
1731 | * performed, and the mode field allows minimal authentication. | 1730 | * performed, and the mode field allows minimal authentication. |
1732 | * | 1731 | * |
1733 | * More sophisticated management can be enabled by the provision of a | ||
1734 | * strategy routine with the table entry. This will be called before | ||
1735 | * any automatic read or write of the data is performed. | ||
1736 | * | ||
1737 | * The strategy routine may return | ||
1738 | * | ||
1739 | * < 0 - Error occurred (error is passed to user process) | ||
1740 | * | ||
1741 | * 0 - OK - proceed with automatic read or write. | ||
1742 | * | ||
1743 | * > 0 - OK - read or write has been done by the strategy routine, so | ||
1744 | * return immediately. | ||
1745 | * | ||
1746 | * There must be a proc_handler routine for any terminal nodes | 1732 | * There must be a proc_handler routine for any terminal nodes |
1747 | * mirrored under /proc/sys (non-terminals are handled by a built-in | 1733 | * mirrored under /proc/sys (non-terminals are handled by a built-in |
1748 | * directory handler). Several default handlers are available to | 1734 | * directory handler). Several default handlers are available to |
@@ -1769,13 +1755,13 @@ struct ctl_table_header *__register_sysctl_paths( | |||
1769 | struct ctl_table_set *set; | 1755 | struct ctl_table_set *set; |
1770 | 1756 | ||
1771 | /* Count the path components */ | 1757 | /* Count the path components */ |
1772 | for (npath = 0; path[npath].ctl_name || path[npath].procname; ++npath) | 1758 | for (npath = 0; path[npath].procname; ++npath) |
1773 | ; | 1759 | ; |
1774 | 1760 | ||
1775 | /* | 1761 | /* |
1776 | * For each path component, allocate a 2-element ctl_table array. | 1762 | * For each path component, allocate a 2-element ctl_table array. |
1777 | * The first array element will be filled with the sysctl entry | 1763 | * The first array element will be filled with the sysctl entry |
1778 | * for this, the second will be the sentinel (ctl_name == 0). | 1764 | * for this, the second will be the sentinel (procname == 0). |
1779 | * | 1765 | * |
1780 | * We allocate everything in one go so that we don't have to | 1766 | * We allocate everything in one go so that we don't have to |
1781 | * worry about freeing additional memory in unregister_sysctl_table. | 1767 | * worry about freeing additional memory in unregister_sysctl_table. |
@@ -1792,7 +1778,6 @@ struct ctl_table_header *__register_sysctl_paths( | |||
1792 | for (n = 0; n < npath; ++n, ++path) { | 1778 | for (n = 0; n < npath; ++n, ++path) { |
1793 | /* Copy the procname */ | 1779 | /* Copy the procname */ |
1794 | new->procname = path->procname; | 1780 | new->procname = path->procname; |
1795 | new->ctl_name = path->ctl_name; | ||
1796 | new->mode = 0555; | 1781 | new->mode = 0555; |
1797 | 1782 | ||
1798 | *prevp = new; | 1783 | *prevp = new; |