Re: [PATCH] advansys: use request_firmware

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Fri, Jul 11, 2008 at 03:28:42PM +0530, Jaswinder Singh wrote:
> ???this is a first draft; please be kind :)

Hi Jaswinder, I wondered when you were going to get around to advansys
;-)  My concern is:

> -/* Microcode buffer is kept after initialization for error recovery. */
[...]
> +	err = request_firmware(&fw, fwname, asc_dvc->drv_ptr->dev);
> +	if (err) {
> +		printk(KERN_ERR "Failed to load image \"%s\" err %d\n",
> +		       fwname, err);
> +		return err;
> +	}
> +	if (fw->size < 4) {
> +		printk(KERN_ERR "Bogus length %d in image \"%s\"\n",
> +		       fw->size, fwname);
> +		release_firmware(fw);
> +		return -EINVAL;
> +	}
> +	chksum = (fw->data[3] << 24) | (fw->data[2] << 16) |
> +		 (fw->data[1] << 8) | fw->data[0];
> +	ASC_DBG(1, "_asc_mcode_chksum 0x%lx\n", (ulong)chksum);
> +	if (AscLoadMicroCode(iop_base, 0, &fw->data[4],
> +			     fw->size - 4) != chksum) {
>  		asc_dvc->err_code |= ASC_IERR_MCODE_CHKSUM;
>  		return warn_code;
>  	}
> +	release_firmware(fw);

You're calling release_firmware() here.  I don't know if that actually
frees the firmware when it's built-in, but if it does, then freeing the
firmware could cause the chip to stop working if it gets reset before
userspace is up.

If it is OK to call release_firmware here, then the error path is
missing a release_firmware() call.

-- 
Intel are signing my paycheques ... these opinions are still mine
"Bill, look, we understand that you're interested in selling us this
operating system, but compare it to ours.  We can't possibly take such
a retrograde step."
--
To unsubscribe from this list: send the line "unsubscribe linux-scsi" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [SCSI Target Devel]     [Linux SCSI Target Infrastructure]     [Kernel Newbies]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Linux IIO]     [Samba]     [Device Mapper]
  Powered by Linux