Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp732804pxj; Fri, 11 Jun 2021 10:03:34 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzYax5e2R3lOL9nGLDE2Jr+NQ6r0QDJN0aJYm0lJLy7Bu/6ERf/9/Bnk+b7ylAly2KiIyAV X-Received: by 2002:a05:6402:19b9:: with SMTP id o25mr4643016edz.192.1623431013782; Fri, 11 Jun 2021 10:03:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623431013; cv=none; d=google.com; s=arc-20160816; b=xnj1JP54v0UyAETbnK46NrzhiYy/5KPGhIe+ybmz1DLcyLsrtNnFMJ6axU5S+2RSUd LWUmERN/Ye9OY8Aw27x+GNaPlRFb+KAvkMs05L6skNEdOQHkIJoNZH7PQ2/E+dAoLmL8 oA3ZJr58USCq6roO6tuwx0IZpEqxi8EBRjMTMXVpblsegDdKLVBUM2dyywDX++LMHfrK PZ4NlbYXdShEYelYOXPUxRRKAuRI2LAexeT1IubbPVjCdAO3yqPGlMcAq8PjoG1vmPPK Q1hzQmrAa57lp5jSbGPR86m2yf2kF1k5Ijv9kOikWkBOs3KtybmG0lTc0tzm5RP4lZ9I QlKQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from; bh=J70O2/XhPqUSrAJQtGTbXehL47sMvWm/H8UMJfbQS7A=; b=RuPV8p5sCQTq9zhz+82/Ch//7/qLJJ+bxMj5sxDJViIm+x1k/eDxaQoB0BEkAZq7zm UG+NmxS7sTipfji9FyzeNEyLAWuldv4JbwfhHOj2zOgPKJr6gmygsON5wUxGvciclZMN dOXB/ePpk9hRQ61RhellaP6h9WJqMFuxU91y5C2MNdSAplY7o2J85sWohSz7ET9rDH/h fqJ/LTps9/GN61y9gqhyXzi6dF2VhcO+x3EHng7xQEcztse3m7TCZLGrwI2hV5OyiKVn crYiP9Ij/Yqb+rvWBbcA1HOdJSEh0K+xgQp0bEggCs1QC9xVqpfE83QASOMpHdiUx1j+ fjHg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id bt10si5493258ejb.390.2021.06.11.10.03.08; Fri, 11 Jun 2021 10:03:33 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231383AbhFKRCx (ORCPT + 99 others); Fri, 11 Jun 2021 13:02:53 -0400 Received: from foss.arm.com ([217.140.110.172]:35652 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230197AbhFKRCv (ORCPT ); Fri, 11 Jun 2021 13:02:51 -0400 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 91384143D; Fri, 11 Jun 2021 10:00:53 -0700 (PDT) Received: from e120937-lin.home (unknown [172.31.20.19]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 204AA3F719; Fri, 11 Jun 2021 10:00:49 -0700 (PDT) From: Cristian Marussi To: linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, virtualization@lists.linux-foundation.org, virtio-dev@lists.oasis-open.org Cc: sudeep.holla@arm.com, james.quinlan@broadcom.com, Jonathan.Cameron@Huawei.com, f.fainelli@gmail.com, etienne.carriere@linaro.org, vincent.guittot@linaro.org, souvik.chakravarty@arm.com, cristian.marussi@arm.com, igor.skalkin@opensynergy.com, peter.hilber@opensynergy.com, alex.bennee@linaro.org, jean-philippe@linaro.org, mikhail.golubev@opensynergy.com, anton.yakovlev@opensynergy.com, Vasyl.Vavrychuk@opensynergy.com, Andriy.Tryshnivskyy@opensynergy.com Subject: [PATCH v4 08/16] [RFC][REWORK] firmware: arm_scmi: Add op to override max message # Date: Fri, 11 Jun 2021 17:59:29 +0100 Message-Id: <20210611165937.701-9-cristian.marussi@arm.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20210611165937.701-1-cristian.marussi@arm.com> References: <20210611165937.701-1-cristian.marussi@arm.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Refactoring core scmi_xfer_info_init routines to account for transport specific maximum number of pending messages. Signed-off-by: Cristian Marussi --- drivers/firmware/arm_scmi/common.h | 6 ++-- drivers/firmware/arm_scmi/driver.c | 52 ++++++++++++++++++------------ 2 files changed, 35 insertions(+), 23 deletions(-) diff --git a/drivers/firmware/arm_scmi/common.h b/drivers/firmware/arm_scmi/common.h index 253a218fe16a..6b8d388fcf74 100644 --- a/drivers/firmware/arm_scmi/common.h +++ b/drivers/firmware/arm_scmi/common.h @@ -320,8 +320,8 @@ struct scmi_chan_info { * @chan_setup: Callback to allocate and setup a channel * @chan_free: Callback to free a channel * @get_max_msg: Optional callback to provide max_msg dynamically - * @return: Maximum number of messages for the channel type (tx or rx) - * that can be pending simultaneously in the system + * Returns the maximum number of messages for the channel type + * (tx or rx) that can be pending simultaneously in the system * @send_message: Callback to send a message * @mark_txdone: Callback to mark tx as done * @fetch_response: Callback to fetch response @@ -334,7 +334,7 @@ struct scmi_transport_ops { int (*chan_setup)(struct scmi_chan_info *cinfo, struct device *dev, bool tx); int (*chan_free)(int id, void *p, void *data); - unsigned int (*get_max_msg)(bool tx, struct scmi_chan_info *base_cinfo); + unsigned int (*get_max_msg)(struct scmi_chan_info *base_cinfo); int (*send_message)(struct scmi_chan_info *cinfo, struct scmi_xfer *xfer); void (*mark_txdone)(struct scmi_chan_info *cinfo, int ret); diff --git a/drivers/firmware/arm_scmi/driver.c b/drivers/firmware/arm_scmi/driver.c index fdd711d85498..041a9e008cbf 100644 --- a/drivers/firmware/arm_scmi/driver.c +++ b/drivers/firmware/arm_scmi/driver.c @@ -1312,20 +1312,13 @@ int scmi_handle_put(const struct scmi_handle *handle) } static int __scmi_xfer_info_init(struct scmi_info *sinfo, - struct scmi_xfers_info *info, - bool tx, - struct scmi_chan_info *base_cinfo) + struct scmi_xfers_info *info) { int i; struct scmi_xfer *xfer; struct device *dev = sinfo->dev; const struct scmi_desc *desc = sinfo->desc; - info->max_msg = desc->max_msg; - - if (desc->ops->get_max_msg) - info->max_msg = desc->ops->get_max_msg(tx, base_cinfo); - /* Pre-allocated messages, no more than what hdr.seq can support */ if (WARN_ON(!info->max_msg || info->max_msg > MSG_TOKEN_MAX)) { dev_err(dev, @@ -1371,23 +1364,42 @@ static int __scmi_xfer_info_init(struct scmi_info *sinfo, return 0; } +static int scmi_channels_max_msg_configure(struct scmi_info *sinfo) +{ + const struct scmi_desc *desc = sinfo->desc; + + if (!desc->ops->get_max_msg) { + sinfo->tx_minfo.max_msg = desc->max_msg; + sinfo->rx_minfo.max_msg = desc->max_msg; + } else { + struct scmi_chan_info *base_cinfo; + + base_cinfo = idr_find(&sinfo->tx_idr, SCMI_PROTOCOL_BASE); + if (!base_cinfo) + return -EINVAL; + + sinfo->tx_minfo.max_msg = desc->ops->get_max_msg(base_cinfo); + + base_cinfo = idr_find(&sinfo->rx_idr, SCMI_PROTOCOL_BASE); + if (base_cinfo) + sinfo->rx_minfo.max_msg = + desc->ops->get_max_msg(base_cinfo); + } + + return 0; +} + static int scmi_xfer_info_init(struct scmi_info *sinfo) { int ret; - struct scmi_chan_info *base_tx_cinfo; - struct scmi_chan_info *base_rx_cinfo; - base_tx_cinfo = idr_find(&sinfo->tx_idr, SCMI_PROTOCOL_BASE); - if (unlikely(!base_tx_cinfo)) - return -EINVAL; - - ret = __scmi_xfer_info_init(sinfo, &sinfo->tx_minfo, true, - base_tx_cinfo); + ret = scmi_channels_max_msg_configure(sinfo); + if (ret) + return ret; - base_rx_cinfo = idr_find(&sinfo->rx_idr, SCMI_PROTOCOL_BASE); - if (!ret && base_rx_cinfo) - ret = __scmi_xfer_info_init(sinfo, &sinfo->rx_minfo, false, - base_rx_cinfo); + 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; } -- 2.17.1