linux-scsi.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 1/1] scsi: Fix possible buffer overflows in storvsc_queuecommand
@ 2020-12-08 13:19 Xiaohui Zhang
  2020-12-08 16:30 ` [EXTERNAL] " KY Srinivasan
  2020-12-08 17:52 ` Michael Kelley
  0 siblings, 2 replies; 4+ messages in thread
From: Xiaohui Zhang @ 2020-12-08 13:19 UTC (permalink / raw)
  To: Xiaohui Zhang, K. Y. Srinivasan, Haiyang Zhang,
	Stephen Hemminger, Wei Liu, James E.J. Bottomley,
	Martin K. Petersen, linux-hyperv, linux-scsi, linux-kernel

From: Zhang Xiaohui <ruc_zhangxiaohui@163.com>

storvsc_queuecommand() calls memcpy() without checking
the destination size may trigger a buffer overflower,
which a local user could use to cause denial of service
or the execution of arbitrary code.
Fix it by putting the length check before calling memcpy().

Signed-off-by: Zhang Xiaohui <ruc_zhangxiaohui@163.com>
---
 drivers/scsi/storvsc_drv.c | 2 ++
 1 file changed, 2 insertions(+)

diff --git a/drivers/scsi/storvsc_drv.c b/drivers/scsi/storvsc_drv.c
index 0c65fbd41..09b60a4c0 100644
--- a/drivers/scsi/storvsc_drv.c
+++ b/drivers/scsi/storvsc_drv.c
@@ -1729,6 +1729,8 @@ static int storvsc_queuecommand(struct Scsi_Host *host, struct scsi_cmnd *scmnd)
 
 	vm_srb->cdb_length = scmnd->cmd_len;
 
+	if (vm_srb->cdb_length > STORVSC_MAX_CMD_LEN)
+		vm_srb->cdb_length = STORVSC_MAX_CMD_LEN;
 	memcpy(vm_srb->cdb, scmnd->cmnd, vm_srb->cdb_length);
 
 	sgl = (struct scatterlist *)scsi_sglist(scmnd);
-- 
2.17.1


^ permalink raw reply related	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2020-12-09 13:32 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2020-12-08 13:19 [PATCH 1/1] scsi: Fix possible buffer overflows in storvsc_queuecommand Xiaohui Zhang
2020-12-08 16:30 ` [EXTERNAL] " KY Srinivasan
2020-12-08 17:52 ` Michael Kelley
     [not found]   ` <56cde2c6.bb9.176451a57d7.Coremail.ruc_zhangxiaohui@163.com>
2020-12-09 13:31     ` Wei Liu

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).