mirror of
https://github.com/projectacrn/acrn-hypervisor.git
synced 2025-06-20 04:33:55 +00:00
We could add MMIO device pass through by two ways: a) If the MMIO device only has MMIO regions and no ACPI Table touched, using "--mmiodev_pt MMIO_regions", b) If the MMIO device touches ACPI Table, using "--acpidev_pt HID" Now only support TPM2 MSFT0101 MMIO device pass through through launch script using "--acpidev_pt MSFT0101". When we want to pass through the TPM2 deivce, we would not allow to emulate the vTPM2 at the same time. This is becuase the ACRN-DM emulate the TPM2 as MSFT0101 too. Otherwise, the VM can't boot. Besides, we could only support one TPM2 device PT and one MMIO device PT. For TPM2 device PT, the MMIO resources are hard-coded. For the MMIO device PT, we could pass through the MMIO resources on the cmdline. ToDo: 1. We may use HID to discover the MMIO regions and ACPI Table instaed of hard-coded. 2. To identify a MMIO device only by MMIO regions. 3. To allocate virtual MMIO regions in a reserved guest MMIO regions. Tracked-On: #5053 Signed-off-by: Li Fei1 <fei1.li@intel.com>
53 lines
1.7 KiB
C
53 lines
1.7 KiB
C
/*
|
|
* Copyright (C) 2018 Intel Corporation
|
|
* All rights reserved.
|
|
*
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
*/
|
|
|
|
#ifndef _TPM_H_
|
|
#define _TPM_H_
|
|
|
|
#define TPM_CRB_MMIO_ADDR 0xFED40000UL
|
|
#define TPM_CRB_MMIO_SIZE 0x5000U
|
|
|
|
/* TPM CRB registers */
|
|
enum {
|
|
CRB_REGS_LOC_STATE = TPM_CRB_MMIO_ADDR + 0x00,
|
|
CRB_REGS_RESERVED0 = TPM_CRB_MMIO_ADDR + 0x04,
|
|
CRB_REGS_LOC_CTRL = TPM_CRB_MMIO_ADDR + 0x08,
|
|
CRB_REGS_LOC_STS = TPM_CRB_MMIO_ADDR + 0x0C,
|
|
CRB_REGS_RESERVED1 = TPM_CRB_MMIO_ADDR + 0x10,
|
|
CRB_REGS_INTF_ID_LO = TPM_CRB_MMIO_ADDR + 0x30,
|
|
CRB_REGS_INTF_ID_HI = TPM_CRB_MMIO_ADDR + 0x34,
|
|
CRB_REGS_CTRL_EXT_LO = TPM_CRB_MMIO_ADDR + 0x38,
|
|
CRB_REGS_CTRL_EXT_HI = TPM_CRB_MMIO_ADDR + 0x3C,
|
|
CRB_REGS_CTRL_REQ = TPM_CRB_MMIO_ADDR + 0x40,
|
|
CRB_REGS_CTRL_STS = TPM_CRB_MMIO_ADDR + 0x44,
|
|
CRB_REGS_CTRL_CANCEL = TPM_CRB_MMIO_ADDR + 0x48,
|
|
CRB_REGS_CTRL_START = TPM_CRB_MMIO_ADDR + 0x4C,
|
|
CRB_REGS_CTRL_INT_ENABLE = TPM_CRB_MMIO_ADDR + 0x50,
|
|
CRB_REGS_CTRL_INT_STS = TPM_CRB_MMIO_ADDR + 0x54,
|
|
CRB_REGS_CTRL_CMD_SIZE = TPM_CRB_MMIO_ADDR + 0x58,
|
|
CRB_REGS_CTRL_CMD_PA_LO = TPM_CRB_MMIO_ADDR + 0x5C,
|
|
CRB_REGS_CTRL_CMD_PA_HI = TPM_CRB_MMIO_ADDR + 0x60,
|
|
CRB_REGS_CTRL_RSP_SIZE = TPM_CRB_MMIO_ADDR + 0x64,
|
|
CRB_REGS_CTRL_RSP_PA = TPM_CRB_MMIO_ADDR + 0x68,
|
|
CRB_DATA_BUFFER = TPM_CRB_MMIO_ADDR + 0x80
|
|
};
|
|
|
|
#define TPM_CRB_REG_SIZE ((CRB_DATA_BUFFER) - (TPM_CRB_MMIO_ADDR))
|
|
#define TPM_CRB_DATA_BUFFER_SIZE ((TPM_CRB_MMIO_SIZE) - (TPM_CRB_REG_SIZE))
|
|
|
|
/* APIs by tpm.c */
|
|
/* Initialize Virtual TPM2 */
|
|
void init_vtpm2(struct vmctx *ctx);
|
|
|
|
/* Deinitialize Virtual TPM2 */
|
|
void deinit_vtpm2(struct vmctx *ctx);
|
|
|
|
/* Parse Virtual TPM option from command line */
|
|
int acrn_parse_vtpm2(char *arg);
|
|
|
|
#endif
|