All of lore.kernel.org
 help / color / mirror / Atom feed
* [RESEND PATCH] scsi: target/iblock: Fix overrun in WRITE SAME emulation
@ 2019-07-02 19:16 ` Roman Bolshakov
  0 siblings, 0 replies; 11+ messages in thread
From: Roman Bolshakov @ 2019-07-02 19:16 UTC (permalink / raw)
  To: target-devel, linux-scsi
  Cc: Roman Bolshakov, Martin K. Petersen, stable, Bart Van Assche

WRITE SAME corrupts data on the block device behind iblock if the
command is emulated. The emulation code issues (M - 1) * N times more
bios than requested, where M is the number of 512 blocks per real block
size and N is the NUMBER OF LOGICAL BLOCKS specified in WRITE SAME
command. So, for a device with 4k blocks, 7 * N more LBAs gets written
after the requested range.

The issue happens because the number of 512 byte sectors to be written
is decreased one by one while the real bios are typically from 1 to 8
512 byte sectors per bio.

Fixes: c66ac9db8d4a ("[SCSI] target: Add LIO target core v4.0.0-rc6")
Cc: <stable@vger.kernel.org>
Signed-off-by: Roman Bolshakov <r.bolshakov@yadro.com>
Reviewed-by: Bart Van Assche <bvanassche@acm.org>
---
 drivers/target/target_core_iblock.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/drivers/target/target_core_iblock.c b/drivers/target/target_core_iblock.c
index f4a075303e9a..6949ea8bc387 100644
--- a/drivers/target/target_core_iblock.c
+++ b/drivers/target/target_core_iblock.c
@@ -502,7 +502,7 @@ iblock_execute_write_same(struct se_cmd *cmd)
 
 		/* Always in 512 byte units for Linux/Block */
 		block_lba += sg->length >> SECTOR_SHIFT;
-		sectors -= 1;
+		sectors -= sg->length >> SECTOR_SHIFT;
 	}
 
 	iblock_submit_bios(&list);
-- 
2.22.0

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

end of thread, other threads:[~2019-07-03 13:24 UTC | newest]

Thread overview: 11+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2019-07-02 19:16 [RESEND PATCH] scsi: target/iblock: Fix overrun in WRITE SAME emulation Roman Bolshakov
2019-07-02 19:16 ` Roman Bolshakov
2019-07-02 19:16 ` Roman Bolshakov
2019-07-02 20:37 ` Martin K. Petersen
2019-07-02 20:37   ` Martin K. Petersen
2019-07-02 20:37   ` Martin K. Petersen
2019-07-03  3:40 ` Michael Christie
2019-07-03  3:40   ` Michael Christie
2019-07-03 13:24   ` Roman Bolshakov
2019-07-03 13:24     ` Roman Bolshakov
2019-07-03 13:24     ` Roman Bolshakov

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.