various minor cleanups for 2.4.13-pre2 (patch included, comments wanted

Jesper Juhl (juhl@eisenstein.dk)
Sun, 14 Oct 2001 13:00:30 +0200


This is a multi-part message in MIME format.
--------------BF9AB8D7DD9B0079ED713531
Content-Type: text/plain; charset=us-ascii
Content-Transfer-Encoding: 7bit

Hi,

While reading through the kernel source (2.4.13-pre2) I've found a few very minor things that I believe are not optimal,
so I've created a patch to fix them.

Here's a list of the files/functions that the patch changes and a small description of the change. Comments are very welcome.

init/main.c : root_dev_setup()
In the for() loop the counter "i" is compared to "sizeof root_device_name". "i" is declared as int
(signed) and sizeof always returns an unsigned value, so I believe "i" should be declared unsigned.

init/main.c : parse_options()
The check that adds "line" to either "envp_init" or "argv_init" checks to see if the buffers are full
and break;s the while() loop if _either_ buffer is full - it should use continue; so both buffers can
get a chance to fill up.
Robert M. Love should get credit for finding this one, I found it by looking at an old patch of his, and
I just checked to see if it was still there and read the code to see if it was correct.

kernel/exec_domain.c :
Contrary to most other files in the kernel source the functions in exec_domain.c are defined with the
return values on a line by themselves. Most places in kernel source have the entire function definition
on a single line (as long as it does not exceed 80 chars in length). So I moved the function definitions
onto a single line.

kernel/exec_domain.c : get_exec_domain_list()
The len variable (signed) is compared to PAGE_SIZE (unsigned). Changing len to "unsigned int" avoids
comparison between signed and unsigned.

It seems that there are tons of places throughout the kernel where signed and unsigned variables are
compared. I won't mind going through the source and try to see where this can be avoided easily, but I'm
not sure it it's worth the effort?

The patch itself is attached as "2.4.13-pre2-misc.patch".

Best regards,
Jesper Juhl
juhl@eisenstein.dk

--------------BF9AB8D7DD9B0079ED713531
Content-Type: text/plain; charset=us-ascii;
name="2.4.13-pre2-misc.patch"
Content-Transfer-Encoding: 7bit
Content-Disposition: inline;
filename="2.4.13-pre2-misc.patch"

diff -ur linux-2.4.13-pre2-orig/init/main.c linux-2.4.13-pre2/init/main.c
--- linux-2.4.13-pre2-orig/init/main.c Sun Oct 14 10:23:21 2001
+++ linux-2.4.13-pre2/init/main.c Sun Oct 14 11:23:09 2001
@@ -291,7 +291,7 @@

static int __init root_dev_setup(char *line)
{
- int i;
+ unsigned int i;
char ch;

ROOT_DEV = name_to_kdev_t(line);
@@ -465,11 +465,11 @@
*/
if (strchr(line,'=')) {
if (envs >= MAX_INIT_ENVS)
- break;
+ continue;
envp_init[++envs] = line;
} else {
if (args >= MAX_INIT_ARGS)
- break;
+ continue;
if (*line)
argv_init[++args] = line;
}
diff -ur linux-2.4.13-pre2-orig/kernel/exec_domain.c linux-2.4.13-pre2/kernel/exec_domain.c
--- linux-2.4.13-pre2-orig/kernel/exec_domain.c Fri Oct 5 01:41:54 2001
+++ linux-2.4.13-pre2/kernel/exec_domain.c Sun Oct 14 12:07:50 2001
@@ -40,8 +40,7 @@
};


-static void
-default_handler(int segment, struct pt_regs *regp)
+static void default_handler(int segment, struct pt_regs *regp)
{
u_long pers = 0;

@@ -73,8 +72,7 @@
send_sig(SIGSEGV, current, 1);
}

-static struct exec_domain *
-lookup_exec_domain(u_long personality)
+static struct exec_domain *lookup_exec_domain(u_long personality)
{
struct exec_domain * ep;
char buffer[30];
@@ -106,8 +104,7 @@
return (ep);
}

-int
-register_exec_domain(struct exec_domain *ep)
+int register_exec_domain(struct exec_domain *ep)
{
struct exec_domain *tmp;
int err = -EBUSY;
@@ -133,8 +130,7 @@
return (err);
}

-int
-unregister_exec_domain(struct exec_domain *ep)
+int unregister_exec_domain(struct exec_domain *ep)
{
struct exec_domain **epp;

@@ -154,8 +150,7 @@
return 0;
}

-int
-__set_personality(u_long personality)
+int __set_personality(u_long personality)
{
struct exec_domain *ep, *oep;

@@ -201,11 +196,10 @@
return 0;
}

-int
-get_exec_domain_list(char *page)
+int get_exec_domain_list(char *page)
{
struct exec_domain *ep;
- int len = 0;
+ unsigned int len = 0;

read_lock(&exec_domains_lock);
for (ep = exec_domains; ep && len < PAGE_SIZE - 80; ep = ep->next)
@@ -216,8 +210,7 @@
return (len);
}

-asmlinkage long
-sys_personality(u_long personality)
+asmlinkage long sys_personality(u_long personality)
{
u_long old = current->personality;;

@@ -274,8 +267,7 @@
{0}
};

-static int __init
-abi_register_sysctl(void)
+static int __init abi_register_sysctl(void)
{
register_sysctl_table(abi_root_table, 1);
return 0;

--------------BF9AB8D7DD9B0079ED713531--

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/