* [PATCH V3 0/6] Drivers for Loongson security engine
@ 2025-02-19 7:33 Qunqin Zhao
2025-02-19 7:33 ` [PATCH V3 5/6] tpm: Add a driver for Loongson TPM device Qunqin Zhao
2025-02-19 7:33 ` [PATCH V3 6/6] MAINTAINERS: Add tpm_lsse.c to LOONGSON CRYPTO DRIVER entry Qunqin Zhao
0 siblings, 2 replies; 6+ messages in thread
From: Qunqin Zhao @ 2025-02-19 7:33 UTC (permalink / raw)
To: lee, herbert, davem, peterhuewe, jarkko
Cc: linux-kernel, loongarch, linux-crypto, jgg, linux-integrity,
Qunqin Zhao
Loongson security engine supports random number generation, hash,
symmetric encryption and asymmetric encryption. Based on these
encryption functions, TPM2 have been implemented in it.
mfd is the baser driver, crypto and tpm are users.
v3: Put the updates to the MAINTAINERS in a separate patch.
v2: Removed misc driver. Added tpm driver.
Qunqin Zhao (6):
mfd: Add support for Loongson Security Module
MAINTAINERS: Add maintainer for Loongson Security Module driver
crypto: loongson - add Loongson RNG driver support
MAINTAINERS: Add maintainer for Loongson RNG driver
tpm: Add a driver for Loongson TPM device
MAINTAINERS: Add tpm_lsse.c to LOONGSON CRYPTO DRIVER entry
MAINTAINERS | 14 +
drivers/char/tpm/Kconfig | 9 +
drivers/char/tpm/Makefile | 1 +
drivers/char/tpm/tpm_lsse.c | 104 +++++++
drivers/crypto/Kconfig | 1 +
drivers/crypto/Makefile | 1 +
drivers/crypto/loongson/Kconfig | 6 +
drivers/crypto/loongson/Makefile | 2 +
drivers/crypto/loongson/ls6000se-rng.c | 190 +++++++++++++
drivers/mfd/Kconfig | 9 +
drivers/mfd/Makefile | 2 +
drivers/mfd/ls6000se.c | 374 +++++++++++++++++++++++++
include/linux/mfd/ls6000se.h | 75 +++++
13 files changed, 788 insertions(+)
create mode 100644 drivers/char/tpm/tpm_lsse.c
create mode 100644 drivers/crypto/loongson/Kconfig
create mode 100644 drivers/crypto/loongson/Makefile
create mode 100644 drivers/crypto/loongson/ls6000se-rng.c
create mode 100644 drivers/mfd/ls6000se.c
create mode 100644 include/linux/mfd/ls6000se.h
base-commit: 2816b0c949af89640b8dc05de53e650cbf1d55fb
--
2.43.0
^ permalink raw reply [flat|nested] 6+ messages in thread
* [PATCH V3 5/6] tpm: Add a driver for Loongson TPM device
2025-02-19 7:33 [PATCH V3 0/6] Drivers for Loongson security engine Qunqin Zhao
@ 2025-02-19 7:33 ` Qunqin Zhao
2025-02-19 13:44 ` Jarkko Sakkinen
2025-02-19 7:33 ` [PATCH V3 6/6] MAINTAINERS: Add tpm_lsse.c to LOONGSON CRYPTO DRIVER entry Qunqin Zhao
1 sibling, 1 reply; 6+ messages in thread
From: Qunqin Zhao @ 2025-02-19 7:33 UTC (permalink / raw)
To: lee, herbert, davem, peterhuewe, jarkko
Cc: linux-kernel, loongarch, linux-crypto, jgg, linux-integrity,
Qunqin Zhao, Yinggang Gu
Loongson security engine supports random number generation, hash,
symmetric encryption and asymmetric encryption. Based on these
encryption functions, TPM2 have been implemented in the Loongson
security engine firmware. This driver is responsible for copying data
into the memory visible to the firmware and receiving data from the
firmware.
Co-developed-by: Yinggang Gu <guyinggang@loongson.cn>
Signed-off-by: Yinggang Gu <guyinggang@loongson.cn>
Signed-off-by: Qunqin Zhao <zhaoqunqin@loongson.cn>
---
v3: Added reminder about Loongson security engine to git log.
drivers/char/tpm/Kconfig | 9 ++++
drivers/char/tpm/Makefile | 1 +
drivers/char/tpm/tpm_lsse.c | 104 ++++++++++++++++++++++++++++++++++++
3 files changed, 114 insertions(+)
create mode 100644 drivers/char/tpm/tpm_lsse.c
diff --git a/drivers/char/tpm/Kconfig b/drivers/char/tpm/Kconfig
index 0fc9a510e0..56d0417065 100644
--- a/drivers/char/tpm/Kconfig
+++ b/drivers/char/tpm/Kconfig
@@ -225,5 +225,14 @@ config TCG_FTPM_TEE
help
This driver proxies for firmware TPM running in TEE.
+config TCG_LSSE
+ tristate "Loongson TPM Interface"
+ depends on MFD_LS6000SE
+ help
+ If you want to make Loongson TPM support available, say Yes and
+ it will be accessible from within Linux. To compile this
+ driver as a module, choose M here; the module will be called
+ tpm_lsse.
+
source "drivers/char/tpm/st33zp24/Kconfig"
endif # TCG_TPM
diff --git a/drivers/char/tpm/Makefile b/drivers/char/tpm/Makefile
index 9bb142c752..bf2280352d 100644
--- a/drivers/char/tpm/Makefile
+++ b/drivers/char/tpm/Makefile
@@ -44,3 +44,4 @@ obj-$(CONFIG_TCG_XEN) += xen-tpmfront.o
obj-$(CONFIG_TCG_CRB) += tpm_crb.o
obj-$(CONFIG_TCG_VTPM_PROXY) += tpm_vtpm_proxy.o
obj-$(CONFIG_TCG_FTPM_TEE) += tpm_ftpm_tee.o
+obj-$(CONFIG_TCG_LSSE) += tpm_lsse.o
diff --git a/drivers/char/tpm/tpm_lsse.c b/drivers/char/tpm/tpm_lsse.c
new file mode 100644
index 0000000000..3fd2d9bac8
--- /dev/null
+++ b/drivers/char/tpm/tpm_lsse.c
@@ -0,0 +1,104 @@
+// SPDX-License-Identifier: GPL-2.0
+/* Copyright (c) 2025 Loongson Technology Corporation Limited. */
+
+#include <linux/device.h>
+#include <linux/mfd/ls6000se.h>
+#include <linux/platform_device.h>
+#include <linux/wait.h>
+
+#include "tpm.h"
+
+struct tpm_msg {
+ u32 cmd;
+ u32 data_off;
+ u32 data_len;
+ u32 info[5];
+};
+
+struct tpm_dev {
+ struct lsse_ch *se_ch;
+ struct completion tpm_completion;
+};
+
+static void tpm_complete(struct lsse_ch *ch)
+{
+ struct tpm_dev *td = ch->priv;
+
+ complete(&td->tpm_completion);
+}
+
+static int tpm_ls_recv(struct tpm_chip *chip, u8 *buf, size_t count)
+{
+ struct tpm_dev *td = dev_get_drvdata(&chip->dev);
+ struct tpm_msg *rmsg;
+ int sig;
+
+ sig = wait_for_completion_interruptible(&td->tpm_completion);
+ if (sig)
+ return sig;
+
+ rmsg = td->se_ch->rmsg;
+ memcpy(buf, td->se_ch->data_buffer, rmsg->data_len);
+
+ return rmsg->data_len;
+}
+
+static int tpm_ls_send(struct tpm_chip *chip, u8 *buf, size_t count)
+{
+ struct tpm_dev *td = dev_get_drvdata(&chip->dev);
+ struct tpm_msg *smsg = td->se_ch->smsg;
+
+ memcpy(td->se_ch->data_buffer, buf, count);
+ smsg->data_len = count;
+
+ return se_send_ch_requeset(td->se_ch);
+}
+
+static const struct tpm_class_ops lsse_tpm_ops = {
+ .flags = TPM_OPS_AUTO_STARTUP,
+ .recv = tpm_ls_recv,
+ .send = tpm_ls_send,
+};
+
+static int lsse_tpm_probe(struct platform_device *pdev)
+{
+ struct device *dev = &pdev->dev;
+ struct tpm_chip *chip;
+ struct tpm_msg *smsg;
+ struct tpm_dev *td;
+
+ td = devm_kzalloc(dev, sizeof(struct tpm_dev), GFP_KERNEL);
+ if (!td)
+ return -ENOMEM;
+
+ init_completion(&td->tpm_completion);
+ td->se_ch = se_init_ch(dev->parent, SE_CH_TPM, PAGE_SIZE,
+ 2 * sizeof(struct tpm_msg), td, tpm_complete);
+ if (!td->se_ch)
+ return -ENODEV;
+ smsg = td->se_ch->smsg;
+ smsg->cmd = SE_CMD_TPM;
+ smsg->data_off = td->se_ch->off;
+
+ chip = tpmm_chip_alloc(dev, &lsse_tpm_ops);
+ if (IS_ERR(chip))
+ return PTR_ERR(chip);
+ chip->flags = TPM_CHIP_FLAG_TPM2 | TPM_CHIP_FLAG_IRQ;
+ dev_set_drvdata(&chip->dev, td);
+
+ return tpm_chip_register(chip);
+}
+
+static struct platform_driver lsse_tpm_driver = {
+ .probe = lsse_tpm_probe,
+ .driver = {
+ .name = "ls6000se-tpm",
+ },
+};
+module_platform_driver(lsse_tpm_driver);
+
+MODULE_ALIAS("platform:ls6000se-tpm");
+MODULE_LICENSE("GPL");
+MODULE_AUTHOR("Yinggang Gu <guyinggang@loongson.cn>");
+MODULE_AUTHOR("Qunqin Zhao <zhaoqunqin@loongson.cn>");
+MODULE_DESCRIPTION("Loongson TPM driver");
--
2.43.0
^ permalink raw reply related [flat|nested] 6+ messages in thread
* [PATCH V3 6/6] MAINTAINERS: Add tpm_lsse.c to LOONGSON CRYPTO DRIVER entry
2025-02-19 7:33 [PATCH V3 0/6] Drivers for Loongson security engine Qunqin Zhao
2025-02-19 7:33 ` [PATCH V3 5/6] tpm: Add a driver for Loongson TPM device Qunqin Zhao
@ 2025-02-19 7:33 ` Qunqin Zhao
1 sibling, 0 replies; 6+ messages in thread
From: Qunqin Zhao @ 2025-02-19 7:33 UTC (permalink / raw)
To: lee, herbert, davem, peterhuewe, jarkko
Cc: linux-kernel, loongarch, linux-crypto, jgg, linux-integrity,
Qunqin Zhao
Changes to Loongson TPM driver would be best reviewed by the Loongson
crypto driver maintainers.
Signed-off-by: Qunqin Zhao <zhaoqunqin@loongson.cn>
---
MAINTAINERS | 1 +
1 file changed, 1 insertion(+)
diff --git a/MAINTAINERS b/MAINTAINERS
index 6493d58436..6aad0f08ad 100644
--- a/MAINTAINERS
+++ b/MAINTAINERS
@@ -13484,6 +13484,7 @@ LOONGSON CRYPTO DRIVER
M: Qunqin Zhao <zhaoqunqin@loongson.com>
L: linux-crypto@vger.kernel.org
S: Maintained
+F: drivers/char/tpm/tpm_lsse.c
F: drivers/crypto/loongson/
LOONGSON-2 APB DMA DRIVER
--
2.43.0
^ permalink raw reply related [flat|nested] 6+ messages in thread
* Re: [PATCH V3 5/6] tpm: Add a driver for Loongson TPM device
2025-02-19 7:33 ` [PATCH V3 5/6] tpm: Add a driver for Loongson TPM device Qunqin Zhao
@ 2025-02-19 13:44 ` Jarkko Sakkinen
2025-02-20 11:23 ` Qunqin Zhao
0 siblings, 1 reply; 6+ messages in thread
From: Jarkko Sakkinen @ 2025-02-19 13:44 UTC (permalink / raw)
To: Qunqin Zhao
Cc: lee, herbert, davem, peterhuewe, linux-kernel, loongarch,
linux-crypto, jgg, linux-integrity, Yinggang Gu
On Wed, Feb 19, 2025 at 03:33:49PM +0800, Qunqin Zhao wrote:
> Loongson security engine supports random number generation, hash,
> symmetric encryption and asymmetric encryption. Based on these
> encryption functions, TPM2 have been implemented in the Loongson
> security engine firmware. This driver is responsible for copying data
> into the memory visible to the firmware and receiving data from the
> firmware.
>
> Co-developed-by: Yinggang Gu <guyinggang@loongson.cn>
> Signed-off-by: Yinggang Gu <guyinggang@loongson.cn>
> Signed-off-by: Qunqin Zhao <zhaoqunqin@loongson.cn>
> ---
> v3: Added reminder about Loongson security engine to git log.
>
> drivers/char/tpm/Kconfig | 9 ++++
> drivers/char/tpm/Makefile | 1 +
> drivers/char/tpm/tpm_lsse.c | 104 ++++++++++++++++++++++++++++++++++++
> 3 files changed, 114 insertions(+)
> create mode 100644 drivers/char/tpm/tpm_lsse.c
>
> diff --git a/drivers/char/tpm/Kconfig b/drivers/char/tpm/Kconfig
> index 0fc9a510e0..56d0417065 100644
> --- a/drivers/char/tpm/Kconfig
> +++ b/drivers/char/tpm/Kconfig
> @@ -225,5 +225,14 @@ config TCG_FTPM_TEE
> help
> This driver proxies for firmware TPM running in TEE.
>
> +config TCG_LSSE
> + tristate "Loongson TPM Interface"
> + depends on MFD_LS6000SE
> + help
> + If you want to make Loongson TPM support available, say Yes and
> + it will be accessible from within Linux. To compile this
> + driver as a module, choose M here; the module will be called
> + tpm_lsse.
> +
> source "drivers/char/tpm/st33zp24/Kconfig"
> endif # TCG_TPM
> diff --git a/drivers/char/tpm/Makefile b/drivers/char/tpm/Makefile
> index 9bb142c752..bf2280352d 100644
> --- a/drivers/char/tpm/Makefile
> +++ b/drivers/char/tpm/Makefile
> @@ -44,3 +44,4 @@ obj-$(CONFIG_TCG_XEN) += xen-tpmfront.o
> obj-$(CONFIG_TCG_CRB) += tpm_crb.o
> obj-$(CONFIG_TCG_VTPM_PROXY) += tpm_vtpm_proxy.o
> obj-$(CONFIG_TCG_FTPM_TEE) += tpm_ftpm_tee.o
> +obj-$(CONFIG_TCG_LSSE) += tpm_lsse.o
> diff --git a/drivers/char/tpm/tpm_lsse.c b/drivers/char/tpm/tpm_lsse.c
> new file mode 100644
> index 0000000000..3fd2d9bac8
> --- /dev/null
> +++ b/drivers/char/tpm/tpm_lsse.c
> @@ -0,0 +1,104 @@
> +// SPDX-License-Identifier: GPL-2.0
> +/* Copyright (c) 2025 Loongson Technology Corporation Limited. */
> +
> +#include <linux/device.h>
> +#include <linux/mfd/ls6000se.h>
> +#include <linux/platform_device.h>
> +#include <linux/wait.h>
> +
> +#include "tpm.h"
> +
> +struct tpm_msg {
> + u32 cmd;
> + u32 data_off;
> + u32 data_len;
> + u32 info[5];
> +};
> +
> +struct tpm_dev {
> + struct lsse_ch *se_ch;
> + struct completion tpm_completion;
> +};
> +
> +static void tpm_complete(struct lsse_ch *ch)
> +{
> + struct tpm_dev *td = ch->priv;
> +
> + complete(&td->tpm_completion);
> +}
> +
> +static int tpm_ls_recv(struct tpm_chip *chip, u8 *buf, size_t count)
> +{
> + struct tpm_dev *td = dev_get_drvdata(&chip->dev);
> + struct tpm_msg *rmsg;
> + int sig;
> +
> + sig = wait_for_completion_interruptible(&td->tpm_completion);
> + if (sig)
> + return sig;
> +
> + rmsg = td->se_ch->rmsg;
> + memcpy(buf, td->se_ch->data_buffer, rmsg->data_len);
> +
> + return rmsg->data_len;
> +}
> +
> +static int tpm_ls_send(struct tpm_chip *chip, u8 *buf, size_t count)
> +{
> + struct tpm_dev *td = dev_get_drvdata(&chip->dev);
> + struct tpm_msg *smsg = td->se_ch->smsg;
> +
> + memcpy(td->se_ch->data_buffer, buf, count);
> + smsg->data_len = count;
> +
> + return se_send_ch_requeset(td->se_ch);
> +}
> +
> +static const struct tpm_class_ops lsse_tpm_ops = {
> + .flags = TPM_OPS_AUTO_STARTUP,
> + .recv = tpm_ls_recv,
> + .send = tpm_ls_send,
> +};
> +
> +static int lsse_tpm_probe(struct platform_device *pdev)
tpm_lsse_
> +{
> + struct device *dev = &pdev->dev;
> + struct tpm_chip *chip;
> + struct tpm_msg *smsg;
> + struct tpm_dev *td;
> +
> + td = devm_kzalloc(dev, sizeof(struct tpm_dev), GFP_KERNEL);
> + if (!td)
> + return -ENOMEM;
> +
> + init_completion(&td->tpm_completion);
> + td->se_ch = se_init_ch(dev->parent, SE_CH_TPM, PAGE_SIZE,
> + 2 * sizeof(struct tpm_msg), td, tpm_complete);
> + if (!td->se_ch)
> + return -ENODEV;
> + smsg = td->se_ch->smsg;
> + smsg->cmd = SE_CMD_TPM;
> + smsg->data_off = td->se_ch->off;
> +
> + chip = tpmm_chip_alloc(dev, &lsse_tpm_ops);
> + if (IS_ERR(chip))
> + return PTR_ERR(chip);
> + chip->flags = TPM_CHIP_FLAG_TPM2 | TPM_CHIP_FLAG_IRQ;
> + dev_set_drvdata(&chip->dev, td);
> +
> + return tpm_chip_register(chip);
> +}
> +
> +static struct platform_driver lsse_tpm_driver = {
> + .probe = lsse_tpm_probe,
> + .driver = {
> + .name = "ls6000se-tpm",
> + },
> +};
> +module_platform_driver(lsse_tpm_driver);
> +
> +MODULE_ALIAS("platform:ls6000se-tpm");
> +MODULE_LICENSE("GPL");
> +MODULE_AUTHOR("Yinggang Gu <guyinggang@loongson.cn>");
> +MODULE_AUTHOR("Qunqin Zhao <zhaoqunqin@loongson.cn>");
Remove MODULE_AUTHOR fields. Git encodes this already.
> +MODULE_DESCRIPTION("Loongson TPM driver");
> --
> 2.43.0
>
Prefix all with tpm_lsse instead of tpm
BR, Jarkko
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH V3 5/6] tpm: Add a driver for Loongson TPM device
2025-02-19 13:44 ` Jarkko Sakkinen
@ 2025-02-20 11:23 ` Qunqin Zhao
2025-02-20 14:12 ` Jarkko Sakkinen
0 siblings, 1 reply; 6+ messages in thread
From: Qunqin Zhao @ 2025-02-20 11:23 UTC (permalink / raw)
To: Jarkko Sakkinen
Cc: lee, herbert, davem, peterhuewe, linux-kernel, loongarch,
linux-crypto, jgg, linux-integrity, Yinggang Gu
在 2025/2/19 下午9:44, Jarkko Sakkinen 写道:
>> +
>> +static const struct tpm_class_ops lsse_tpm_ops = {
>> + .flags = TPM_OPS_AUTO_STARTUP,
>> + .recv = tpm_ls_recv,
>> + .send = tpm_ls_send,
>> +};
>> +
>> +static int lsse_tpm_probe(struct platform_device *pdev)
> tpm_lsse_
OK.
> +
> +static struct platform_driver lsse_tpm_driver = {
> + .probe = lsse_tpm_probe,
> + .driver = {
> + .name = "ls6000se-tpm",
> + },
> +};
> +module_platform_driver(lsse_tpm_driver);
> +
> +MODULE_ALIAS("platform:ls6000se-tpm");
> +MODULE_LICENSE("GPL");
> +MODULE_AUTHOR("Yinggang Gu <guyinggang@loongson.cn>");
> +MODULE_AUTHOR("Qunqin Zhao <zhaoqunqin@loongson.cn>");
> Remove MODULE_AUTHOR fields. Git encodes this already.
Do you mean that "modinfo" will still show the author after removing
MODULE_AUTHOR fields?
>
>> +MODULE_DESCRIPTION("Loongson TPM driver");
>> --
>> 2.43.0
>>
> Prefix all with tpm_lsse instead of tpm
OK, thanks for your comments.
BR, Qunqin.
>
> BR, Jarkko
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH V3 5/6] tpm: Add a driver for Loongson TPM device
2025-02-20 11:23 ` Qunqin Zhao
@ 2025-02-20 14:12 ` Jarkko Sakkinen
0 siblings, 0 replies; 6+ messages in thread
From: Jarkko Sakkinen @ 2025-02-20 14:12 UTC (permalink / raw)
To: Qunqin Zhao
Cc: lee, herbert, davem, peterhuewe, linux-kernel, loongarch,
linux-crypto, jgg, linux-integrity, Yinggang Gu
On Thu, Feb 20, 2025 at 07:23:42PM +0800, Qunqin Zhao wrote:
>
> 在 2025/2/19 下午9:44, Jarkko Sakkinen 写道:
> > > +
> > > +static const struct tpm_class_ops lsse_tpm_ops = {
> > > + .flags = TPM_OPS_AUTO_STARTUP,
> > > + .recv = tpm_ls_recv,
> > > + .send = tpm_ls_send,
> > > +};
> > > +
> > > +static int lsse_tpm_probe(struct platform_device *pdev)
> > tpm_lsse_
> OK.
> > +
> > +static struct platform_driver lsse_tpm_driver = {
> > + .probe = lsse_tpm_probe,
> > + .driver = {
> > + .name = "ls6000se-tpm",
> > + },
> > +};
> > +module_platform_driver(lsse_tpm_driver);
> > +
> > +MODULE_ALIAS("platform:ls6000se-tpm");
> > +MODULE_LICENSE("GPL");
> > +MODULE_AUTHOR("Yinggang Gu <guyinggang@loongson.cn>");
> > +MODULE_AUTHOR("Qunqin Zhao <zhaoqunqin@loongson.cn>");
> > Remove MODULE_AUTHOR fields. Git encodes this already.
>
> Do you mean that "modinfo" will still show the author after removing
> MODULE_AUTHOR fields?
What is the utility of showing that? Nobody ever updates those in real
life, so you really can't trust them anyhow. We're better of not showing
anything at all.
>
> >
> > > +MODULE_DESCRIPTION("Loongson TPM driver");
> > > --
> > > 2.43.0
> > >
> > Prefix all with tpm_lsse instead of tpm
>
> OK, thanks for your comments.
>
> BR, Qunqin.
>
> >
> > BR, Jarkko
>
BR, Jarkko
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2025-02-20 14:12 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-02-19 7:33 [PATCH V3 0/6] Drivers for Loongson security engine Qunqin Zhao
2025-02-19 7:33 ` [PATCH V3 5/6] tpm: Add a driver for Loongson TPM device Qunqin Zhao
2025-02-19 13:44 ` Jarkko Sakkinen
2025-02-20 11:23 ` Qunqin Zhao
2025-02-20 14:12 ` Jarkko Sakkinen
2025-02-19 7:33 ` [PATCH V3 6/6] MAINTAINERS: Add tpm_lsse.c to LOONGSON CRYPTO DRIVER entry Qunqin Zhao
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).