Received: by 2002:a25:868d:0:0:0:0:0 with SMTP id z13csp3814967ybk; Tue, 19 May 2020 13:39:02 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxPAr0Q00sTeULg0AQiS8FX7GY99AJkBgdH0bhs9jQ4w4WaTcwGm0Jx8nv34ytupDAFUo87 X-Received: by 2002:a17:906:51b:: with SMTP id j27mr925831eja.246.1589920742601; Tue, 19 May 2020 13:39:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1589920742; cv=none; d=google.com; s=arc-20160816; b=W2Hz1wKthsfKqQ99xO8ha1WsqfyCfUcZJw9mr6AUDp0MzSC6uX857AsXmGNhPgKpzG cwtnFGW/ktA94AcOWCt6uPh55/tLqnMLVRYZyt8awPr/o9MjZR3wH6bTenIsEWepFtaO h8JX6iCYC+t4KQDLKD9nQvvsCuDtlbcw8nywIN0GHnRAJZBrEUI6U1g7Qd0jxBvz/CQB /pKN561xfyQZ8u5bnG6/XMVnzrq9IHg+v2RYJXJ7gsJMbKArqnMFVCcXx6C2o1QQdfX6 HCpjLVOsTUi55ksAYzR8aJN6tffsx/2fiT6DKpT/GMpkLpf0gKGwa+UX+PHxcCojjoDl 4z4w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:dkim-filter; bh=LqGeZSIaZSENYc/sTteG8mdtmKimMPs3s55nyanWcEw=; b=FTaFYKDgdw6mizWsPXOAghJ/2QbgM5vywNU5IC6vXerlUhvz/kVIEkSgfnO8JPdpHi Uqad5G20s2+SpJ07EYBkboSddTOIMq5LMQnMF6xdbAhKa+QbkOQBdU19Gpec70rzGdYt XzupkjzIdrRS8xT48uMYNqqujFzNwB4rInb/6i0s4hxatIwGrkgkeU3XHvN5GVB90beG 3q/3sU7Azs+yncEHqAD8do6wNFtencih027NeKCqChceaZKpLBbvEaR14a0+T875NM1m M77yQrJ5MpeVQqof9OisyS8NgDyemiFRBb0bfM/qRqEoHWrr0wJx+zrWQ1+b3QsjhJeH zpqg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@broadcom.com header.s=dkimrelay header.b=iJ8daraq; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=broadcom.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ox11si566397ejb.61.2020.05.19.13.38.40; Tue, 19 May 2020 13:39:02 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@broadcom.com header.s=dkimrelay header.b=iJ8daraq; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=broadcom.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728032AbgESUfG (ORCPT + 99 others); Tue, 19 May 2020 16:35:06 -0400 Received: from rnd-relay.smtp.broadcom.com ([192.19.229.170]:35322 "EHLO rnd-relay.smtp.broadcom.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727939AbgESUfC (ORCPT ); Tue, 19 May 2020 16:35:02 -0400 Received: from mail-irv-17.broadcom.com (mail-irv-17.lvn.broadcom.net [10.75.242.48]) by rnd-relay.smtp.broadcom.com (Postfix) with ESMTP id 6C53B30D82B; Tue, 19 May 2020 13:33:38 -0700 (PDT) DKIM-Filter: OpenDKIM Filter v2.10.3 rnd-relay.smtp.broadcom.com 6C53B30D82B DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=broadcom.com; s=dkimrelay; t=1589920418; bh=idCAwH65TvJoECMSQ+xjnD19SjnYnIujkrcbMhDjDEU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=iJ8daraqpkzatWJq9eG4T9sG9xvEc1Xi2vT9BJYubzwEJQmcU1rNmwywqjPM60845 syYRRu1GASzkAg/4B2CdK+67D4pNMlJOqnp/UkRQUH1QYqTyvCKvzzuYdOetgHjsPj tGXOQhjA0cfEhoSiVrzmS4gn/EeACUuPhUAZ/IOg= Received: from stbsrv-and-01.and.broadcom.net (stbsrv-and-01.and.broadcom.net [10.28.16.211]) by mail-irv-17.broadcom.com (Postfix) with ESMTP id B6AED14008D; Tue, 19 May 2020 13:34:59 -0700 (PDT) From: Jim Quinlan To: james.quinlan@broadcom.com, Nicolas Saenz Julienne Cc: Christoph Hellwig , Marek Szyprowski , Robin Murphy , iommu@lists.linux-foundation.org (open list:DMA MAPPING HELPERS), linux-kernel@vger.kernel.org (open list) Subject: [PATCH 10/15] dma-direct: Invoke dma offset func if needed Date: Tue, 19 May 2020 16:34:08 -0400 Message-Id: <20200519203419.12369-11-james.quinlan@broadcom.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200519203419.12369-1-james.quinlan@broadcom.com> References: <20200519203419.12369-1-james.quinlan@broadcom.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Just like dma_pfn_offset, another offset is added to the dma/phys translation if there happen to be multiple regions that have different mapping offsets. Signed-off-by: Jim Quinlan --- include/linux/dma-direct.h | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/include/linux/dma-direct.h b/include/linux/dma-direct.h index 24b8684aa21d..825a773dbbc3 100644 --- a/include/linux/dma-direct.h +++ b/include/linux/dma-direct.h @@ -15,6 +15,14 @@ static inline dma_addr_t __phys_to_dma(struct device *dev, phys_addr_t paddr) { dma_addr_t dev_addr = (dma_addr_t)paddr; +#ifdef CONFIG_DMA_PFN_OFFSET_MAP + if (unlikely(dev->dma_offset_map)) { + unsigned long dma_pfn_offset = dma_pfn_offset_frm_phys_addr( + dev->dma_offset_map, paddr); + + return dev_addr - ((dma_addr_t)dma_pfn_offset << PAGE_SHIFT); + } +#endif return dev_addr - ((dma_addr_t)dev->dma_pfn_offset << PAGE_SHIFT); } @@ -22,6 +30,14 @@ static inline phys_addr_t __dma_to_phys(struct device *dev, dma_addr_t dev_addr) { phys_addr_t paddr = (phys_addr_t)dev_addr; +#ifdef CONFIG_DMA_PFN_OFFSET_MAP + if (unlikely(dev->dma_offset_map)) { + unsigned long dma_pfn_offset = dma_pfn_offset_frm_dma_addr( + dev->dma_offset_map, dev_addr); + + return paddr + ((phys_addr_t)dma_pfn_offset << PAGE_SHIFT); + } +#endif return paddr + ((phys_addr_t)dev->dma_pfn_offset << PAGE_SHIFT); } #endif /* !CONFIG_ARCH_HAS_PHYS_TO_DMA */ -- 2.17.1