Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp485174ybl; Tue, 28 Jan 2020 06:41:39 -0800 (PST) X-Google-Smtp-Source: APXvYqwcXSWwxdzmqEtyU/7SCZOrAxoBLCCigR+wUX2ddwfLgvSdsqY8ncnwPSjJmD+X9y1Pc0AL X-Received: by 2002:a9d:7852:: with SMTP id c18mr15697098otm.247.1580222499666; Tue, 28 Jan 2020 06:41:39 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1580222499; cv=none; d=google.com; s=arc-20160816; b=ZF+CIeSCCDwhSuLzFkscvl7KYgDw7W7WNcq63xO9ZmH6dAK2lwclFlfyInvU09A/fD rWm3uOdgrbJovxuAxbZa6Udk3FHuya6xnWONbM1X3k1oU/gqjj91GNyj5WevWOh8XQkM RL6ZVi+vMG6pVddQx6aGTkes3y8e3pDEBasDKIPTET3dk9+OClrMzakdj2VcTD5Io+EF mOauYgGXijhYg+mtZkUMp/Kwd93ezdI+a3QNhUPZAlFpS6Lii1DwZm2jrzxqMkL1vAb1 8wO2pUx/2AMuPkmiycVj+vC5nfCY1dv4XTLyrP+ahdeFsKJyR3+8fdnp1c5FVIN9sykI 8cPA== 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=ehwX008aElXmSyIUa/dhlXEMBwzGWkC0Nvo1pR1hcy0=; b=HA/dV917ts28LunR2zD1/KhpTksFpyJBXBditgs7K2vX39RICD271CaP//nQ/v7Ilm ZjX4hrFhlcpP0tgMHRrpowAjT4RxyIY8gVFW2UjaXWQJBY5Efq0FXRcTGZBq6QdG8xcp payYhH+8gSJpMisH1tCyD/CE6gs6yS+LRddllP8P9mCWMGx9nPdl5N+MVBH7Zy5pMV2A cX81SLA9as4941V9pSlGPUeHZJ+ih5xbGT3ZKT31DuIZfZ1vq0MZhAesnrbuSv19RdhT MO9L468iQ95HMiBfxqHSD7IQG/Xx4DGyYyazvM9/ZLjT4LqPUh3k9C0w74vqxKP1aBlU dsGw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=zhYcfPJR; 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 n63si4835496oib.210.2020.01.28.06.41.27; Tue, 28 Jan 2020 06:41:39 -0800 (PST) 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=zhYcfPJR; 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 S1730328AbgA1OQf (ORCPT + 99 others); Tue, 28 Jan 2020 09:16:35 -0500 Received: from mail.kernel.org ([198.145.29.99]:39980 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730323AbgA1OQd (ORCPT ); Tue, 28 Jan 2020 09:16:33 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (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 2220021739; Tue, 28 Jan 2020 14:16:31 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1580220992; bh=SgJWTW4n7ASg2yHjYEkALQkHjY6x8z5LrjxxF7dd860=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=zhYcfPJRX+7Lfye1XwMqlRKaXBk56BKCWkYK1a3eia7ysSqHM0/kZOhLJEvOsfu++ aXxR9Q0ww03N+UkZ9wSN6BpVevN58POv4FpOK2471AMTFeBk0Xp086g2dTNGXI0sUy n2LZZKCAeDReh0HvHFSCjANOkFT0y+5Xfz4o3Cf8= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Israel Rukshin , Max Gurtovoy , Sagi Grimberg , Jason Gunthorpe , Sasha Levin Subject: [PATCH 4.9 046/271] IB/iser: Pass the correct number of entries for dma mapped SGL Date: Tue, 28 Jan 2020 15:03:15 +0100 Message-Id: <20200128135856.072520674@linuxfoundation.org> X-Mailer: git-send-email 2.25.0 In-Reply-To: <20200128135852.449088278@linuxfoundation.org> References: <20200128135852.449088278@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 From: Israel Rukshin [ Upstream commit 57b26497fabe1b9379b59fbc7e35e608e114df16 ] ib_dma_map_sg() augments the SGL into a 'dma mapped SGL'. This process may change the number of entries and the lengths of each entry. Code that touches dma_address is iterating over the 'dma mapped SGL' and must use dma_nents which returned from ib_dma_map_sg(). ib_sg_to_pages() and ib_map_mr_sg() are using dma_address so they must use dma_nents. Fixes: 39405885005a ("IB/iser: Port to new fast registration API") Fixes: bfe066e256d5 ("IB/iser: Reuse ib_sg_to_pages") Signed-off-by: Israel Rukshin Reviewed-by: Max Gurtovoy Acked-by: Sagi Grimberg Signed-off-by: Jason Gunthorpe Signed-off-by: Sasha Levin --- drivers/infiniband/ulp/iser/iser_memory.c | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/drivers/infiniband/ulp/iser/iser_memory.c b/drivers/infiniband/ulp/iser/iser_memory.c index 9c3e9ab53a415..759c2fe033e71 100644 --- a/drivers/infiniband/ulp/iser/iser_memory.c +++ b/drivers/infiniband/ulp/iser/iser_memory.c @@ -240,8 +240,8 @@ int iser_fast_reg_fmr(struct iscsi_iser_task *iser_task, page_vec->npages = 0; page_vec->fake_mr.page_size = SIZE_4K; plen = ib_sg_to_pages(&page_vec->fake_mr, mem->sg, - mem->size, NULL, iser_set_page); - if (unlikely(plen < mem->size)) { + mem->dma_nents, NULL, iser_set_page); + if (unlikely(plen < mem->dma_nents)) { iser_err("page vec too short to hold this SG\n"); iser_data_buf_dump(mem, device->ib_device); iser_dump_page_vec(page_vec); @@ -450,10 +450,10 @@ static int iser_fast_reg_mr(struct iscsi_iser_task *iser_task, ib_update_fast_reg_key(mr, ib_inc_rkey(mr->rkey)); - n = ib_map_mr_sg(mr, mem->sg, mem->size, NULL, SIZE_4K); - if (unlikely(n != mem->size)) { + n = ib_map_mr_sg(mr, mem->sg, mem->dma_nents, NULL, SIZE_4K); + if (unlikely(n != mem->dma_nents)) { iser_err("failed to map sg (%d/%d)\n", - n, mem->size); + n, mem->dma_nents); return n < 0 ? n : -EINVAL; } -- 2.20.1