From mboxrd@z Thu Jan 1 00:00:00 1970 From: Dan Carpenter Date: Sat, 27 Aug 2011 10:00:45 +0000 Subject: [patch] rapidio: potential null deref in rio_setup_device() Message-Id: <20110827100045.GL3775@shale.localdomain> List-Id: MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit To: Matt Porter Cc: Alexandre Bounine , open list , kernel-janitors@vger.kernel.org The "goto cleanup" path can dereference "rswitch" which is NULL here. Signed-off-by: Dan Carpenter --- This is sort of embarrassing, I've patched this function before but missed this. Hopefully it's right now. diff --git a/drivers/rapidio/rio-scan.c b/drivers/rapidio/rio-scan.c index 0914f49..882cef9 100644 --- a/drivers/rapidio/rio-scan.c +++ b/drivers/rapidio/rio-scan.c @@ -432,7 +432,7 @@ static struct rio_dev __devinit *rio_setup_device(struct rio_net *net, /* Assign component tag to device */ if (next_comptag >= 0x10000) { pr_err("RIO: Component Tag Counter Overflow\n"); - goto cleanup; + goto out_rdev; } rio_mport_write_config_32(port, destid, hopcount, RIO_COMPONENT_TAG_CSR, next_comptag); @@ -518,7 +518,7 @@ static struct rio_dev __devinit *rio_setup_device(struct rio_net *net, cleanup: if (rio_is_switch(rdev)) kfree(rswitch->route_table); - +out_rdev: kfree(rdev); return NULL; }