blob: da15a73bd8b190a69d63162639a3001e38da4e75 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
/* SPDX-License-Identifier: BSD-3-Clause */
#ifndef __COREBOOT_SRC_DRIVERS_SPI_TPM_TPM_H
#define __COREBOOT_SRC_DRIVERS_SPI_TPM_TPM_H
#include <drivers/tpm/cr50.h>
#include <security/tpm/tss_errors.h>
#include <stddef.h>
#include <spi-generic.h>
#define TPM_LOCALITY_0_SPI_BASE 0x00d40000
/*
* A tpm device descriptor, values read from the appropriate device regisrers
* are cached here.
*/
struct tpm2_info {
uint16_t vendor_id;
uint16_t device_id;
uint16_t revision;
};
/*
* Initialize a TPM2 device: read its id, claim locality of zero, verify that
* this indeed is a TPM2 device. Use the passed in handle to access the right
* SPI port.
*
* Return 0 on success, non-zero on failure.
*/
tpm_result_t tpm2_init(struct spi_slave *spi_if);
/*
* Each command processing consists of sending the command to the TPM, by
* writing it into the FIFO register, then polling the status register until
* the TPM is ready to respond, then reading the response from the FIFO
* regitster. The size of the response can be gleaned from the 6 byte header.
*
* This function places the response into the tpm2_response buffer and returns
* the size of the response.
*/
size_t tpm2_process_command(const void *tpm2_command, size_t command_size,
void *tpm2_response, size_t max_response);
/* Get information about previously initialized TPM device. */
void tpm2_get_info(struct tpm2_info *info);
#endif /* ! __COREBOOT_SRC_DRIVERS_SPI_TPM_TPM_H */
|