changing definition of NULL to ((void *)0) for C

Nicolas Thery nthery at gmail.com
Tue Jun 3 03:36:38 PDT 2008


2008/6/2 Sascha Wildner <saw at online.de>:
> Hi all,
>
> the following patch will add <sys/_null.h> which defines NULL as 0 for C++
> and as ((void *)0) for C, similar to FreeBSD. Currently NULL is always 0
> (except for a few things which redefine it).
>
> The remainder of the patch changes our headers to #include <sys/_null.h>
> where NULL was defined previously and fixes a number of warnings which
> cropped up once NULL was void *. It also removes some casts of NULL to void
> * which are currently needed to "fix" the "missing sentinel in function
> call" warnings.
>
> http://leaf.dragonflybsd.org/~swildner/NULL.diff
>
> If no one objects, I'll commit this on Thursday.

That looks like a good thing to me.  You must have spent quite some
time making all these changes!

I reviewed the 1st half only.  I've got only a pedantic remark.  NULL
should be changed to 0 in the following diff :-)

RCS file: /home/dcvs/src/gnu/usr.bin/gdb/kgdb/trgt_i386.c,v
retrieving revision 1.5
diff -u -r1.5 trgt_i386.c
--- gnu/usr.bin/gdb/kgdb/trgt_i386.c	14 Jan 2008 21:36:38 -0000	1.5
+++ gnu/usr.bin/gdb/kgdb/trgt_i386.c	1 Jun 2008 02:24:14 -0000
@@ -63,7 +63,7 @@
 	/*
 	 * kt->pcb == NULL is a marker for "non-dumping kernel thread".
 	 */
-	if (kt->pcb == NULL) {
+	if (kt->pcb == 0) {
 		uintptr_t regs[5];
 		uintptr_t addr;
 		uintptr_t sp;

Cheers,
Nicolas





More information about the Kernel mailing list