[PATCH v1.5 3/5] key: add tpm_send command

Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
From: Mimi Zohar
Date: Tuesday, November 23, 2010 - 4:54 pm

Add internal kernel tpm_send() command used to seal/unseal keys.

Changelog:
- replaced module_put in tpm_send() with new tpm_chip_put() wrapper
  (suggested by David Howells)
- Make tpm_send() cmd argument a 'void *' (suggested by David Howells)

Signed-off-by: David Safford <safford@watson.ibm.com>
Signed-off-by: Mimi Zohar <zohar@us.ibm.com>
Acked-by: David Howells <dhowells@redhat.com>
---
 drivers/char/tpm/tpm.c |   16 ++++++++++++++++
 include/linux/tpm.h    |    4 ++++
 2 files changed, 20 insertions(+), 0 deletions(-)

diff --git a/drivers/char/tpm/tpm.c b/drivers/char/tpm/tpm.c
index 26c09f3..068bac8 100644
--- a/drivers/char/tpm/tpm.c
+++ b/drivers/char/tpm/tpm.c
@@ -780,6 +780,22 @@ int tpm_pcr_extend(u32 chip_num, int pcr_idx, const u8 *hash)
 }
 EXPORT_SYMBOL_GPL(tpm_pcr_extend);
 
+int tpm_send(u32 chip_num, void *cmd, size_t buflen)
+{
+	struct tpm_chip *chip;
+	int rc;
+
+	chip = tpm_chip_find_get(chip_num);
+	if (chip == NULL)
+		return -ENODEV;
+
+	rc = transmit_cmd(chip, cmd, buflen, "attempting tpm_cmd");
+
+	tpm_chip_put(chip);
+	return rc;
+}
+EXPORT_SYMBOL_GPL(tpm_send);
+
 ssize_t tpm_show_pcrs(struct device *dev, struct device_attribute *attr,
 		      char *buf)
 {
diff --git a/include/linux/tpm.h b/include/linux/tpm.h
index ac5d1c1..fdc718a 100644
--- a/include/linux/tpm.h
+++ b/include/linux/tpm.h
@@ -31,6 +31,7 @@
 
 extern int tpm_pcr_read(u32 chip_num, int pcr_idx, u8 *res_buf);
 extern int tpm_pcr_extend(u32 chip_num, int pcr_idx, const u8 *hash);
+extern int tpm_send(u32 chip_num, void *cmd, size_t buflen);
 #else
 static inline int tpm_pcr_read(u32 chip_num, int pcr_idx, u8 *res_buf) {
 	return -ENODEV;
@@ -38,5 +39,8 @@ static inline int tpm_pcr_read(u32 chip_num, int pcr_idx, u8 *res_buf) {
 static inline int tpm_pcr_extend(u32 chip_num, int pcr_idx, const u8 *hash) {
 	return -ENODEV;
 }
+static inline int tpm_send(u32 chip_num, void *cmd, size_t buflen) {
+	return -ENODEV;
+}
 #endif
 #endif
-- 
1.7.2.2



--
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
[PATCH v1.5 0/5] keys: trusted and encrypted keys, Mimi Zohar, (Tue Nov 23, 3:50 pm)
[PATCH v1.5 2/5] tpm: add module_put wrapper, Mimi Zohar, (Tue Nov 23, 3:50 pm)
[PATCH v1.5 4/5] keys: add new trusted key-type, Mimi Zohar, (Tue Nov 23, 3:50 pm)
[PATCH v1.5 3/5] key: add tpm_send command, Mimi Zohar, (Tue Nov 23, 4:54 pm)
Re: [PATCH v1.5 2/5] tpm: add module_put wrapper, Serge Hallyn, (Tue Nov 23, 7:19 pm)
Re: [PATCH v1.5 3/5] key: add tpm_send command, Serge Hallyn, (Tue Nov 23, 7:32 pm)
Re: [PATCH v1.5 3/5] key: add tpm_send command, David Safford, (Wed Nov 24, 5:46 am)
Re: [PATCH v1.5 3/5] key: add tpm_send command, Serge Hallyn, (Wed Nov 24, 7:59 am)
[PATCH v1.5 5/5] keys: add new key-type encrypted, Mimi Zohar, (Wed Nov 24, 9:21 am)
Re: [PATCH v1.5 3/5] key: add tpm_send command, David Safford, (Wed Nov 24, 9:31 am)
Re: [PATCH v1.5 0/5] keys: trusted and encrypted keys, James Morris, (Sun Nov 28, 2:56 pm)
Re: [PATCH v1.5 3/5] key: add tpm_send command, David Howells, (Tue Nov 30, 7:32 am)
Re: [PATCH v1.5 3/5] key: add tpm_send command, David Safford, (Tue Nov 30, 8:22 am)
Re: [PATCH v1.5 4/5] keys: add new trusted key-type, David Howells, (Wed Dec 1, 10:48 am)
Re: [PATCH v1.5 4/5] keys: add new trusted key-type, David Safford, (Wed Dec 1, 2:18 pm)
Re: [PATCH v1.5 5/5] keys: add new key-type encrypted, David Howells, (Fri Dec 3, 6:42 am)
Re: [PATCH v1.5 5/5] keys: add new key-type encrypted, David Howells, (Wed Dec 8, 3:54 am)