2012-07-11 15:08:12 +00:00
|
|
|
|
|
|
|
#ifndef __TPM_EVENTLOG_H__
|
|
|
|
#define __TPM_EVENTLOG_H__
|
|
|
|
|
|
|
|
#define TCG_EVENT_NAME_LEN_MAX 255
|
|
|
|
#define MAX_TEXT_EVENT 1000 /* Max event string length */
|
|
|
|
#define ACPI_TCPA_SIG "TCPA" /* 0x41504354 /'TCPA' */
|
|
|
|
|
2015-06-17 22:17:08 +00:00
|
|
|
#ifdef CONFIG_PPC64
|
|
|
|
#define do_endian_conversion(x) be32_to_cpu(x)
|
|
|
|
#else
|
|
|
|
#define do_endian_conversion(x) x
|
|
|
|
#endif
|
|
|
|
|
2012-07-11 15:08:12 +00:00
|
|
|
enum bios_platform_class {
|
|
|
|
BIOS_CLIENT = 0x00,
|
|
|
|
BIOS_SERVER = 0x01,
|
|
|
|
};
|
|
|
|
|
|
|
|
struct tpm_bios_log {
|
|
|
|
void *bios_event_log;
|
|
|
|
void *bios_event_log_end;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct tcpa_event {
|
|
|
|
u32 pcr_index;
|
|
|
|
u32 event_type;
|
|
|
|
u8 pcr_value[20]; /* SHA1 */
|
|
|
|
u32 event_size;
|
|
|
|
u8 event_data[0];
|
|
|
|
};
|
|
|
|
|
|
|
|
enum tcpa_event_types {
|
|
|
|
PREBOOT = 0,
|
|
|
|
POST_CODE,
|
|
|
|
UNUSED,
|
|
|
|
NO_ACTION,
|
|
|
|
SEPARATOR,
|
|
|
|
ACTION,
|
|
|
|
EVENT_TAG,
|
|
|
|
SCRTM_CONTENTS,
|
|
|
|
SCRTM_VERSION,
|
|
|
|
CPU_MICROCODE,
|
|
|
|
PLATFORM_CONFIG_FLAGS,
|
|
|
|
TABLE_OF_DEVICES,
|
|
|
|
COMPACT_HASH,
|
|
|
|
IPL,
|
|
|
|
IPL_PARTITION_DATA,
|
|
|
|
NONHOST_CODE,
|
|
|
|
NONHOST_CONFIG,
|
|
|
|
NONHOST_INFO,
|
|
|
|
};
|
|
|
|
|
|
|
|
struct tcpa_pc_event {
|
|
|
|
u32 event_id;
|
|
|
|
u32 event_size;
|
|
|
|
u8 event_data[0];
|
|
|
|
};
|
|
|
|
|
|
|
|
enum tcpa_pc_event_ids {
|
|
|
|
SMBIOS = 1,
|
|
|
|
BIS_CERT,
|
|
|
|
POST_BIOS_ROM,
|
|
|
|
ESCD,
|
|
|
|
CMOS,
|
|
|
|
NVRAM,
|
|
|
|
OPTION_ROM_EXEC,
|
|
|
|
OPTION_ROM_CONFIG,
|
|
|
|
OPTION_ROM_MICROCODE = 10,
|
|
|
|
S_CRTM_VERSION,
|
|
|
|
S_CRTM_CONTENTS,
|
|
|
|
POST_CONTENTS,
|
|
|
|
HOST_TABLE_OF_DEVICES,
|
|
|
|
};
|
|
|
|
|
2016-11-14 10:00:52 +00:00
|
|
|
int read_log(struct tpm_chip *chip);
|
2012-08-14 23:35:32 +00:00
|
|
|
|
|
|
|
#if defined(CONFIG_TCG_IBMVTPM) || defined(CONFIG_TCG_IBMVTPM_MODULE) || \
|
|
|
|
defined(CONFIG_ACPI)
|
2016-11-14 10:00:50 +00:00
|
|
|
extern int tpm_bios_log_setup(struct tpm_chip *chip);
|
|
|
|
extern void tpm_bios_log_teardown(struct tpm_chip *chip);
|
2012-08-14 23:35:32 +00:00
|
|
|
#else
|
2016-11-14 10:00:50 +00:00
|
|
|
static inline int tpm_bios_log_setup(struct tpm_chip *chip)
|
2012-08-14 23:35:32 +00:00
|
|
|
{
|
2016-11-14 10:00:50 +00:00
|
|
|
return 0;
|
2012-08-14 23:35:32 +00:00
|
|
|
}
|
2016-11-14 10:00:50 +00:00
|
|
|
static inline void tpm_bios_log_teardown(struct tpm_chip *chip)
|
2012-08-14 23:35:32 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2012-07-11 15:08:12 +00:00
|
|
|
#endif
|