sysctl: remove impossible condition check
Remove checks for conditions that will never happen. If procname is NULL the loop would already had bailed out, so there's no need to check it again. At the same time this also compacts the function find_in_table() by refactoring it to be easier to read. Signed-off-by: Lucas De Marchi <lucas.demarchi@profusion.mobi> Reviewed-by: Jesper Juhl <jj@chaosbits.net> Signed-off-by: Eric W. Biederman <ebiederm@xmission.com>
此提交包含在:
@@ -59,17 +59,11 @@ out:
|
||||
|
||||
static struct ctl_table *find_in_table(struct ctl_table *p, struct qstr *name)
|
||||
{
|
||||
int len;
|
||||
for ( ; p->procname; p++) {
|
||||
|
||||
if (!p->procname)
|
||||
if (strlen(p->procname) != name->len)
|
||||
continue;
|
||||
|
||||
len = strlen(p->procname);
|
||||
if (len != name->len)
|
||||
continue;
|
||||
|
||||
if (memcmp(p->procname, name->name, len) != 0)
|
||||
if (memcmp(p->procname, name->name, name->len) != 0)
|
||||
continue;
|
||||
|
||||
/* I have a match */
|
||||
@@ -266,10 +260,6 @@ static int scan(struct ctl_table_header *head, ctl_table *table,
|
||||
for (; table->procname; table++, (*pos)++) {
|
||||
int res;
|
||||
|
||||
/* Can't do anything without a proc name */
|
||||
if (!table->procname)
|
||||
continue;
|
||||
|
||||
if (*pos < file->f_pos)
|
||||
continue;
|
||||
|
||||
|
新增問題並參考
封鎖使用者