Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp987654imj; Thu, 7 Feb 2019 15:26:47 -0800 (PST) X-Google-Smtp-Source: AHgI3IZOxBrCT92uC4ow9pFXZL00e3oN3cCuXfbRAr3dE8k2+se+jWnX8WkBEvIMZITYEngJCmYZ X-Received: by 2002:a62:6e07:: with SMTP id j7mr19317822pfc.135.1549582007710; Thu, 07 Feb 2019 15:26:47 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1549582007; cv=none; d=google.com; s=arc-20160816; b=OdoMvfBv66szwKicRr+h0buKZM1qKUHyWcECj+0yhJ9F61dIjuGchF+Y14xhq6MWVn MEh4GZfSyJJb/qGRbfcr7HtuxJ8y7pbeGi7pTESrNvR/py9K2NI+h4DZnKcgSeIKRKUo ZbhnfHrEDcMvCCZsZ2W0QrFFWJVoOOUeemuvcjbKNpY39HYtfc8Ek5qtDighyXxQI96n Jkc76zbXuefsXPTA7oLr134rkWbNGBDU+wYCdglT6JpdIbUmO9kDjDXq9ld1OGUVZrMB p9KhCKLhFogERgncmLI6boGHLlrw+t8ufX8D2gvcBKYWxo1/ykhTBKpQlIdOtN7CRg1i +qeg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=N6u/T/ptq33utHLTvfNH605r1Wn4UerCtbgT7053eUs=; b=i/OyIGMDC6oYcEKu2rhdEPyRtKP9o1Ni8dCOqf0w+XwmdBSeRYMRqG23mMhHvvI/Hl Rs61HgC7upTn0HFo7sYjOmXaYXILY6iY/mWV8Miuy9KxhrVT6xFv4R48LSzYXSHgkicY WyKorRz7IPpzTPT7WIbooGuuMl90iHeAsoGLk6xKdVsT6x7K/Ta2JOgSGr6rdybXHDMg IE1TdNN1fTLpjPt6NHZODzClJRZnaD44w9EdnG4J3rACvKxUeD9SdgmCwijf22YbQrPK shj6ohlYDT+BwlGX0D0wPjiaRQ4WkcT0tAX/nKYrAR8w5eXg7WqDcYlPppLEt8oj4KBD jsuQ== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d4si397261pla.58.2019.02.07.15.26.16; Thu, 07 Feb 2019 15:26:47 -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; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726781AbfBGXXZ (ORCPT + 99 others); Thu, 7 Feb 2019 18:23:25 -0500 Received: from mga12.intel.com ([192.55.52.136]:30212 "EHLO mga12.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726651AbfBGXXZ (ORCPT ); Thu, 7 Feb 2019 18:23:25 -0500 X-Amp-Result: UNKNOWN X-Amp-Original-Verdict: FILE UNKNOWN X-Amp-File-Uploaded: False Received: from orsmga001.jf.intel.com ([10.7.209.18]) by fmsmga106.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 07 Feb 2019 15:23:24 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.58,345,1544515200"; d="scan'208";a="136766309" Received: from meisenhu-mobl3.ger.corp.intel.com (HELO kekkonen.fi.intel.com) ([10.252.43.220]) by orsmga001.jf.intel.com with ESMTP; 07 Feb 2019 15:23:20 -0800 Received: by kekkonen.fi.intel.com (Postfix, from userid 1000) id EC61C21D9A; Fri, 8 Feb 2019 01:23:16 +0200 (EET) Date: Fri, 8 Feb 2019 01:23:16 +0200 From: Sakari Ailus To: Jason Gunthorpe Cc: "linux-rdma@vger.kernel.org" , "linux-kernel@vger.kernel.org" , Christoph Hellwig , Shiraz Saleem , Imre Deak , Daniel Vetter , "linux-media@vger.kernel.org" , Yong Zhi , Bingbu Cao , Tian Shu Qiu , Jian Xu Zheng , Sinclair Yeh , Thomas Hellstrom , "dri-devel@lists.freedesktop.org" Subject: Re: [PATCH] lib/scatterlist: Provide a DMA page iterator Message-ID: <20190207232316.3min76e2xy3aqrxh@kekkonen.localdomain> References: <20190104223531.GA1705@ziepe.ca> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190104223531.GA1705@ziepe.ca> User-Agent: NeoMutt/20170113 (1.7.2) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Jan 04, 2019 at 10:35:43PM +0000, Jason Gunthorpe wrote: > Commit 2db76d7c3c6d ("lib/scatterlist: sg_page_iter: support sg lists w/o > backing pages") introduced the sg_page_iter_dma_address() function without > providing a way to use it in the general case. If the sg_dma_len is not > equal to the dma_length callers cannot safely use the > for_each_sg_page/sg_page_iter_dma_address combination. > > Resolve this API mistake by providing a DMA specific iterator, > for_each_sg_dma_page(), that uses the right length so > sg_page_iter_dma_address() works as expected with all sglists. A new > iterator type is introduced to provide compile-time safety against wrongly > mixing accessors and iterators. > > Signed-off-by: Jason Gunthorpe Acked-by: Sakari Ailus (ipu3-cio2) -- Sakari Ailus sakari.ailus@linux.intel.com