Received: by 2002:a05:6a10:413:0:0:0:0 with SMTP id 19csp3558661pxp; Tue, 15 Mar 2022 00:46:25 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzsck6pzcn0JSunGkhQ7llIbnrlDhLIpJZlDffTR5FxO+H5koIXeZbMXry725yFgBqWq4A9 X-Received: by 2002:a17:90b:4ad2:b0:1bf:d47:8077 with SMTP id mh18-20020a17090b4ad200b001bf0d478077mr3073957pjb.85.1647330385263; Tue, 15 Mar 2022 00:46:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1647330385; cv=none; d=google.com; s=arc-20160816; b=WIwDPSdRoRB+nBFD7r5RfYThHl0utA14vFhn4noPGnTBCazfAv9FbKqnGbvZOWrvG1 slO0YKClzAChOR9BWMA8fLqulEWphUPRS5HTSq501cIWxr9SzIfnkkSE3sqndNfJJsoh mZAA80IDjCCuXD1tBKMSTvQpAW71MW4JFkcRq8cWXJ/XkESocBR+8Z9kjwJELMiPRQwl vH/+WRL7m+iUS2xUZV16Pv7DkMitP2Bmne+LOui1Nk6gV6C8oo3LBDibhfoOpbsVUhLp DwmDOxsb3URG2exyN0M8QS3sO5MQs2wjxkOlrdi1C0/kdY44eDVfb2FkTOZlub2OuK/9 55ZA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=RAySHBWyjG7FLvFsgxl2vNZoSS8NNVYauM0P0r64UDA=; b=LtwaJvjI3nqe/nifyVm9dSOGlu8cIGI1rX1+8vpzHY2UUPXfYXqNEySDdKwb05MCC+ loIddF2ClhtvQqdrAXIEvjjtGdmGTpNhrg6WZwBHMxJQmFvxuZkTA865yuiUlmz3T77k wZEqf/cu4jo/bV0kEBSAa9c/YyWCF2CCmbN0tTjsgpLOik7XDk/uO55i63BGoq+Ro5vQ lU6YIUU/4cSYVjnyJ/Mj9+oBleSYfv4WBA5vcYsUlFWKpWCGULtQeYBJ21qL6vA3lE8N 8RwUZbwHfMXXfNwZNbqKmmN+SXRUY6P/VIrxILr67EzjHy0ysWnY2F8n79Y03+UkZoot vTKA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=rxWGQz7L; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id 11-20020a17090a000b00b001beec00d3ebsi1206303pja.125.2022.03.15.00.46.12; Tue, 15 Mar 2022 00:46:25 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=rxWGQz7L; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239985AbiCNL7A (ORCPT + 99 others); Mon, 14 Mar 2022 07:59:00 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38092 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240162AbiCNL6R (ORCPT ); Mon, 14 Mar 2022 07:58:17 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2D5E465D7; Mon, 14 Mar 2022 04:57:08 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id BA01161251; Mon, 14 Mar 2022 11:57:07 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id C48DDC340E9; Mon, 14 Mar 2022 11:57:06 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1647259027; bh=IU/bSd/Up1lGH3O2Qg9A2SkcKJiyLwSWHeG6qKlMYTs=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=rxWGQz7L1JLFWj+HNXDkDtlGwa7pfbVj5+RD8fEodESw94vnRdpf7G1It2k3xsCTw ZuyLOrKEoWnooFDj0ckD+ZgxuhXuRFOSdivC3S1qGwpolKVCU1qIgA261TJFEssXzp cddWNvrh9KWga/wt+MmEuo391M/t+jIwyrIAWn8Q= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Xie Yongji , "Michael S. Tsirkin" , Sasha Levin Subject: [PATCH 5.4 03/43] virtio-blk: Dont use MAX_DISCARD_SEGMENTS if max_discard_seg is zero Date: Mon, 14 Mar 2022 12:53:14 +0100 Message-Id: <20220314112734.514655046@linuxfoundation.org> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220314112734.415677317@linuxfoundation.org> References: <20220314112734.415677317@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-8.6 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Xie Yongji [ Upstream commit dacc73ed0b88f1a787ec20385f42ca9dd9eddcd0 ] Currently the value of max_discard_segment will be set to MAX_DISCARD_SEGMENTS (256) with no basis in hardware if device set 0 to max_discard_seg in configuration space. It's incorrect since the device might not be able to handle such large descriptors. To fix it, let's follow max_segments restrictions in this case. Fixes: 1f23816b8eb8 ("virtio_blk: add discard and write zeroes support") Signed-off-by: Xie Yongji Link: https://lore.kernel.org/r/20220304100058.116-1-xieyongji@bytedance.com Signed-off-by: Michael S. Tsirkin Signed-off-by: Sasha Levin --- drivers/block/virtio_blk.c | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/drivers/block/virtio_blk.c b/drivers/block/virtio_blk.c index 816eb2db7308..4b3645e648ee 100644 --- a/drivers/block/virtio_blk.c +++ b/drivers/block/virtio_blk.c @@ -980,9 +980,15 @@ static int virtblk_probe(struct virtio_device *vdev) virtio_cread(vdev, struct virtio_blk_config, max_discard_seg, &v); + + /* + * max_discard_seg == 0 is out of spec but we always + * handled it. + */ + if (!v) + v = sg_elems - 2; blk_queue_max_discard_segments(q, - min_not_zero(v, - MAX_DISCARD_SEGMENTS)); + min(v, MAX_DISCARD_SEGMENTS)); blk_queue_flag_set(QUEUE_FLAG_DISCARD, q); } -- 2.34.1