diff options
| author | fishsoupisgood <github@madingley.org> | 2019-04-29 01:17:54 +0100 | 
|---|---|---|
| committer | fishsoupisgood <github@madingley.org> | 2019-05-27 03:43:43 +0100 | 
| commit | 3f2546b2ef55b661fd8dd69682b38992225e86f6 (patch) | |
| tree | 65ca85f13617aee1dce474596800950f266a456c /hw/tpm/tpm_tis.h | |
| download | qemu-master.tar.gz qemu-master.tar.bz2 qemu-master.zip | |
Diffstat (limited to 'hw/tpm/tpm_tis.h')
| -rw-r--r-- | hw/tpm/tpm_tis.h | 70 | 
1 files changed, 70 insertions, 0 deletions
| diff --git a/hw/tpm/tpm_tis.h b/hw/tpm/tpm_tis.h new file mode 100644 index 00000000..a1df41fa --- /dev/null +++ b/hw/tpm/tpm_tis.h @@ -0,0 +1,70 @@ +/* + * tpm_tis.h - QEMU's TPM TIS interface emulator + * + * Copyright (C) 2006, 2010-2013 IBM Corporation + * + * Authors: + *  Stefan Berger <stefanb@us.ibm.com> + *  David Safford <safford@us.ibm.com> + * + * This work is licensed under the terms of the GNU GPL, version 2 or later. + * See the COPYING file in the top-level directory. + * + * Implementation of the TIS interface according to specs found at + * http://www.trustedcomputinggroup.org + * + */ +#ifndef TPM_TPM_TIS_H +#define TPM_TPM_TIS_H + +#include "hw/isa/isa.h" +#include "hw/acpi/tpm.h" +#include "qemu-common.h" + +#define TPM_TIS_NUM_LOCALITIES      5     /* per spec */ +#define TPM_TIS_LOCALITY_SHIFT      12 +#define TPM_TIS_NO_LOCALITY         0xff + +#define TPM_TIS_IS_VALID_LOCTY(x)   ((x) < TPM_TIS_NUM_LOCALITIES) + +#define TPM_TIS_BUFFER_MAX          4096 + +typedef enum { +    TPM_TIS_STATE_IDLE = 0, +    TPM_TIS_STATE_READY, +    TPM_TIS_STATE_COMPLETION, +    TPM_TIS_STATE_EXECUTION, +    TPM_TIS_STATE_RECEPTION, +} TPMTISState; + +/* locality data  -- all fields are persisted */ +typedef struct TPMLocality { +    TPMTISState state; +    uint8_t access; +    uint32_t sts; +    uint32_t iface_id; +    uint32_t inte; +    uint32_t ints; + +    uint16_t w_offset; +    uint16_t r_offset; +    TPMSizedBuffer w_buffer; +    TPMSizedBuffer r_buffer; +} TPMLocality; + +typedef struct TPMTISEmuState { +    QEMUBH *bh; +    uint32_t offset; +    uint8_t buf[TPM_TIS_BUFFER_MAX]; + +    uint8_t active_locty; +    uint8_t aborting_locty; +    uint8_t next_locty; + +    TPMLocality loc[TPM_TIS_NUM_LOCALITIES]; + +    qemu_irq irq; +    uint32_t irq_num; +} TPMTISEmuState; + +#endif /* TPM_TPM_TIS_H */ | 
