Commit da379f3c authored by Jarkko Sakkinen's avatar Jarkko Sakkinen

tpm: migrate pubek_show to struct tpm_buf

Migrated pubek_show to struct tpm_buf and cleaned up its implementation.
Previously the output parameter structure was declared but left
completely unused. Now it is used to refer different fields of the
output. We can move it to tpm-sysfs.c as it does not have any use
outside of that file.
Signed-off-by: default avatarJarkko Sakkinen <jarkko.sakkinen@linux.intel.com>
parent 25eabb13
...@@ -20,44 +20,48 @@ ...@@ -20,44 +20,48 @@
#include <linux/device.h> #include <linux/device.h>
#include "tpm.h" #include "tpm.h"
#define READ_PUBEK_RESULT_SIZE 314 struct tpm_readpubek_out {
u8 algorithm[4];
u8 encscheme[2];
u8 sigscheme[2];
__be32 paramsize;
u8 parameters[12];
__be32 keysize;
u8 modulus[256];
u8 checksum[20];
} __packed;
#define READ_PUBEK_RESULT_MIN_BODY_SIZE (28 + 256) #define READ_PUBEK_RESULT_MIN_BODY_SIZE (28 + 256)
#define TPM_ORD_READPUBEK 124 #define TPM_ORD_READPUBEK 124
static const struct tpm_input_header tpm_readpubek_header = {
.tag = cpu_to_be16(TPM_TAG_RQU_COMMAND),
.length = cpu_to_be32(30),
.ordinal = cpu_to_be32(TPM_ORD_READPUBEK)
};
static ssize_t pubek_show(struct device *dev, struct device_attribute *attr, static ssize_t pubek_show(struct device *dev, struct device_attribute *attr,
char *buf) char *buf)
{ {
u8 *data; struct tpm_buf tpm_buf;
struct tpm_cmd_t tpm_cmd; struct tpm_readpubek_out *out;
ssize_t err; ssize_t rc;
int i, rc; int i;
char *str = buf; char *str = buf;
struct tpm_chip *chip = to_tpm_chip(dev); struct tpm_chip *chip = to_tpm_chip(dev);
char anti_replay[20];
memset(&tpm_cmd, 0, sizeof(tpm_cmd)); memset(&anti_replay, 0, sizeof(anti_replay));
tpm_cmd.header.in = tpm_readpubek_header; rc = tpm_buf_init(&tpm_buf, TPM_TAG_RQU_COMMAND, TPM_ORD_READPUBEK);
err = tpm_transmit_cmd(chip, NULL, &tpm_cmd, READ_PUBEK_RESULT_SIZE, if (rc)
READ_PUBEK_RESULT_MIN_BODY_SIZE, 0, return rc;
"attempting to read the PUBEK");
if (err) tpm_buf_append(&tpm_buf, anti_replay, sizeof(anti_replay));
goto out;
rc = tpm_transmit_cmd(chip, NULL, tpm_buf.data, PAGE_SIZE,
/* READ_PUBEK_RESULT_MIN_BODY_SIZE, 0,
ignore header 10 bytes "attempting to read the PUBEK");
algorithm 32 bits (1 == RSA ) if (rc) {
encscheme 16 bits tpm_buf_destroy(&tpm_buf);
sigscheme 16 bits return 0;
parameters (RSA 12->bytes: keybit, #primes, expbit) }
keylenbytes 32 bits
256 byte modulus out = (struct tpm_readpubek_out *)&tpm_buf.data[10];
ignore checksum 20 bytes
*/
data = tpm_cmd.params.readpubek_out_buffer;
str += str +=
sprintf(str, sprintf(str,
"Algorithm: %02X %02X %02X %02X\n" "Algorithm: %02X %02X %02X %02X\n"
...@@ -68,21 +72,26 @@ static ssize_t pubek_show(struct device *dev, struct device_attribute *attr, ...@@ -68,21 +72,26 @@ static ssize_t pubek_show(struct device *dev, struct device_attribute *attr,
"%02X %02X %02X %02X\n" "%02X %02X %02X %02X\n"
"Modulus length: %d\n" "Modulus length: %d\n"
"Modulus:\n", "Modulus:\n",
data[0], data[1], data[2], data[3], out->algorithm[0], out->algorithm[1], out->algorithm[2],
data[4], data[5], out->algorithm[3],
data[6], data[7], out->encscheme[0], out->encscheme[1],
data[12], data[13], data[14], data[15], out->sigscheme[0], out->sigscheme[1],
data[16], data[17], data[18], data[19], out->parameters[0], out->parameters[1],
data[20], data[21], data[22], data[23], out->parameters[2], out->parameters[3],
be32_to_cpu(*((__be32 *) (data + 24)))); out->parameters[4], out->parameters[5],
out->parameters[6], out->parameters[7],
out->parameters[8], out->parameters[9],
out->parameters[10], out->parameters[11],
be32_to_cpu(out->keysize));
for (i = 0; i < 256; i++) { for (i = 0; i < 256; i++) {
str += sprintf(str, "%02X ", data[i + 28]); str += sprintf(str, "%02X ", out->modulus[i]);
if ((i + 1) % 16 == 0) if ((i + 1) % 16 == 0)
str += sprintf(str, "\n"); str += sprintf(str, "\n");
} }
out:
rc = str - buf; rc = str - buf;
tpm_buf_destroy(&tpm_buf);
return rc; return rc;
} }
static DEVICE_ATTR_RO(pubek); static DEVICE_ATTR_RO(pubek);
......
...@@ -345,17 +345,6 @@ enum tpm_sub_capabilities { ...@@ -345,17 +345,6 @@ enum tpm_sub_capabilities {
TPM_CAP_PROP_TIS_DURATION = 0x120, TPM_CAP_PROP_TIS_DURATION = 0x120,
}; };
struct tpm_readpubek_params_out {
u8 algorithm[4];
u8 encscheme[2];
u8 sigscheme[2];
__be32 paramsize;
u8 parameters[12]; /*assuming RSA*/
__be32 keysize;
u8 modulus[256];
u8 checksum[20];
} __packed;
typedef union { typedef union {
struct tpm_input_header in; struct tpm_input_header in;
struct tpm_output_header out; struct tpm_output_header out;
...@@ -385,8 +374,6 @@ struct tpm_getrandom_in { ...@@ -385,8 +374,6 @@ struct tpm_getrandom_in {
} __packed; } __packed;
typedef union { typedef union {
struct tpm_readpubek_params_out readpubek_out;
u8 readpubek_out_buffer[sizeof(struct tpm_readpubek_params_out)];
struct tpm_pcrread_in pcrread_in; struct tpm_pcrread_in pcrread_in;
struct tpm_pcrread_out pcrread_out; struct tpm_pcrread_out pcrread_out;
struct tpm_getrandom_in getrandom_in; struct tpm_getrandom_in getrandom_in;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment