aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/block/mtip32xx/mtip32xx.c
diff options
context:
space:
mode:
authorSelvan Mani <smani@micron.com>2012-11-07 08:03:37 -0500
committerJens Axboe <axboe@kernel.dk>2012-11-23 08:32:54 -0500
commit3208795e612406df04a32b46eb5ea5fccfa51d69 (patch)
tree83ad3d3b6c1e0ede845623efdd838a11472f1e91 /drivers/block/mtip32xx/mtip32xx.c
parenta8c32a5c98943d370ea606a2e7dc04717eb92206 (diff)
mtip32xx: fix potential crash on SEC_ERASE_UNIT
The mtip driver lifted this code from elsewhere and then added a special handling check for SEC_ERASE_UNIT. If the caller tries to do a security erase but passes no output data for the command then outbuf is not allocated and the driver duly explodes. Reported-by: Dan Carpenter <dan.carpenter@oracle.com> Signed-off-by: Alan Cox <alan@linux.intel.com> Signed-off-by: Selvan Mani <smani@micron.com> Signed-off-by: Asai Thambi S P <asamymuthupa@micron.com> Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'drivers/block/mtip32xx/mtip32xx.c')
-rw-r--r--drivers/block/mtip32xx/mtip32xx.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/block/mtip32xx/mtip32xx.c b/drivers/block/mtip32xx/mtip32xx.c
index adc6f36564cf..dfb7196bbde9 100644
--- a/drivers/block/mtip32xx/mtip32xx.c
+++ b/drivers/block/mtip32xx/mtip32xx.c
@@ -2218,8 +2218,8 @@ static int exec_drive_taskfile(struct driver_data *dd,
2218 fis.device); 2218 fis.device);
2219 2219
2220 /* check for erase mode support during secure erase.*/ 2220 /* check for erase mode support during secure erase.*/
2221 if ((fis.command == ATA_CMD_SEC_ERASE_UNIT) 2221 if ((fis.command == ATA_CMD_SEC_ERASE_UNIT) && outbuf &&
2222 && (outbuf[0] & MTIP_SEC_ERASE_MODE)) { 2222 (outbuf[0] & MTIP_SEC_ERASE_MODE)) {
2223 erasemode = 1; 2223 erasemode = 1;
2224 } 2224 }
2225 2225