Received: by 2002:a25:683:0:0:0:0:0 with SMTP id 125csp340471ybg; Mon, 1 Jun 2020 02:47:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxKTMCf04+JVnidBWaTgpuCScz14XSlmC6wrESJUXmgoXCP3Oe7ziWTSkztVWn4zP16uxEd X-Received: by 2002:a05:6402:690:: with SMTP id f16mr21721808edy.9.1591004859698; Mon, 01 Jun 2020 02:47:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1591004859; cv=none; d=google.com; s=arc-20160816; b=dhf+lydeP5byWSebQbP1O9RJT7Wz6AO9GRVu6ezaP0Lx3ZKHlMPDYtWi0wBKNl5iwy LExL05FvvH2L64VGpRZPBf4lTIaQCGY+m0Tc8xcJRPx+V6g91hP/a71C+dPwB7CsPP0q w5MtZgIXnrPJUR7S1sOmdLrAGqcaKJcgVp9MSYsHlWeEqtk43jZE9NOOiSiVxx1D6Q5Y aQlmiIO0XkL55fntqAgnXVs4BeaaNDih5oEmyIbtNH5oyfNYLsgASZWKZ+6eVxPXbm4V 7zztcr4/ziU+UhFRIGQ25PGP1m01EdIEWK2LnbOnG2IepAy8KOaJs6/gNR45HHkjUXVq 6C3A== 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=BaKPF8ajp6pYZ7elGoHvfxsHpRoItYNAx0KYMCc2e1s=; b=GgUPuGRLeInIBJm7zxXOafSvsBX5ud8z0RKV5m50BFC3brku6c8izNCtmxy7xo6KDb pMf58HDvIeoNtk/ZAwk/dcKgbBWqeePQmqx2EQvEjDKcE6MHeylIOArXAIss3PFlK67Q uEis7/C4BVkucqJ1Xw67ECTGifo72g8czIafH06nz91rMgcva8tF6KIPfZaof+VWMA2S jL4MdeyPCkwNmzh1HBWyQ1Z4A+O1rIRF/+xTVuUp3h6gWTczf5TctLdq6AIZ3BYtlPmT FmvEbnigMk1c4ag5298Gh720oPqmNiFbOGeE9rJS0Soq1dvSl4LSyehXzecc/adyjPcc N4Rw== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id q15si10427111edi.367.2020.06.01.02.47.17; Mon, 01 Jun 2020 02:47:39 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726113AbgFAJp1 (ORCPT + 99 others); Mon, 1 Jun 2020 05:45:27 -0400 Received: from foss.arm.com ([217.140.110.172]:35670 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726067AbgFAJpX (ORCPT ); Mon, 1 Jun 2020 05:45:23 -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 142C31063; Mon, 1 Jun 2020 02:45:23 -0700 (PDT) Received: from usa.arm.com (e103737-lin.cambridge.arm.com [10.1.197.49]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id 16F5F3F305; Mon, 1 Jun 2020 02:45:21 -0700 (PDT) From: Sudeep Holla To: Will Deacon , devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org Cc: Sudeep Holla , linux-kernel@vger.kernel.org, Marc Zyngier Subject: [RFC PATCH 3/3] firmware: Add example PSA FF-A non-secure VM partition Date: Mon, 1 Jun 2020 10:45:12 +0100 Message-Id: <20200601094512.50509-4-sudeep.holla@arm.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200601094512.50509-1-sudeep.holla@arm.com> References: <20200601094512.50509-1-sudeep.holla@arm.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This is just an example non-secure VM partition to show how to create the device and use the PSA FF-A interface APIs. Signed-off-by: Sudeep Holla --- drivers/firmware/arm_psa_ffa/Kconfig | 7 +++ drivers/firmware/arm_psa_ffa/Makefile | 1 + drivers/firmware/arm_psa_ffa/partition.c | 71 ++++++++++++++++++++++++ 3 files changed, 79 insertions(+) create mode 100644 drivers/firmware/arm_psa_ffa/partition.c diff --git a/drivers/firmware/arm_psa_ffa/Kconfig b/drivers/firmware/arm_psa_ffa/Kconfig index ba699ec68ec4..34ad61e79234 100644 --- a/drivers/firmware/arm_psa_ffa/Kconfig +++ b/drivers/firmware/arm_psa_ffa/Kconfig @@ -13,3 +13,10 @@ config ARM_PSA_FFA_TRANSPORT This driver provides interface for all the client drivers making use of the features offered by ARM PSA-FF-A. + +config ARM_PSA_FFA_PARTITION + tristate "Arm PSA FF-A compliant partition" + depends on ARM_PSA_FFA_TRANSPORT + help + This driver provides example for ARM PSA-FF-A client driver + making use of the interfaces offered by ARM PSA-FF-A driver. diff --git a/drivers/firmware/arm_psa_ffa/Makefile b/drivers/firmware/arm_psa_ffa/Makefile index ac0455ff71a4..8eb03898baf7 100644 --- a/drivers/firmware/arm_psa_ffa/Makefile +++ b/drivers/firmware/arm_psa_ffa/Makefile @@ -1,2 +1,3 @@ # SPDX-License-Identifier: GPL-2.0-only obj-$(CONFIG_ARM_PSA_FFA_TRANSPORT) += driver.o +obj-$(CONFIG_ARM_PSA_FFA_PARTITION) += partition.o diff --git a/drivers/firmware/arm_psa_ffa/partition.c b/drivers/firmware/arm_psa_ffa/partition.c new file mode 100644 index 000000000000..8549f8d61454 --- /dev/null +++ b/drivers/firmware/arm_psa_ffa/partition.c @@ -0,0 +1,71 @@ +// SPDX-License-Identifier: GPL-2.0-only +/* + * Arm PSA FFA example partition driver + * + * Copyright (C) 2020 Arm Ltd. + */ + +#include +#include +#include +#include +#include +#include +#include + +static int psa_ffa_partition_probe(struct platform_device *pdev) +{ + u16 vm_id; + uuid_t uuid; + const char *uuid_str; + u32 uuid0_4[4]; + struct device *dev = &pdev->dev; + const struct device_node *np = dev->of_node; + struct arm_psa_ffa_handle *handle; + struct psa_ffa_partition_info **buffer; + + handle = arm_psa_ffa_handle_get(dev); + if (!handle) + return -ENODEV; + + if (of_property_read_string(np, "uuid", &uuid_str)) { + dev_err(dev, "failed to parse \"uuid\" property in '%pOF'\n", np); + return -ENODEV; + } + + if (uuid_parse(uuid_str, &uuid)) { + dev_err(dev, "invalid \"uuid\" property (%s)\n", uuid_str); + return -ENODEV; + } + + export_uuid((u8 *)uuid0_4, &uuid); + + vm_id = handle->id_get(); + + handle->partition_info_get(uuid0_4[0], uuid0_4[1], uuid0_4[2], + uuid0_4[3], buffer); + + return 0; +} + +static const struct of_device_id psa_ffa_partition_of_match[] = { + {.compatible = "arm,psa-ffa-partition"}, + {}, +}; + +MODULE_DEVICE_TABLE(of, psa_ffa_partition_of_match); + +static struct platform_driver psa_ffa_partition_driver = { + .driver = { + .name = "psa-ffa-partition", + .of_match_table = psa_ffa_partition_of_match, + }, + .probe = psa_ffa_partition_probe, +}; + +module_platform_driver(psa_ffa_partition_driver); + +MODULE_ALIAS("platform: arm-psa-ffa"); +MODULE_AUTHOR("Sudeep Holla "); +MODULE_DESCRIPTION("Arm PSA FF-A example partition driver"); +MODULE_LICENSE("GPL v2"); -- 2.17.1