Received: by 2002:ac0:aa62:0:0:0:0:0 with SMTP id w31-v6csp3701745ima; Tue, 23 Oct 2018 09:52:02 -0700 (PDT) X-Google-Smtp-Source: ACcGV633P+zUoM44JjyUGmOir4xdQgzNjTvUXqONiRdi1aYzGu2o08yLOn5JnuEH9gNcd8S9mcQ/ X-Received: by 2002:a62:7086:: with SMTP id l128-v6mr22123799pfc.181.1540313522861; Tue, 23 Oct 2018 09:52:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1540313522; cv=none; d=google.com; s=arc-20160816; b=xocVLPdqKGmtWNxFXukmVGYqMhr/jHRZENhswVJk7qTJOGjf2kC/lIH69nES7nNsJW ssdctKRP0UwZRtX3PGqAjLR2IHWTOon2ldIR+lkq0uj8TTI9Hq4nSSi7pqU+cfnUFC7K 4viXjEFSI3hwxY5CIZtNn4M8DqeOpd1ifahOAvkHswQyhV835jyQ48g14JWvir/1SbgY ZqF7DNt6RoCis9ihzsxVqLATv+7kCRz1UhzTgPwF+/4qkbIqhFANmHD1Vln+GDazLf4r UdDNV/s8kP4qFPHhp/MWUAyyDCTKETbhsT3+XxASrIDUMPAIR9UGJN9DdNqiH2XSAR89 bKfg== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=5POqQp9wY9Ov2oSm7iIgymdgAD+bPC6crnDgzcLaFck=; b=zndHz8Zw6GGipikiEge1LAEdb46EwemU4YuPiB1MFUOuJHh+TWSUp5PwqM8pMu+0Ua UAu68mI5G59xplOg0z+Us1nj/Y2E9hSHNIDUK6xA+8FTvAG5wNXrFaGe93WI/wk2RBv5 vMbqNnhwCJVlIJdJtnT8vR2Zx24VcW/EX7k3PUhYier/29y6FI78qlqvEs5/IXkDMsbM out6gOqARINmEI8c0AslqfZYk9Wt1PIneOFCj47U20oWwCFMcnmMI0nfxgHFALlWIh70 edXfHLYwOPSkccx/ZUA5YT2JNa0fE/OpaxLeJb8vFFqomghruP9JOx9vsWhm76lkAx4z wSVg== 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=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x20-v6si1930372pga.475.2018.10.23.09.51.23; Tue, 23 Oct 2018 09:52:02 -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; 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=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728641AbeJXBOw (ORCPT + 99 others); Tue, 23 Oct 2018 21:14:52 -0400 Received: from fllv0016.ext.ti.com ([198.47.19.142]:52340 "EHLO fllv0016.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727402AbeJXBOw (ORCPT ); Tue, 23 Oct 2018 21:14:52 -0400 Received: from lelv0266.itg.ti.com ([10.180.67.225]) by fllv0016.ext.ti.com (8.15.2/8.15.2) with ESMTP id w9NGodN5053194; Tue, 23 Oct 2018 11:50:39 -0500 Received: from DFLE100.ent.ti.com (dfle100.ent.ti.com [10.64.6.21]) by lelv0266.itg.ti.com (8.15.2/8.15.2) with ESMTPS id w9NGodLw032789 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Tue, 23 Oct 2018 11:50:39 -0500 Received: from DFLE114.ent.ti.com (10.64.6.35) by DFLE100.ent.ti.com (10.64.6.21) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1466.3; Tue, 23 Oct 2018 11:50:38 -0500 Received: from dflp33.itg.ti.com (10.64.6.16) by DFLE114.ent.ti.com (10.64.6.35) with Microsoft SMTP Server (version=TLS1_0, cipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.1.1466.3 via Frontend Transport; Tue, 23 Oct 2018 11:50:38 -0500 Received: from [128.247.58.153] (ileax41-snat.itg.ti.com [10.172.224.153]) by dflp33.itg.ti.com (8.14.3/8.13.8) with ESMTP id w9NGocX4013898; Tue, 23 Oct 2018 11:50:38 -0500 Subject: Re: [PATCH v4 02/17] remoteproc: add rproc_va_to_pa function To: Loic Pallardy , , CC: , , , References: <1532697292-14272-1-git-send-email-loic.pallardy@st.com> <1532697292-14272-3-git-send-email-loic.pallardy@st.com> From: Suman Anna Message-ID: <91e489e7-86c3-6ee3-918d-151ef1697429@ti.com> Date: Tue, 23 Oct 2018 11:50:38 -0500 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.2.1 MIME-Version: 1.0 In-Reply-To: <1532697292-14272-3-git-send-email-loic.pallardy@st.com> Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Loic, Bjorn, On 7/27/18 8:14 AM, Loic Pallardy wrote: > This new function translates CPU virtual address in > CPU physical one according to virtual address location. > > Signed-off-by: Loic Pallardy > Acked-by: Bjorn Andersson > --- > drivers/remoteproc/remoteproc_core.c | 18 +++++++++++++++++- > 1 file changed, 17 insertions(+), 1 deletion(-) > > diff --git a/drivers/remoteproc/remoteproc_core.c b/drivers/remoteproc/remoteproc_core.c > index 437fabf..8e5fe1e 100644 > --- a/drivers/remoteproc/remoteproc_core.c > +++ b/drivers/remoteproc/remoteproc_core.c > @@ -140,6 +140,22 @@ static void rproc_disable_iommu(struct rproc *rproc) > iommu_domain_free(domain); > } > > +static phys_addr_t rproc_va_to_pa(void *cpu_addr) > +{ > + /* > + * Return physical address according to virtual address location > + * - in vmalloc: if region ioremapped or defined as dma_alloc_coherent > + * - in kernel: if region allocated in generic dma memory pool > + */ > + if (is_vmalloc_addr(cpu_addr)) { > + return page_to_phys(vmalloc_to_page(cpu_addr)) + > + offset_in_page(cpu_addr); > + } > + > + WARN_ON(!virt_addr_valid(cpu_addr)); > + return virt_to_phys(cpu_addr); > +} > + > /** > * rproc_da_to_va() - lookup the kernel virtual address for a remoteproc address > * @rproc: handle of a remote processor > @@ -711,7 +727,7 @@ static int rproc_handle_carveout(struct rproc *rproc, > * In this case, the device address and the physical address > * are the same. > */ > - rsc->pa = dma; > + rsc->pa = (u32)rproc_va_to_pa(va); While I agree with the direction here, we ought to add a check here warning users if some address bits are getting lost as a result of the typecast. Granted the issue may have been present previously with dma_addr_t as well, but most platforms were using 32-bit dma addresses, so this was kinda masked. There are ARMv7 platforms with LPAE enabled allowing physical addresses > 32-bits. In anycase, we definitely have a need for a v2 for the fw_rsc_carveout structure to deal with 64-bit addresses. regards Suman > > carveout->va = va; > carveout->len = rsc->len; >