diff options
| author | Julia Lawall <julia@diku.dk> | 2010-05-27 08:37:19 -0400 |
|---|---|---|
| committer | Greg Kroah-Hartman <gregkh@suse.de> | 2010-06-04 16:38:57 -0400 |
| commit | c60e55f30a4dac15db51b398c3bd94e4cfbf743a (patch) | |
| tree | 2eb8f149857dc0d52551532b8ebe4f8c8a7db7d3 | |
| parent | 0aa3f139cd5123ffb8f397b91d777635e9761c24 (diff) | |
Staging: Eliminate a NULL pointer dereference
Eliminate a NULL or near NULL pointer dereference.
A simplified version of the semantic match that finds this problem is as
follows: (http://coccinelle.lip6.fr/)
// <smpl>
@r exists@
expression E,E1;
identifier f;
statement S1,S2,S3;
@@
if ((E == NULL && ...) || ...)
{
... when != if (...) S1 else S2
when != E = E1
* E->f
... when any
return ...;
}
else S3
// </smpl>
Signed-off-by: Julia Lawall <julia@diku.dk>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
| -rw-r--r-- | drivers/staging/comedi/drivers/usbdux.c | 3 | ||||
| -rw-r--r-- | drivers/staging/dt3155/allocator.c | 4 |
2 files changed, 2 insertions, 5 deletions
diff --git a/drivers/staging/comedi/drivers/usbdux.c b/drivers/staging/comedi/drivers/usbdux.c index 86f035d00675..27b4cb2e2ec2 100644 --- a/drivers/staging/comedi/drivers/usbdux.c +++ b/drivers/staging/comedi/drivers/usbdux.c | |||
| @@ -351,8 +351,7 @@ static int usbdux_ai_stop(struct usbduxsub *this_usbduxsub, int do_unlink) | |||
| 351 | int ret = 0; | 351 | int ret = 0; |
| 352 | 352 | ||
| 353 | if (!this_usbduxsub) { | 353 | if (!this_usbduxsub) { |
| 354 | dev_err(&this_usbduxsub->interface->dev, | 354 | pr_err("comedi?: usbdux_ai_stop: this_usbduxsub=NULL!\n"); |
| 355 | "comedi?: usbdux_ai_stop: this_usbduxsub=NULL!\n"); | ||
| 356 | return -EFAULT; | 355 | return -EFAULT; |
| 357 | } | 356 | } |
| 358 | dev_dbg(&this_usbduxsub->interface->dev, "comedi: usbdux_ai_stop\n"); | 357 | dev_dbg(&this_usbduxsub->interface->dev, "comedi: usbdux_ai_stop\n"); |
diff --git a/drivers/staging/dt3155/allocator.c b/drivers/staging/dt3155/allocator.c index bd5adbc2a238..d33947b0378f 100644 --- a/drivers/staging/dt3155/allocator.c +++ b/drivers/staging/dt3155/allocator.c | |||
| @@ -176,9 +176,7 @@ int allocator_free_dma(unsigned long address) | |||
| 176 | prev = ptr; ptr = ptr->next; | 176 | prev = ptr; ptr = ptr->next; |
| 177 | 177 | ||
| 178 | if (!ptr) { | 178 | if (!ptr) { |
| 179 | printk(KERN_ERR ALL_MSG | 179 | pr_err(ALL_MSG "free_dma but add. not allocated\n"); |
| 180 | "free_dma(0x%08lx) but add. not allocated\n", | ||
| 181 | ptr->address); | ||
| 182 | return -EINVAL; | 180 | return -EINVAL; |
| 183 | } | 181 | } |
| 184 | PDEBUGG("freeing: %08lx (%li) next %08lx\n", ptr->address, ptr->size, | 182 | PDEBUGG("freeing: %08lx (%li) next %08lx\n", ptr->address, ptr->size, |
