From patchwork Wed Aug 31 20:50:06 2016 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Loic Pallardy X-Patchwork-Id: 75114 Delivered-To: patch@linaro.org Received: by 10.140.29.52 with SMTP id a49csp532315qga; Wed, 31 Aug 2016 13:51:18 -0700 (PDT) X-Received: by 10.98.57.90 with SMTP id g87mr20329086pfa.106.1472676674674; Wed, 31 Aug 2016 13:51:14 -0700 (PDT) Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id gc14si1486608pac.142.2016.08.31.13.51.14; Wed, 31 Aug 2016 13:51:14 -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 S1760680AbcHaUvF (ORCPT + 27 others); Wed, 31 Aug 2016 16:51:05 -0400 Received: from mx07-00178001.pphosted.com ([62.209.51.94]:18123 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1760110AbcHaUvA (ORCPT ); Wed, 31 Aug 2016 16:51:00 -0400 Received: from pps.filterd (m0046668.ppops.net [127.0.0.1]) by mx07-00178001.pphosted.com (8.16.0.11/8.16.0.11) with SMTP id u7VKmE8n004441; Wed, 31 Aug 2016 22:50:56 +0200 Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx07-.pphosted.com with ESMTP id 255bt0awd5-1 (version=TLSv1 cipher=ECDHE-RSA-AES256-SHA bits=256 verify=NOT); Wed, 31 Aug 2016 22:50:56 +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 BF07E31; Wed, 31 Aug 2016 20:50:55 +0000 (GMT) Received: from Webmail-eu.st.com (Safex1hubcas23.st.com [10.75.90.46]) by zeta.dmz-eu.st.com (STMicroelectronics) with ESMTP id A6FAE50E2; Wed, 31 Aug 2016 20:50:55 +0000 (GMT) Received: from localhost (10.129.5.21) by webmail-ga.st.com (10.75.90.48) with Microsoft SMTP Server (TLS) id 14.3.279.2; Wed, 31 Aug 2016 22:50:54 +0200 From: Loic Pallardy To: , , CC: , , , Subject: [PATCH v2 03/19] remoteproc: core: Add function to amend an existing resource table entry Date: Wed, 31 Aug 2016 22:50:06 +0200 Message-ID: <1472676622-32533-4-git-send-email-loic.pallardy@st.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1472676622-32533-1-git-send-email-loic.pallardy@st.com> References: <1472676622-32533-1-git-send-email-loic.pallardy@st.com> MIME-Version: 1.0 X-Originating-IP: [10.129.5.21] X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:, , definitions=2016-08-31_04:, , signatures=0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Lee Jones Sometimes the firmware does not know best. When a firmware is built, it can be loaded with a resource table, usually detailing shared; memory, virtual device, trace log information etc. However, some vendors require this hard-coded information to be amended with new/improved information obtained from Device Tree for instance. Until now, no method exists which allows the resource table to be amended. The addition of this function changes that. It is now possible to pull in a resource table and amend it before it is finally shared with the remote device. Signed-off-by: Lee Jones Signed-off-by: Loic Pallardy --- drivers/remoteproc/remoteproc_core.c | 63 ++++++++++++++++++++++++++++++++++++ 1 file changed, 63 insertions(+) -- 1.9.1 diff --git a/drivers/remoteproc/remoteproc_core.c b/drivers/remoteproc/remoteproc_core.c index 6c48c11..330ad4f 100644 --- a/drivers/remoteproc/remoteproc_core.c +++ b/drivers/remoteproc/remoteproc_core.c @@ -915,6 +915,69 @@ int rproc_request_resource(struct rproc *rproc, u32 type, void *resource) } EXPORT_SYMBOL(rproc_request_resource); +static int rproc_update_resource_table_entry(struct rproc *rproc, + struct rproc_request_resource *request, + struct resource_table *table, int size) +{ + struct fw_rsc_carveout *tblc, *newc; + struct fw_rsc_devmem *tbld, *newd; + struct fw_rsc_trace *tblt, *newt; + int updated = true; + int i; + + for (i = 0; i < table->num; i++) { + int offset = table->offset[i]; + struct fw_rsc_hdr *hdr = (void *)table + offset; + void *rsc = (void *)hdr + sizeof(*hdr); + + if (request->type != hdr->type) + continue; + + switch (hdr->type) { + case RSC_CARVEOUT: + tblc = rsc; + newc = request->resource; + + if (strncmp(newc->name, tblc->name, + sizeof(*tblc->name))) + break; + + memcpy(tblc, newc, request->size); + + return updated; + case RSC_DEVMEM: + tbld = rsc; + newd = request->resource; + + if (strncmp(newd->name, tbld->name, + sizeof(*tbld->name))) + break; + + memcpy(tbld, newd, request->size); + + return updated; + case RSC_TRACE: + tblt = rsc; + newt = request->resource; + + if (strncmp(newt->name, tblt->name, + sizeof(*tblt->name))) + break; + + memcpy(tblt, newt, request->size); + + return updated; + default: + dev_err(&rproc->dev, + "Unsupported resource type: %d\n", + hdr->type); + return -EINVAL; + } + } + + return !updated; +} + /* * take a firmware and boot a remote processor with it. */