blob: 54b0b63535857f4dba1ef0c739f8882df8a31c80 [file] [log] [blame]
// SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
/* Copyright 2013-2018 IBM Corp. */
#ifndef __TPM_H
#define __TPM_H
#include <device.h>
#include <eventlib.h>
#include <tss2/eventlog.h>
#include <tss2/tssskiboot.h>
struct tpm_dev {
/* TPM bus id */
int bus_id;
/* TPM address in the bus */
int i2c_addr;
};
struct tpm_driver {
/* Driver name */
const char* name;
/* Transmit the TPM command stored in buf to the tpm device */
int (*transmit)(struct tpm_dev *dev, uint8_t* buf, size_t cmdlen,
size_t *buflen);
};
struct tpm_chip {
/* TPM chip id */
int id;
/* Indicates whether or not the device and log are functional */
bool enabled;
/* TPM device tree node */
struct dt_node *node;
/* Event log handler */
struct _TpmLogMgr logmgr;
/* TPM device handler */
struct tpm_dev *dev;
/* TPM driver handler */
struct tpm_driver *driver;
struct list_node link;
};
void tss_tpm_register(struct tpm_dev *dev, struct tpm_driver *driver);
void tss_tpm_unregister(void);
struct tpm_dev* tpm_get_device(void);
struct tpm_driver* tpm_get_driver(void);
/*
* Register a tpm chip by binding the driver to dev.
* Event log is also registered by this function.
*/
extern int tpm_register_chip(struct dt_node *node, struct tpm_dev *dev,
struct tpm_driver *driver);
/*
* tpm_extendl - For each TPM device, this extends the sha1 and sha 256 digests
* to the indicated PCR and also records an event for the same PCR
* in the event log
* This calls a TSS extend function that supports multibank. Both sha1 and
* sha256 digests are extended in a single operation sent to the TPM device.
*/
int tpm_extendl(TPMI_DH_PCR pcr,
TPMI_ALG_HASH alg1, uint8_t *digest1,
TPMI_ALG_HASH alg2, uint8_t *digest2,
uint32_t event_type, const char *event_msg,
uint32_t event_msg_len);
/* Add status property to the TPM devices */
extern void tpm_add_status_property(void);
extern int tpm_init(void);
extern void tpm_cleanup(void);
#endif /* __TPM_H */