提交 3abe3ab3 编写于 作者: S Srinivas Kandagatla 提交者: Greg Kroah-Hartman

misc: fastrpc: add secure domain support

ADSP/MDSP/SDSP are by default secured, which means it can only be loaded
with a Signed process.
Where as CDSP can be either be secured/unsecured. non-secured Compute DSP
would allow users to load unsigned process and run hexagon instructions,
but blocking access to secured hardware within the DSP. Where as signed
process with secure CDSP would be allowed to access all the dsp resources.

This patch adds basic code to create device nodes as per device tree property.
Signed-off-by: NSrinivas Kandagatla <srinivas.kandagatla@linaro.org>
Link: https://lore.kernel.org/r/20220214161002.6831-6-srinivas.kandagatla@linaro.orgSigned-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 fb42387b
...@@ -241,12 +241,15 @@ struct fastrpc_channel_ctx { ...@@ -241,12 +241,15 @@ struct fastrpc_channel_ctx {
/* Flag if dsp attributes are cached */ /* Flag if dsp attributes are cached */
bool valid_attributes; bool valid_attributes;
u32 dsp_attributes[FASTRPC_MAX_DSP_ATTRIBUTES]; u32 dsp_attributes[FASTRPC_MAX_DSP_ATTRIBUTES];
struct fastrpc_device *secure_fdevice;
struct fastrpc_device *fdevice; struct fastrpc_device *fdevice;
bool secure;
}; };
struct fastrpc_device { struct fastrpc_device {
struct fastrpc_channel_ctx *cctx; struct fastrpc_channel_ctx *cctx;
struct miscdevice miscdev; struct miscdevice miscdev;
bool secure;
}; };
struct fastrpc_user { struct fastrpc_user {
...@@ -1697,7 +1700,7 @@ static int fastrpc_req_mem_map(struct fastrpc_user *fl, char __user *argp) ...@@ -1697,7 +1700,7 @@ static int fastrpc_req_mem_map(struct fastrpc_user *fl, char __user *argp)
return -EFAULT; return -EFAULT;
/* create SMMU mapping */ /* create SMMU mapping */
err = fastrpc_map_create(fl, req.fd, req.length, &map); err = fastrpc_map_create(fl, req.fd, req.length, 0, &map);
if (err) { if (err) {
dev_err(dev, "failed to map buffer, fd = %d\n", req.fd); dev_err(dev, "failed to map buffer, fd = %d\n", req.fd);
return err; return err;
...@@ -1891,7 +1894,7 @@ static struct platform_driver fastrpc_cb_driver = { ...@@ -1891,7 +1894,7 @@ static struct platform_driver fastrpc_cb_driver = {
}; };
static int fastrpc_device_register(struct device *dev, struct fastrpc_channel_ctx *cctx, static int fastrpc_device_register(struct device *dev, struct fastrpc_channel_ctx *cctx,
const char *domain) bool is_secured, const char *domain)
{ {
struct fastrpc_device *fdev; struct fastrpc_device *fdev;
int err; int err;
...@@ -1900,13 +1903,19 @@ static int fastrpc_device_register(struct device *dev, struct fastrpc_channel_ct ...@@ -1900,13 +1903,19 @@ static int fastrpc_device_register(struct device *dev, struct fastrpc_channel_ct
if (!fdev) if (!fdev)
return -ENOMEM; return -ENOMEM;
fdev->secure = is_secured;
fdev->cctx = cctx; fdev->cctx = cctx;
fdev->miscdev.minor = MISC_DYNAMIC_MINOR; fdev->miscdev.minor = MISC_DYNAMIC_MINOR;
fdev->miscdev.fops = &fastrpc_fops; fdev->miscdev.fops = &fastrpc_fops;
fdev->miscdev.name = devm_kasprintf(dev, GFP_KERNEL, "fastrpc-%s", domain); fdev->miscdev.name = devm_kasprintf(dev, GFP_KERNEL, "fastrpc-%s%s",
domain, is_secured ? "-secure" : "");
err = misc_register(&fdev->miscdev); err = misc_register(&fdev->miscdev);
if (!err) if (!err) {
cctx->fdevice = fdev; if (is_secured)
cctx->secure_fdevice = fdev;
else
cctx->fdevice = fdev;
}
return err; return err;
} }
...@@ -1917,6 +1926,7 @@ static int fastrpc_rpmsg_probe(struct rpmsg_device *rpdev) ...@@ -1917,6 +1926,7 @@ static int fastrpc_rpmsg_probe(struct rpmsg_device *rpdev)
struct fastrpc_channel_ctx *data; struct fastrpc_channel_ctx *data;
int i, err, domain_id = -1; int i, err, domain_id = -1;
const char *domain; const char *domain;
bool secure_dsp;
err = of_property_read_string(rdev->of_node, "label", &domain); err = of_property_read_string(rdev->of_node, "label", &domain);
if (err) { if (err) {
...@@ -1940,10 +1950,31 @@ static int fastrpc_rpmsg_probe(struct rpmsg_device *rpdev) ...@@ -1940,10 +1950,31 @@ static int fastrpc_rpmsg_probe(struct rpmsg_device *rpdev)
if (!data) if (!data)
return -ENOMEM; return -ENOMEM;
err = fastrpc_device_register(rdev, data, domains[domain_id]);
if (err) { secure_dsp = !(of_property_read_bool(rdev->of_node, "qcom,non-secure-domain"));
kfree(data); data->secure = secure_dsp;
return err;
switch (domain_id) {
case ADSP_DOMAIN_ID:
case MDSP_DOMAIN_ID:
case SDSP_DOMAIN_ID:
err = fastrpc_device_register(rdev, data, secure_dsp, domains[domain_id]);
if (err)
goto fdev_error;
break;
case CDSP_DOMAIN_ID:
/* Create both device nodes so that we can allow both Signed and Unsigned PD */
err = fastrpc_device_register(rdev, data, true, domains[domain_id]);
if (err)
goto fdev_error;
err = fastrpc_device_register(rdev, data, false, domains[domain_id]);
if (err)
goto fdev_error;
break;
default:
err = -EINVAL;
goto fdev_error;
} }
kref_init(&data->refcount); kref_init(&data->refcount);
...@@ -1957,6 +1988,9 @@ static int fastrpc_rpmsg_probe(struct rpmsg_device *rpdev) ...@@ -1957,6 +1988,9 @@ static int fastrpc_rpmsg_probe(struct rpmsg_device *rpdev)
data->rpdev = rpdev; data->rpdev = rpdev;
return of_platform_populate(rdev->of_node, NULL, NULL, rdev); return of_platform_populate(rdev->of_node, NULL, NULL, rdev);
fdev_error:
kfree(data);
return err;
} }
static void fastrpc_notify_users(struct fastrpc_user *user) static void fastrpc_notify_users(struct fastrpc_user *user)
...@@ -1983,6 +2017,9 @@ static void fastrpc_rpmsg_remove(struct rpmsg_device *rpdev) ...@@ -1983,6 +2017,9 @@ static void fastrpc_rpmsg_remove(struct rpmsg_device *rpdev)
if (cctx->fdevice) if (cctx->fdevice)
misc_deregister(&cctx->fdevice->miscdev); misc_deregister(&cctx->fdevice->miscdev);
if (cctx->secure_fdevice)
misc_deregister(&cctx->secure_fdevice->miscdev);
of_platform_depopulate(&rpdev->dev); of_platform_depopulate(&rpdev->dev);
cctx->rpdev = NULL; cctx->rpdev = NULL;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册