From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-13.0 required=3.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH, MAILING_LIST_MULTI,SIGNED_OFF_BY,SPF_HELO_NONE,SPF_PASS,USER_AGENT_GIT autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 5716CC433E0 for ; Wed, 15 Jul 2020 16:56:52 +0000 (UTC) Received: from merlin.infradead.org (merlin.infradead.org [205.233.59.134]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 235ED20672 for ; Wed, 15 Jul 2020 16:56:52 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=lists.infradead.org header.i=@lists.infradead.org header.b="lQCBVvSE" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 235ED20672 Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=linux.intel.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=merlin.20170209; h=Sender:Content-Transfer-Encoding: Content-Type:Cc:List-Subscribe:List-Help:List-Post:List-Archive: List-Unsubscribe:List-Id:MIME-Version:Message-Id:Date:Subject:To:From: Reply-To:Content-ID:Content-Description:Resent-Date:Resent-From:Resent-Sender :Resent-To:Resent-Cc:Resent-Message-ID:In-Reply-To:References:List-Owner; bh=36rhk9mB6HdFkD1yQAg0+gL/vCsUjOhrA/wWgqehjZA=; b=lQCBVvSEUqjAcZZiD32HuxiXGb W11PkXwFhuM/SAj+WhpqB5WEsGQGRc1srCVfFN24Zx2cWGrRJy2cb06eneDOzP82LOI5iERgUXRrZ FBHM3o9RCbOqvkF+WkRHqnDruzcYGuxr9MQtwiVSpWCQpcjGMbn0J+sU8irk0ZBv4gLQadQdNdc3v 3gCUYVrJShS9AXD1mmQ24BKbYoRp2nmjEpbJwNGSCOY5kwIP5UdNlX9t77/fJhyDtsLb2x3okY7Jk p5otaLlBk+i2/wk1y2jJAXHX38dq99UTLT7zICVisnlCm0FU+8lzeoULYt7EqxkxUTioFugrU9x4W 8Kab9TOA==; Received: from localhost ([::1] helo=merlin.infradead.org) by merlin.infradead.org with esmtp (Exim 4.92.3 #3 (Red Hat Linux)) id 1jvkh6-0007Gw-95; Wed, 15 Jul 2020 16:55:44 +0000 Received: from mga09.intel.com ([134.134.136.24]) by merlin.infradead.org with esmtps (Exim 4.92.3 #3 (Red Hat Linux)) id 1jvkh3-0007F1-OO for linux-arm-kernel@lists.infradead.org; Wed, 15 Jul 2020 16:55:42 +0000 IronPort-SDR: LH25G0H2YaWKJO4MAlAxdwc7yXMCg3g6209wIujFptfVL77yCqRUAbeTLopkUS1C5U0k11Q6WP Ub823/x8ZhWw== X-IronPort-AV: E=McAfee;i="6000,8403,9683"; a="150604892" X-IronPort-AV: E=Sophos;i="5.75,355,1589266800"; d="scan'208";a="150604892" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga004.jf.intel.com ([10.7.209.38]) by orsmga102.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 15 Jul 2020 09:55:37 -0700 IronPort-SDR: rkodu1XP7wuy8dfyVNQJEuNahLyq+9htGYJkoVrhNOfDjjKvoCstQOxLeh8qkedwgCfd1nMWKJ Ug0fHuHHx09A== X-IronPort-AV: E=Sophos;i="5.75,355,1589266800"; d="scan'208";a="430192750" Received: from bellalan-mobl2.ger.corp.intel.com (HELO dalessan-mobl1.ir.intel.com) ([10.251.85.12]) by orsmga004-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 15 Jul 2020 09:55:34 -0700 From: Daniele Alessandrelli To: Sudeep Holla , linux-arm-kernel@lists.infradead.org Subject: [PATCH] firmware: arm_scmi: Pass shmem address to SMCCC call Date: Wed, 15 Jul 2020 17:55:18 +0100 Message-Id: <20200715165518.57558-1-daniele.alessandrelli@linux.intel.com> X-Mailer: git-send-email 2.26.2 MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20200715_125541_940462_7ADB34D4 X-CRM114-Status: GOOD ( 15.75 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: linux-kernel@vger.kernel.org, Peng Fan , "Paul J. Murphy" , Daniele Alessandrelli , "Paul J. Murphy" Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org From: Daniele Alessandrelli Currently, when SMC/HVC is used as transport, the base address of the shared memory used for communication is not passed to the SMCCC call. This means that such an address must be hard-coded into the bootloader. In order to increase flexibility and allow the memory layout to be changed without modifying the bootloader, this patch adds the shared memory base address to the a1 argument of the SMCCC call. On the Secure Monitor side, the service call implementation can therefore read the a1 argument in order to know the location of the shared memory to use. This change is backward compatible to existing service call implementations as long as they don't check for a1 to be zero. Signed-off-by: Daniele Alessandrelli Signed-off-by: Paul J. Murphy --- drivers/firmware/arm_scmi/smc.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/drivers/firmware/arm_scmi/smc.c b/drivers/firmware/arm_scmi/smc.c index 49bc4b0e8428..aef3a58f8266 100644 --- a/drivers/firmware/arm_scmi/smc.c +++ b/drivers/firmware/arm_scmi/smc.c @@ -21,12 +21,14 @@ * * @cinfo: SCMI channel info * @shmem: Transmit/Receive shared memory area + * @shmem_paddr: Physical address of shmem * @func_id: smc/hvc call function id */ struct scmi_smc { struct scmi_chan_info *cinfo; struct scmi_shared_mem __iomem *shmem; + resource_size_t shmem_paddr; struct mutex shmem_lock; u32 func_id; }; @@ -73,6 +75,7 @@ static int smc_chan_setup(struct scmi_chan_info *cinfo, struct device *dev, dev_err(dev, "failed to ioremap SCMI Tx shared memory\n"); return -EADDRNOTAVAIL; } + scmi_info->shmem_paddr = res.start; ret = of_property_read_u32(dev->of_node, "arm,smc-id", &func_id); if (ret < 0) @@ -109,7 +112,8 @@ static int smc_send_message(struct scmi_chan_info *cinfo, shmem_tx_prepare(scmi_info->shmem, xfer); - arm_smccc_1_1_invoke(scmi_info->func_id, 0, 0, 0, 0, 0, 0, 0, &res); + arm_smccc_1_1_invoke(scmi_info->func_id, scmi_info->shmem_paddr, 0, 0, + 0, 0, 0, 0, &res); scmi_rx_callback(scmi_info->cinfo, shmem_read_header(scmi_info->shmem)); mutex_unlock(&scmi_info->shmem_lock); -- 2.26.2 _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel