From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754791AbbBJKLJ (ORCPT ); Tue, 10 Feb 2015 05:11:09 -0500 Received: from mail-lb0-f172.google.com ([209.85.217.172]:48663 "EHLO mail-lb0-f172.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754610AbbBJKLH (ORCPT ); Tue, 10 Feb 2015 05:11:07 -0500 MIME-Version: 1.0 X-Originating-IP: [93.172.140.139] In-Reply-To: <1420838519-15669-3-git-send-email-s-anna@ti.com> References: <1420838519-15669-1-git-send-email-s-anna@ti.com> <1420838519-15669-3-git-send-email-s-anna@ti.com> From: Ohad Ben-Cohen Date: Tue, 10 Feb 2015 12:10:44 +0200 Message-ID: Subject: Re: [PATCH v3 2/2] remoteproc: add support to handle internal memories To: Suman Anna , Tony Lindgren , Kevin Hilman Cc: Dave Gerlach , Robert Tivy , "linux-kernel@vger.kernel.org" , "linux-omap@vger.kernel.org" , linux-arm Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Suman, On Fri, Jan 9, 2015 at 11:21 PM, Suman Anna wrote: > A remote processor may need to load certain firmware sections into > internal memories (eg: RAM at L1 or L2 levels) for performance or > other reasons. Introduce a new resource type (RSC_INTMEM) and add > an associated handler function to handle such memories. The handler > creates a kernel mapping for the resource's 'pa' (physical address). ... > + * rproc_handle_intmem() - handle internal memory resource entry > + * @rproc: rproc handle > + * @rsc: the intmem resource entry > + * @offset: offset of the resource data in resource table > + * @avail: size of available data (for image validation) > + * > + * This function will handle firmware requests for mapping a memory region > + * internal to a remote processor into kernel. It neither allocates any > + * physical pages, nor performs any iommu mapping, as this resource entry > + * is primarily used for representing physical internal memories. If the > + * internal memory region can only be accessed through an iommu, please > + * use a devmem resource entry. > + * > + * These resource entries should be grouped near the carveout entries in > + * the firmware's resource table, as other firmware entries might request > + * placing other data objects inside these memory regions (e.g. data/code > + * segments, trace resource entries, ...). > + */ > +static int rproc_handle_intmem(struct rproc *rproc, struct fw_rsc_intmem *rsc, > + int offset, int avail) > +{ ... > + va = (__force void *)ioremap_nocache(rsc->pa, rsc->len); Back in the days when we developed remoteproc there was a tremendous effort to move away from ioremap when not strictly needed. I'd be happy if someone intimate with the related hardware could ack that in this specific case ioremap is indeed needed. No need to review the entire patch, or anything remoteproc, just make sure that generally ioremap is how we want to access this internal memory. Tony or Kevin any chance you could take a look and ack? If ioremap is indeed the way to go, I'd also expect that we wouldn't have to use __force here, but that's probably a minor patch cleanup. Thanks, Ohad.