mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-10 07:50:04 +00:00
tpm_ftpm_tee: register driver on TEE bus
OP-TEE based fTPM Trusted Application depends on tee-supplicant to provide NV RAM implementation based on RPMB secure storage. So this dependency can be resolved via TEE bus where we only invoke fTPM driver probe once fTPM device is registered on the bus which is only true after the tee-supplicant is up and running. Additionally, TEE bus provides auto device enumeration. Signed-off-by: Maxim Uvarov <maxim.uvarov@linaro.org> Suggested-by: Sumit Garg <sumit.garg@linaro.org> Suggested-by: Arnd Bergmann <arnd@linaro.org> Reviewed-by: Sumit Garg <sumit.garg@linaro.org> Reviewed-by: Jarkko Sakkinen <jarkko.sakkinen@linux.intel.com> Tested-by: Sumit Garg <sumit.garg@linaro.org> Signed-off-by: Jens Wiklander <jens.wiklander@linaro.org>
This commit is contained in:
parent
5f178bb71e
commit
9f1944c23c
@ -214,11 +214,10 @@ static int ftpm_tee_match(struct tee_ioctl_version_data *ver, const void *data)
|
|||||||
* Return:
|
* Return:
|
||||||
* On success, 0. On failure, -errno.
|
* On success, 0. On failure, -errno.
|
||||||
*/
|
*/
|
||||||
static int ftpm_tee_probe(struct platform_device *pdev)
|
static int ftpm_tee_probe(struct device *dev)
|
||||||
{
|
{
|
||||||
int rc;
|
int rc;
|
||||||
struct tpm_chip *chip;
|
struct tpm_chip *chip;
|
||||||
struct device *dev = &pdev->dev;
|
|
||||||
struct ftpm_tee_private *pvt_data = NULL;
|
struct ftpm_tee_private *pvt_data = NULL;
|
||||||
struct tee_ioctl_open_session_arg sess_arg;
|
struct tee_ioctl_open_session_arg sess_arg;
|
||||||
|
|
||||||
@ -297,6 +296,13 @@ out_tee_session:
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int ftpm_plat_tee_probe(struct platform_device *pdev)
|
||||||
|
{
|
||||||
|
struct device *dev = &pdev->dev;
|
||||||
|
|
||||||
|
return ftpm_tee_probe(dev);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ftpm_tee_remove() - remove the TPM device
|
* ftpm_tee_remove() - remove the TPM device
|
||||||
* @pdev: the platform_device description.
|
* @pdev: the platform_device description.
|
||||||
@ -304,9 +310,9 @@ out_tee_session:
|
|||||||
* Return:
|
* Return:
|
||||||
* 0 always.
|
* 0 always.
|
||||||
*/
|
*/
|
||||||
static int ftpm_tee_remove(struct platform_device *pdev)
|
static int ftpm_tee_remove(struct device *dev)
|
||||||
{
|
{
|
||||||
struct ftpm_tee_private *pvt_data = dev_get_drvdata(&pdev->dev);
|
struct ftpm_tee_private *pvt_data = dev_get_drvdata(dev);
|
||||||
|
|
||||||
/* Release the chip */
|
/* Release the chip */
|
||||||
tpm_chip_unregister(pvt_data->chip);
|
tpm_chip_unregister(pvt_data->chip);
|
||||||
@ -328,11 +334,18 @@ static int ftpm_tee_remove(struct platform_device *pdev)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int ftpm_plat_tee_remove(struct platform_device *pdev)
|
||||||
|
{
|
||||||
|
struct device *dev = &pdev->dev;
|
||||||
|
|
||||||
|
return ftpm_tee_remove(dev);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ftpm_tee_shutdown() - shutdown the TPM device
|
* ftpm_tee_shutdown() - shutdown the TPM device
|
||||||
* @pdev: the platform_device description.
|
* @pdev: the platform_device description.
|
||||||
*/
|
*/
|
||||||
static void ftpm_tee_shutdown(struct platform_device *pdev)
|
static void ftpm_plat_tee_shutdown(struct platform_device *pdev)
|
||||||
{
|
{
|
||||||
struct ftpm_tee_private *pvt_data = dev_get_drvdata(&pdev->dev);
|
struct ftpm_tee_private *pvt_data = dev_get_drvdata(&pdev->dev);
|
||||||
|
|
||||||
@ -347,17 +360,54 @@ static const struct of_device_id of_ftpm_tee_ids[] = {
|
|||||||
};
|
};
|
||||||
MODULE_DEVICE_TABLE(of, of_ftpm_tee_ids);
|
MODULE_DEVICE_TABLE(of, of_ftpm_tee_ids);
|
||||||
|
|
||||||
static struct platform_driver ftpm_tee_driver = {
|
static struct platform_driver ftpm_tee_plat_driver = {
|
||||||
.driver = {
|
.driver = {
|
||||||
.name = "ftpm-tee",
|
.name = "ftpm-tee",
|
||||||
.of_match_table = of_match_ptr(of_ftpm_tee_ids),
|
.of_match_table = of_match_ptr(of_ftpm_tee_ids),
|
||||||
},
|
},
|
||||||
.probe = ftpm_tee_probe,
|
.shutdown = ftpm_plat_tee_shutdown,
|
||||||
.remove = ftpm_tee_remove,
|
.probe = ftpm_plat_tee_probe,
|
||||||
.shutdown = ftpm_tee_shutdown,
|
.remove = ftpm_plat_tee_remove,
|
||||||
};
|
};
|
||||||
|
|
||||||
module_platform_driver(ftpm_tee_driver);
|
/* UUID of the fTPM TA */
|
||||||
|
static const struct tee_client_device_id optee_ftpm_id_table[] = {
|
||||||
|
{UUID_INIT(0xbc50d971, 0xd4c9, 0x42c4,
|
||||||
|
0x82, 0xcb, 0x34, 0x3f, 0xb7, 0xf3, 0x78, 0x96)},
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
|
||||||
|
MODULE_DEVICE_TABLE(tee, optee_ftpm_id_table);
|
||||||
|
|
||||||
|
static struct tee_client_driver ftpm_tee_driver = {
|
||||||
|
.id_table = optee_ftpm_id_table,
|
||||||
|
.driver = {
|
||||||
|
.name = "optee-ftpm",
|
||||||
|
.bus = &tee_bus_type,
|
||||||
|
.probe = ftpm_tee_probe,
|
||||||
|
.remove = ftpm_tee_remove,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static int __init ftpm_mod_init(void)
|
||||||
|
{
|
||||||
|
int rc;
|
||||||
|
|
||||||
|
rc = platform_driver_register(&ftpm_tee_plat_driver);
|
||||||
|
if (rc)
|
||||||
|
return rc;
|
||||||
|
|
||||||
|
return driver_register(&ftpm_tee_driver.driver);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void __exit ftpm_mod_exit(void)
|
||||||
|
{
|
||||||
|
platform_driver_unregister(&ftpm_tee_plat_driver);
|
||||||
|
driver_unregister(&ftpm_tee_driver.driver);
|
||||||
|
}
|
||||||
|
|
||||||
|
module_init(ftpm_mod_init);
|
||||||
|
module_exit(ftpm_mod_exit);
|
||||||
|
|
||||||
MODULE_AUTHOR("Thirupathaiah Annapureddy <thiruan@microsoft.com>");
|
MODULE_AUTHOR("Thirupathaiah Annapureddy <thiruan@microsoft.com>");
|
||||||
MODULE_DESCRIPTION("TPM Driver for fTPM TA in TEE");
|
MODULE_DESCRIPTION("TPM Driver for fTPM TA in TEE");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user