Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp481855imu; Mon, 26 Nov 2018 13:43:00 -0800 (PST) X-Google-Smtp-Source: AFSGD/W8yofvgu0aaCemHmbmqKRkFuRfE3YJO4/7/5/AvZnrPH9ZZe34Ya4O7A7zVxIWG6hdT36k X-Received: by 2002:a63:181c:: with SMTP id y28mr25952176pgl.75.1543268580683; Mon, 26 Nov 2018 13:43:00 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543268580; cv=none; d=google.com; s=arc-20160816; b=bIlnksy6QtQe7fXQghmUirkLLws9KIsXHiHiLG2YPMTAYTwZYf1/BQLdyjn+FqN1pO bmHmgmvbPv55ftgHPq1TF9M6ddR61F88agYZo1WvoFZTgWGQjxr0OUmvUAFVfVZK54Ce nZSLZbLBxVO4y+aJJp977k6iCIvNZUhvD2yzL4mQiw71lQC4ZaLPowb0jtJ0l+0Tqy4J jhTIJj+E2zN6cGpKe0BsbrSEilGssh2VD4oZ87Ha3LTyjxI6bpmn1X5UKkUOo6DsB8+n WPRM0HolCBabfIjzisqX1EXehj8Fc52AHZDLM2oo66pBSET2a02eAJxQDXr8mr6LCJau 6R/w== 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:dkim-signature; bh=hAwrr7memIbfMLcL8gYw9J1pdDk0Z8wyXzhL+SlGOLY=; b=n9BFaZexVGF9pJGRX8bKGOsOrXSmbGSwz2XfV9CP+1lBokECYx7k1i6q/RUImciRki YI5w3D+kKUfPgyyNMVZoXbvbdBs2Irk8lkX2aCxZB4FlNmq7qDdHVlFMme1iWL+VuUY0 1qHcBRY1puhiY8RFb5m9Lwcm4m8hb/p3gGDxCRj22ZI33g9f/aDb8Vn7A59fpuKAr6pu WOsDwnW6+IdXuXJSfZSxCblRoEk4DdoglQH5dUuqe4ysrFcmxwu8xppj2KpKux24flnK Gcvc8CaY/rhdwtD+uCFa8hvngwAGDkJbXC5fBh0yfUXTHhuFkQIL+IOJY/X3NQqF56h6 Bzyg== ARC-Authentication-Results: i=1; mx.google.com; dkim=neutral (body hash did not verify) header.i=@lechnology.com header.s=default header.b=xnzafMHA; 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 i33-v6si1434631pld.433.2018.11.26.13.42.45; Mon, 26 Nov 2018 13:43:00 -0800 (PST) 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; dkim=neutral (body hash did not verify) header.i=@lechnology.com header.s=default header.b=xnzafMHA; 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 S1727198AbeK0Ih3 (ORCPT + 99 others); Tue, 27 Nov 2018 03:37:29 -0500 Received: from vern.gendns.com ([98.142.107.122]:47304 "EHLO vern.gendns.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726367AbeK0Ih3 (ORCPT ); Tue, 27 Nov 2018 03:37:29 -0500 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lechnology.com; s=default; h=Content-Transfer-Encoding:Content-Type: In-Reply-To:MIME-Version:Date:Message-ID:From:References:Cc:To:Subject:Sender :Reply-To:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id:List-Help: List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=rUvdSNCoP3lXARK+Y+kuF/xq/Oo6RwcwSkI+0v9FcA8=; b=xnzafMHAb1hslKnbUbQYuxcvKF bzpvciGPlnAUjCDJR1Li/57OITavWI5xV+WM3IcxAl2Di3PyHjRAGn+vscrPweDZys/iIU+PA98U4 PoB+8r9Jtlhq8uD8fmEtzX8ldnj+ZZLOVkCEA2I0L+edmZLZi+a8sh17aUaM96nXWV/WW741/HHrG UDntmu2hEezEmtKc4kNLkVPbqtjxjg8blO8q+sqClG2GZsg1xLDis3lgO3cufPqCNmuq8pROL1Qx4 wY0F6lUlShSLJyu0ADmUxGql4t8wtVDYF39VqVs6bP/JUY83nJrAmhHSLADbi3xS6WiK7Zlx/+Qkk N3PDJN0A==; Received: from 108-198-5-147.lightspeed.okcbok.sbcglobal.net ([108.198.5.147]:45146 helo=[192.168.0.134]) by vern.gendns.com with esmtpsa (TLSv1.2:ECDHE-RSA-AES128-GCM-SHA256:128) (Exim 4.91) (envelope-from ) id 1gROcs-0005T9-0J; Mon, 26 Nov 2018 16:41:06 -0500 Subject: Re: [PATCH 02/16] remoteproc: Add a rproc_set_firmware() API To: Roger Quadros , ohad@wizery.com, bjorn.andersson@linaro.org Cc: tony@atomide.com, robh+dt@kernel.org, bcousson@baylibre.com, ssantosh@kernel.org, s-anna@ti.com, nsekhar@ti.com, t-kristo@ti.com, nsaulnier@ti.com, jreeder@ti.com, m-karicheri2@ti.com, woods.technical@gmail.com, linux-omap@vger.kernel.org, linux-remoteproc@vger.kernel.org, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org References: <1543218769-5507-1-git-send-email-rogerq@ti.com> <1543218769-5507-3-git-send-email-rogerq@ti.com> From: David Lechner Message-ID: Date: Mon, 26 Nov 2018 15:41:54 -0600 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: <1543218769-5507-3-git-send-email-rogerq@ti.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-AntiAbuse: This header was added to track abuse, please include it with any abuse report X-AntiAbuse: Primary Hostname - vern.gendns.com X-AntiAbuse: Original Domain - vger.kernel.org X-AntiAbuse: Originator/Caller UID/GID - [47 12] / [47 12] X-AntiAbuse: Sender Address Domain - lechnology.com X-Get-Message-Sender-Via: vern.gendns.com: authenticated_id: davidmain+lechnology.com/only user confirmed/virtual account not confirmed X-Authenticated-Sender: vern.gendns.com: davidmain@lechnology.com X-Source: X-Source-Args: X-Source-Dir: Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 11/26/18 1:52 AM, Roger Quadros wrote: > From: Suman Anna > > A new API, rproc_set_firmware() is added to allow the remoteproc platform > drivers and remoteproc client drivers to be able to configure a custom > firmware name that is different from the default name used during > remoteproc registration. This function is being introduced to provide > a kernel-level equivalent of the current sysfs interface to remoteproc > client drivers. This allows some remoteproc drivers to choose different > firmwares at runtime when the remote processor is not running based on > the functional feature it is providing using that remote processor. > The TI PRU Ethernet driver will be an example of such usage as it > requires to use different firmwares for different supported protocols. > > Also, update the firmware_store() function used by the sysfs interface > to reuse this function to avoid code duplication. > > Signed-off-by: Suman Anna > --- > drivers/remoteproc/remoteproc_core.c | 61 +++++++++++++++++++++++++++++++++++ > drivers/remoteproc/remoteproc_sysfs.c | 33 ++----------------- > include/linux/remoteproc.h | 1 + > 3 files changed, 64 insertions(+), 31 deletions(-) > > diff --git a/drivers/remoteproc/remoteproc_core.c b/drivers/remoteproc/remoteproc_core.c > index 39458a7..581e6e8 100644 > --- a/drivers/remoteproc/remoteproc_core.c > +++ b/drivers/remoteproc/remoteproc_core.c > @@ -2151,6 +2151,67 @@ void rproc_report_crash(struct rproc *rproc, enum rproc_crash_type type) ... > +int rproc_set_firmware(struct rproc *rproc, const char *fw_name) > +{ > + struct device *dev = rproc->dev.parent; > + int ret, len; > + char *p; > + > + if (!rproc || !fw_name) > + return -EINVAL; > + > + ret = mutex_lock_interruptible(&rproc->lock); > + if (ret) { > + dev_err(dev, "can't lock rproc %s: %d\n", rproc->name, ret); > + return -EINVAL; > + } > + > + if (rproc->state != RPROC_OFFLINE) { > + dev_err(dev, "can't change firmware while running\n"); > + ret = -EBUSY; > + goto out; > + } > + > + len = strcspn(fw_name, "\n"); > + if (!len) { > + dev_err(dev, "can't provide a NULL firmware\n"); I realize this was just copied, but technically, this would be an empty string rather than NULL.