Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp797359ybe; Fri, 13 Sep 2019 06:32:37 -0700 (PDT) X-Google-Smtp-Source: APXvYqwueF7C2PK4etgljwTw75luiHNwk7UC8zNgIfM9wFh8bvQxGOb9IV4+cdQ2pA313fnqK6HX X-Received: by 2002:a17:906:4e12:: with SMTP id z18mr40021116eju.187.1568381556938; Fri, 13 Sep 2019 06:32:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1568381556; cv=none; d=google.com; s=arc-20160816; b=dLTb7NA8ZgX2ECWjzEsKQkuXqwwQrXjOqFkjWdS9107U0ZjX56YMy3cQDjLbCSK4Qc B9CgY4hJLwNCZeNIntmtcuFTIXr0SxXmcRq5L0ZexD8nNuFDuB/zR/FI+/BcwH/MZLoP p7yknEf7U7KjEdWmasipo+wi1S1+RlSaPPM3+K92dBqLvXw3iW/+9Guu6WCxi8X+d+lW LfvKJy04WYHl4+RXEpU9pMQ2kEMQgE5a9JF9z6zqxf/GjcbpKVsG9l0KBFxWBVV95mJN z5ov1bbgOcY9sxAuTBHbckt8ITIu7pgG4vN3XhoFDIvNVpCqK92E38Qjl8MBrY7ONKvN B0bA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=Sfy+GB9s2MbKLGslKvpcK8wG2Kmm4vKiUFjjE4VrK28=; b=OXbjbifu8gab4mHaxq76gOz16yOlVM21k1rRKeuODKZHz22sePvqACTsxThgbU05GY nL64IlOJ5iGD2Qwvngr0ZDa9nP+Ztjl+B6575LUxS1kyFnxYKicSiUqE0D7ofwxglxZW YB4uYgJeeUC5lZEv83aV73yxR1WvX9CFyXXMMiOASoZz11u3/63QUyNyEEcQa+SLkFb7 Sl0kbw6d8En988ngATiyeNq1jKAp/8zRmMoMK2QATlnIqPKig5CpE1DEc+05CHPaK9IC Z69k7mAWyUrqVTWgQVxT828Sod/R/kZWT+4ajb4FOT/4qynLtACRH4WnWMpMVjMM1nxm gT5g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=hNW2KzMr; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w55si18033076eda.15.2019.09.13.06.32.10; Fri, 13 Sep 2019 06:32:36 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=hNW2KzMr; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2391649AbfIMN3c (ORCPT + 99 others); Fri, 13 Sep 2019 09:29:32 -0400 Received: from mail.kernel.org ([198.145.29.99]:47208 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390390AbfIMNTO (ORCPT ); Fri, 13 Sep 2019 09:19:14 -0400 Received: from localhost (unknown [104.132.45.99]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id DE45F20640; Fri, 13 Sep 2019 13:19:12 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1568380753; bh=+HLiC11vGqxHSXKdFpYDJRMhz3DLeHPkz4fOm8VWOuc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=hNW2KzMruo4eaKmDpri9ZyrSMUrlDW6AUVRx4t0vAUYJ5cX9QbPi6QkNHD/KKmcNx hqMO43PGRsKu7JiYTvdqInR6abFG9sHyjTnf9HYiFESRH/TEJ3/ji3WQzrGKqaw4B+ uRM1Uy2gU2AR+72dNYeid0gmnmL7/EYtIBCKzDgQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Roman Bolshakov , Bart Van Assche , "Martin K. Petersen" , Sasha Levin Subject: [PATCH 4.19 146/190] scsi: target/iblock: Fix overrun in WRITE SAME emulation Date: Fri, 13 Sep 2019 14:06:41 +0100 Message-Id: <20190913130611.632934574@linuxfoundation.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20190913130559.669563815@linuxfoundation.org> References: <20190913130559.669563815@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org [ Upstream commit 5676234f20fef02f6ca9bd66c63a8860fce62645 ] 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: Signed-off-by: Roman Bolshakov Reviewed-by: Bart Van Assche Signed-off-by: Martin K. Petersen Signed-off-by: Sasha Levin --- 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 1bc9b14236d8b..854b2bcca7c1a 100644 --- a/drivers/target/target_core_iblock.c +++ b/drivers/target/target_core_iblock.c @@ -515,7 +515,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.20.1