summaryrefslogtreecommitdiff
path: root/meta-arm/meta-arm-bsp/recipes-kernel/linux/linux-arm64-ack-5.15/tc/0034-ANDROID-trusty-ffa-Add-support-for-FFA-memory-operat.patch
blob: 3654bff2ac67597ef0ce866bec330470abc60a35 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
From 996e6bae70ec2ce04061daab23f20e9c353c4227 Mon Sep 17 00:00:00 2001
From: Arunachalam Ganapathy <arunachalam.ganapathy@arm.com>
Date: Tue, 18 Jan 2022 15:11:46 +0000
Subject: [PATCH 34/40] ANDROID: trusty-ffa: Add support for FFA memory
 operations

Initializes Trusty mem_ops with FFA memory operations for share,
lend, reclaim.

Signed-off-by: Arunachalam Ganapathy <arunachalam.ganapathy@arm.com>
Change-Id: Id3a1eb5ae8e4721cb983c624773d39bafe25a77d
Upstream-Status: Pending [Not submitted to upstream yet]
Signed-off-by: Rupinderjit Singh <rupinderjit.singh@arm.com
---
 drivers/trusty/trusty-ffa.c | 102 ++++++++++++++++++++++++++++++++++++
 drivers/trusty/trusty.c     |   5 ++
 2 files changed, 107 insertions(+)

diff --git a/drivers/trusty/trusty-ffa.c b/drivers/trusty/trusty-ffa.c
index c8c16a1fc700..0655b3887b52 100644
--- a/drivers/trusty/trusty-ffa.c
+++ b/drivers/trusty/trusty-ffa.c
@@ -15,8 +15,110 @@
 #include "trusty-ffa.h"
 #include "trusty-private.h"
 
+static int __trusty_ffa_share_memory(struct device *dev, u64 *id,
+				     struct scatterlist *sglist,
+				     unsigned int nents, pgprot_t pgprot,
+				     u64 tag, bool share)
+{
+	struct trusty_state *s = platform_get_drvdata(to_platform_device(dev));
+	int ret;
+	struct scatterlist *sg;
+	size_t count;
+	struct ffa_device *ffa_dev = to_ffa_dev(s->ffa->dev);
+	const struct ffa_dev_ops *ffa_ops = s->ffa->ops;
+	struct ffa_mem_region_attributes ffa_mem_attr;
+	struct ffa_mem_ops_args ffa_mem_args;
+
+	if (WARN_ON(nents < 1))
+		return -EINVAL;
+
+	count = dma_map_sg(dev, sglist, nents, DMA_BIDIRECTIONAL);
+	if (count != nents) {
+		dev_err(s->dev, "failed to dma map sg_table\n");
+		return -EINVAL;
+	}
+
+	sg = sglist;
+
+	mutex_lock(&s->ffa->share_memory_msg_lock);
+
+	ffa_mem_attr.receiver = ffa_dev->vm_id;
+	ffa_mem_attr.attrs = FFA_MEM_RW;
+
+	ffa_mem_args.use_txbuf = 1;
+	ffa_mem_args.tag = tag;
+	ffa_mem_args.attrs = &ffa_mem_attr;
+	ffa_mem_args.nattrs = 1;
+	ffa_mem_args.sg = sg;
+	ffa_mem_args.flags = 0;
+
+	if (share) {
+		ret = ffa_ops->memory_share(ffa_dev, &ffa_mem_args);
+	} else {
+		ret = ffa_ops->memory_lend(ffa_dev, &ffa_mem_args);
+	}
+
+	mutex_unlock(&s->ffa->share_memory_msg_lock);
+
+	if (!ret) {
+		*id = ffa_mem_args.g_handle;
+		dev_dbg(s->dev, "%s: done\n", __func__);
+		return 0;
+	}
+
+	dev_err(s->dev, "%s: failed %d", __func__, ret);
+
+	dma_unmap_sg(dev, sglist, nents, DMA_BIDIRECTIONAL);
+	return ret;
+}
+
+static int trusty_ffa_share_memory(struct device *dev, u64 *id,
+				   struct scatterlist *sglist,
+				   unsigned int nents, pgprot_t pgprot, u64 tag)
+{
+	return __trusty_ffa_share_memory(dev, id, sglist, nents, pgprot, tag,
+					 true);
+}
+
+static int trusty_ffa_lend_memory(struct device *dev, u64 *id,
+				  struct scatterlist *sglist,
+				  unsigned int nents, pgprot_t pgprot, u64 tag)
+{
+	return __trusty_ffa_share_memory(dev, id, sglist, nents, pgprot, tag,
+					 false);
+}
+
+static int trusty_ffa_reclaim_memory(struct device *dev, u64 id,
+				     struct scatterlist *sglist,
+				     unsigned int nents)
+{
+	struct trusty_state *s = platform_get_drvdata(to_platform_device(dev));
+	int ret = 0;
+	const struct ffa_dev_ops *ffa_ops = s->ffa->ops;
+
+	if (WARN_ON(nents < 1))
+		return -EINVAL;
+
+	mutex_lock(&s->ffa->share_memory_msg_lock);
+
+	ret = ffa_ops->memory_reclaim(id, 0);
+
+	mutex_unlock(&s->ffa->share_memory_msg_lock);
+
+	if (ret != 0)
+		return ret;
+
+	dma_unmap_sg(dev, sglist, nents, DMA_BIDIRECTIONAL);
+
+	dev_dbg(s->dev, "%s: done\n", __func__);
+	return 0;
+}
+
 static const struct trusty_mem_ops trusty_ffa_mem_ops = {
 	.desc = &trusty_ffa_transport,
+	.trusty_share_memory = &trusty_ffa_share_memory,
+	.trusty_lend_memory = &trusty_ffa_lend_memory,
+	.trusty_reclaim_memory = &trusty_ffa_reclaim_memory,
 };
 
 static const struct ffa_device_id trusty_ffa_device_id[] = {
diff --git a/drivers/trusty/trusty.c b/drivers/trusty/trusty.c
index 4686b0d34f61..f91c255c9897 100644
--- a/drivers/trusty/trusty.c
+++ b/drivers/trusty/trusty.c
@@ -674,6 +674,11 @@ static int trusty_remove(struct platform_device *pdev)
  *
  * For Trusty API version < TRUSTY_API_VERSION_MEM_OBJ:
  *     trusty_smc_transport used for messaging.
+ *
+ * For Trusty API version == TRUSTY_API_VERSION_MEM_OBJ:
+ *     trusty_smc_transport used for messaging.
+ *     trusty_ffa_transport used for memory sharing.
+ *
  */
 static const trusty_transports_t trusty_transports[] = {
 	&trusty_smc_transport,
-- 
2.34.1