Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp2518060ybv; Mon, 24 Feb 2020 06:42:27 -0800 (PST) X-Google-Smtp-Source: APXvYqwaE2x+ofeUFRKvuf/Km3OTiJ4wLxrrGrbTwJMAEsJli3lWyIjCjM87Wwi2IIsvMd/2lPSY X-Received: by 2002:aca:f305:: with SMTP id r5mr13048116oih.174.1582555347383; Mon, 24 Feb 2020 06:42:27 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582555347; cv=none; d=google.com; s=arc-20160816; b=lhOUc0ptZ3UdU6QAQpKlWT/IdJpZOoZrs0UtjRSgUCqn1YOqyC/qqyfpbqYLJiiNbG BZH0ZQE4StOPuh8ja5ktTf3F/pb5lv8H1JSHoERITkyGxsQmPtWs0gvmyIovg0LXoH92 yxyMXH6EWLGS5dWIv9OsOp6ka7+QFUbTRCwnrvicFBWNM3WyGh7PWcsSlLn89XQH6PF1 vDNEZnNA3xSKgFP1nWGhvWRKuwCCDLSdUOogyWbin0fmAubF9WG8Q/S/B7OKoQmtBkJe Ye6lAkLUPQ+dqcNn5UV4K09FcUwLJW1LfcyXWRXje7mC4JYAISuUiHkdkPWCGgnZdKoL 5dJQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=ryC/BMF7AKN8kVmuwwyXrg2yga82DYzhmtx3+Z0BBn0=; b=q1OQ6J41a63K8tZ4M+8XxClVry2juOkD9k1wMTUfn8kZ0f2H4N1zs77yO3EU2Q8BwJ 4ZGcVmKyGulYWVSD26kB7IhN42iGa0bmO6mZRT/w0MhxrJbhRfz394ITXpm92EJWKHCL CZaKQHjr1JkPw+KrtKJyWYnw1IxXxQaoRGLjH/yHxHpBwZ76cw2gjZutIDxxvBLMgsTW zyhENaasTO1xW7i/x1KygCYfK2qBawUVIOTI5nIeJ9pI0TUv4FMLKQXQaYUvdtlYTTzH RBHsf7Okq48AYEQdA/fD6pUybnlL4pzeiHi8sMGO82CrGC4SaxUclanTeApNbyJDd84V AXdA== 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 o4si6313031otp.200.2020.02.24.06.42.14; Mon, 24 Feb 2020 06:42:27 -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; 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 S1727724AbgBXOmJ (ORCPT + 99 others); Mon, 24 Feb 2020 09:42:09 -0500 Received: from foss.arm.com ([217.140.110.172]:38122 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727648AbgBXOmI (ORCPT ); Mon, 24 Feb 2020 09:42:08 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 8939D31B; Mon, 24 Feb 2020 06:42:07 -0800 (PST) Received: from e120937-lin.cambridge.arm.com (e120937-lin.cambridge.arm.com [10.1.197.50]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 8A6323F534; Mon, 24 Feb 2020 06:42:06 -0800 (PST) From: Cristian Marussi To: linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org Cc: sudeep.holla@arm.com, lukasz.luba@arm.com, james.quinlan@broadcom.com, Jonathan.Cameron@Huawei.com, cristian.marussi@arm.com Subject: [RFC PATCH v3 01/13] firmware: arm_scmi: Add receive buffer support for notifications Date: Mon, 24 Feb 2020 14:41:12 +0000 Message-Id: <20200224144124.2008-2-cristian.marussi@arm.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200224144124.2008-1-cristian.marussi@arm.com> References: <20200224144124.2008-1-cristian.marussi@arm.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Sudeep Holla With all the plumbing in place, let's just add the separate dedicated receive buffers to handle notifications that can arrive asynchronously from the platform firmware to OS. Also add one check to see if the platform supports any receive channels before allocating the receive buffers: since those buffers are optionally supported though, the whole xfer initialization is also postponed to be able to check for their existence in advance. Signed-off-by: Sudeep Holla [Changed parameters in __scmi_xfer_info_init()] Signed-off-by: Cristian Marussi --- V1 --> V2: - reviewed commit message - reviewed parameters of __scmi_xfer_info_init() --- drivers/firmware/arm_scmi/driver.c | 24 ++++++++++++++++++------ 1 file changed, 18 insertions(+), 6 deletions(-) diff --git a/drivers/firmware/arm_scmi/driver.c b/drivers/firmware/arm_scmi/driver.c index dbec767222e9..efb660c34b57 100644 --- a/drivers/firmware/arm_scmi/driver.c +++ b/drivers/firmware/arm_scmi/driver.c @@ -76,6 +76,7 @@ struct scmi_xfers_info { * implementation version and (sub-)vendor identification. * @handle: Instance of SCMI handle to send to clients * @tx_minfo: Universal Transmit Message management info + * @rx_minfo: Universal Receive Message management info * @tx_idr: IDR object to map protocol id to Tx channel info pointer * @rx_idr: IDR object to map protocol id to Rx channel info pointer * @protocols_imp: List of protocols implemented, currently maximum of @@ -89,6 +90,7 @@ struct scmi_info { struct scmi_revision_info version; struct scmi_handle handle; struct scmi_xfers_info tx_minfo; + struct scmi_xfers_info rx_minfo; struct idr tx_idr; struct idr rx_idr; u8 *protocols_imp; @@ -525,13 +527,13 @@ int scmi_handle_put(const struct scmi_handle *handle) return 0; } -static int scmi_xfer_info_init(struct scmi_info *sinfo) +static int __scmi_xfer_info_init(struct scmi_info *sinfo, + struct scmi_xfers_info *info) { int i; struct scmi_xfer *xfer; struct device *dev = sinfo->dev; const struct scmi_desc *desc = sinfo->desc; - struct scmi_xfers_info *info = &sinfo->tx_minfo; /* Pre-allocated messages, no more than what hdr.seq can support */ if (WARN_ON(desc->max_msg >= MSG_TOKEN_MAX)) { @@ -566,6 +568,16 @@ static int scmi_xfer_info_init(struct scmi_info *sinfo) return 0; } +static int scmi_xfer_info_init(struct scmi_info *sinfo) +{ + int ret = __scmi_xfer_info_init(sinfo, &sinfo->tx_minfo); + + if (!ret && idr_find(&sinfo->rx_idr, SCMI_PROTOCOL_BASE)) + ret = __scmi_xfer_info_init(sinfo, &sinfo->rx_minfo); + + return ret; +} + static int scmi_chan_setup(struct scmi_info *info, struct device *dev, int prot_id, bool tx) { @@ -699,10 +711,6 @@ static int scmi_probe(struct platform_device *pdev) info->desc = desc; INIT_LIST_HEAD(&info->node); - ret = scmi_xfer_info_init(info); - if (ret) - return ret; - platform_set_drvdata(pdev, info); idr_init(&info->tx_idr); idr_init(&info->rx_idr); @@ -715,6 +723,10 @@ static int scmi_probe(struct platform_device *pdev) if (ret) return ret; + ret = scmi_xfer_info_init(info); + if (ret) + return ret; + ret = scmi_base_protocol_init(handle); if (ret) { dev_err(dev, "unable to communicate with SCMI(%d)\n", ret); -- 2.17.1