Fix iotest 153
[qemu/ar7.git] / hw / tpm / tpm_ppi.h
blobd33ef27de6d685df8a12c3f8daa24bceb47e22a8
1 /*
2 * TPM Physical Presence Interface
4 * Copyright (C) 2018 IBM Corporation
6 * Authors:
7 * Stefan Berger <stefanb@us.ibm.com>
9 * This work is licensed under the terms of the GNU GPL, version 2 or later.
10 * See the COPYING file in the top-level directory.
12 #ifndef TPM_TPM_PPI_H
13 #define TPM_TPM_PPI_H
15 #include "hw/acpi/tpm.h"
16 #include "exec/address-spaces.h"
18 typedef struct TPMPPI {
19 MemoryRegion ram;
20 uint8_t *buf;
21 } TPMPPI;
23 /**
24 * tpm_ppi_init:
25 * @tpmppi: a TPMPPI
26 * @m: the address-space / MemoryRegion to use
27 * @addr: the address of the PPI region
28 * @obj: the owner object
30 * Register the TPM PPI memory region at @addr on the given address
31 * space for the object @obj.
32 **/
33 void tpm_ppi_init(TPMPPI *tpmppi, struct MemoryRegion *m,
34 hwaddr addr, Object *obj);
36 /**
37 * tpm_ppi_reset:
38 * @tpmppi: a TPMPPI
40 * Function to call on machine reset. It will check if the "Memory
41 * overwrite" variable is set, and perform a memory clear on volatile
42 * memory if requested.
43 **/
44 void tpm_ppi_reset(TPMPPI *tpmppi);
46 #endif /* TPM_TPM_PPI_H */