From patchwork Fri Oct 27 12:44:14 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Loic Pallardy X-Patchwork-Id: 117313 Delivered-To: patch@linaro.org Received: by 10.140.22.164 with SMTP id 33csp727511qgn; Fri, 27 Oct 2017 05:45:04 -0700 (PDT) X-Google-Smtp-Source: ABhQp+ScQKybVAPuhQD6pit09D8DTlmt/F5CmDudWduW0h3uZopATXpYUgefXbg8m5PBni5rNtn6 X-Received: by 10.98.182.15 with SMTP id j15mr365408pff.47.1509108304202; Fri, 27 Oct 2017 05:45:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1509108304; cv=none; d=google.com; s=arc-20160816; b=hR+RHJ8XI8UCENNlqpEKYLc2R/LoPrwONQrHYeIx3nZ7KiVGSWdqtmztTqFWTS5jht EndyXYeE9lh42yjFZRpgn3F57hYRLAr+PfEXoNA6txzBtjmOjx/kD5jSFmG9TvCsyTF7 tujPRDn37+QHTjXsQcyr9PO2UAQB43z7NWHgEBk1irPBVJe5Y7iL1xSRIHEestpGaFMr u+GaaDheDFvDAGpYvxLXlJjUnHJqBZ8bYRoSDFw9GxiiONo1DO64LF/44how+j+OPtif MJnpJgKxXxzTMkWzD9YKMTCK9gLUm0+qyJgw8gxgL7FustszUr4p1nEem6DXjpenTAdt 6Yow== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:arc-authentication-results; bh=WJ/qcxZevF9kjlPWWVZ5naLNJjrDiVIIg9g6nGcsOhw=; b=gMYRljqhEkTM++MITEqTv9Q3zn99y1cvyuWGOnTHmbv+GmxBB81LUzd/5MFvpgLsTz cjvTETexTatKyvQDPjcL0VdtdnP5gu9+5I3sY81Mng3Vv1r1aLUv57ehabFhCnc/Fx26 Zg7mHrPFdjCi1gmORfnCYqlnib62j3EZ+/o2xHIFN0w3SlONyBrNYdtdFgH5N/H95G+l qKoSJGZfMVyeEWfLzS8HzU+9KurrxIs1c6GDdUkiGLaDtxdTiBTCXSSDGaRLUi6uAlcT xZZM32zG1NSGRo91tUBl+NBHgK+k6Q7w8D0EjswkLgWVxCkBSZt+2RWQFS6+0FfZN/eZ sZ+g== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id m18si5298857pfh.138.2017.10.27.05.45.03; Fri, 27 Oct 2017 05:45:04 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752723AbdJ0MpB (ORCPT + 27 others); Fri, 27 Oct 2017 08:45:01 -0400 Received: from mx08-00178001.pphosted.com ([91.207.212.93]:33921 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1752649AbdJ0Moi (ORCPT ); Fri, 27 Oct 2017 08:44:38 -0400 Received: from pps.filterd (m0046661.ppops.net [127.0.0.1]) by mx08-.pphosted.com (8.16.0.21/8.16.0.21) with SMTP id v9RChcWG000584; Fri, 27 Oct 2017 14:44:36 +0200 Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx08-00178001.pphosted.com with ESMTP id 2duapy893k-1 (version=TLSv1 cipher=ECDHE-RSA-AES256-SHA bits=256 verify=NOT); Fri, 27 Oct 2017 14:44:36 +0200 Received: from zeta.dmz-eu.st.com (zeta.dmz-eu.st.com [164.129.230.9]) by beta.dmz-eu.st.com (STMicroelectronics) with ESMTP id E379C34; Fri, 27 Oct 2017 12:44:35 +0000 (GMT) Received: from Webmail-eu.st.com (sfhdag7node2.st.com [10.75.127.20]) by zeta.dmz-eu.st.com (STMicroelectronics) with ESMTP id C76F226E0; Fri, 27 Oct 2017 12:44:35 +0000 (GMT) Received: from localhost (10.75.127.50) by SFHDAG7NODE2.st.com (10.75.127.20) with Microsoft SMTP Server (TLS) id 15.0.1347.2; Fri, 27 Oct 2017 14:44:35 +0200 From: Loic Pallardy To: , CC: , , , , Loic Pallardy Subject: [PATCH 7/7] remoteproc: st: add reserved memory support Date: Fri, 27 Oct 2017 14:44:14 +0200 Message-ID: <1509108254-22296-8-git-send-email-loic.pallardy@st.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1509108254-22296-1-git-send-email-loic.pallardy@st.com> References: <1509108254-22296-1-git-send-email-loic.pallardy@st.com> MIME-Version: 1.0 X-Originating-IP: [10.75.127.50] X-ClientProxiedBy: SFHDAG3NODE2.st.com (10.75.127.8) To SFHDAG7NODE2.st.com (10.75.127.20) X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:, , definitions=2017-10-27_07:, , signatures=0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org ST remote processor needs some specified memory regions for firmware and IPC. Memory regions are defined as reserved memory and should be registered in remoteproc core thanks to rproc_add_carveout function. Memory region release is handled by ST driver itself on remove operation. Signed-off-by: Loic Pallardy --- drivers/remoteproc/st_remoteproc.c | 43 +++++++++++++++++++++++++++++++------- 1 file changed, 35 insertions(+), 8 deletions(-) -- 1.9.1 diff --git a/drivers/remoteproc/st_remoteproc.c b/drivers/remoteproc/st_remoteproc.c index aacef0e..1549ce8 100644 --- a/drivers/remoteproc/st_remoteproc.c +++ b/drivers/remoteproc/st_remoteproc.c @@ -19,6 +19,7 @@ #include #include #include +#include #include #include #include @@ -208,8 +209,10 @@ static int st_rproc_parse_dt(struct platform_device *pdev) struct device *dev = &pdev->dev; struct rproc *rproc = platform_get_drvdata(pdev); struct st_rproc *ddata = rproc->priv; - struct device_node *np = dev->of_node; - int err; + struct device_node *node, *np = dev->of_node; + struct resource res; + struct rproc_mem_entry *mem; + int err, count, i; if (ddata->config->sw_reset) { ddata->sw_reset = devm_reset_control_get_exclusive(dev, @@ -254,10 +257,36 @@ static int st_rproc_parse_dt(struct platform_device *pdev) return -EINVAL; } - err = of_reserved_mem_device_init(dev); - if (err) { - dev_err(dev, "Failed to obtain shared memory\n"); - return err; + count = of_count_phandle_with_args(np, "memory-region", NULL); + + for (i = 0; i < count; i++) { + node = of_parse_phandle(np, "memory-region", i); + if (!node) { + dev_err(dev, "No memory-region specified\n"); + return -EINVAL; + } + + err = of_address_to_resource(node, 0, &res); + if (err) { + dev_err(dev, "Bad memory-region definition\n"); + return err; + } + + mem = devm_kzalloc(dev, sizeof(*mem), GFP_KERNEL); + if (!mem) + return -ENOMEM; + + mem->dma = res.start; + mem->da = res.start; + mem->len = resource_size(&res); + mem->va = devm_ioremap_wc(dev, mem->dma, mem->len); + if (!mem->va) { + dev_err(dev, "Unable to map memory region: %pa+%zx\n", + &res.start, mem->len); + return -EBUSY; + } + + rproc_add_carveout(rproc, mem); } err = clk_prepare(ddata->clk); @@ -387,8 +416,6 @@ static int st_rproc_remove(struct platform_device *pdev) clk_disable_unprepare(ddata->clk); - of_reserved_mem_device_release(&pdev->dev); - for (i = 0; i < ST_RPROC_MAX_VRING * MBOX_MAX; i++) mbox_free_channel(ddata->mbox_chan[i]);