Procházet zdrojové kódy

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>
Lucas De Marchi před 14 roky
rodič
revize
36885d7b11
1 změnil soubory, kde provedl 2 přidání a 12 odebrání
  1. 2 12
      fs/proc/proc_sysctl.c

+ 2 - 12
fs/proc/proc_sysctl.c

@@ -59,17 +59,11 @@ out:
 
 
 static struct ctl_table *find_in_table(struct ctl_table *p, struct qstr *name)
 static struct ctl_table *find_in_table(struct ctl_table *p, struct qstr *name)
 {
 {
-	int len;
 	for ( ; p->procname; p++) {
 	for ( ; p->procname; p++) {
-
-		if (!p->procname)
-			continue;
-
-		len = strlen(p->procname);
-		if (len != name->len)
+		if (strlen(p->procname) != name->len)
 			continue;
 			continue;
 
 
-		if (memcmp(p->procname, name->name, len) != 0)
+		if (memcmp(p->procname, name->name, name->len) != 0)
 			continue;
 			continue;
 
 
 		/* I have a match */
 		/* I have a match */
@@ -266,10 +260,6 @@ static int scan(struct ctl_table_header *head, ctl_table *table,
 	for (; table->procname; table++, (*pos)++) {
 	for (; table->procname; table++, (*pos)++) {
 		int res;
 		int res;
 
 
-		/* Can't do anything without a proc name */
-		if (!table->procname)
-			continue;
-
 		if (*pos < file->f_pos)
 		if (*pos < file->f_pos)
 			continue;
 			continue;