summaryrefslogtreecommitdiffstats
path: root/SecurityPkg/Include/Guid/Tcg2PhysicalPresenceData.h
blob: 382b487649eff9f69f52a56e222cb336f1a4ad60 (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
/** @file
  Define the variable data structures used for TCG2 physical presence.
  The TPM2 request from firmware or OS is saved to variable. And it is
  cleared after it is processed in the next boot cycle. The TPM2 response
  is saved to variable.

Copyright (c) 2015 - 2018, Intel Corporation. All rights reserved. <BR>
SPDX-License-Identifier: BSD-2-Clause-Patent

**/

#ifndef __TCG2_PHYSICAL_PRESENCE_DATA_GUID_H__
#define __TCG2_PHYSICAL_PRESENCE_DATA_GUID_H__

#define EFI_TCG2_PHYSICAL_PRESENCE_DATA_GUID \
  { \
    0xaeb9c5c1, 0x94f1, 0x4d02, { 0xbf, 0xd9, 0x46, 0x2, 0xdb, 0x2d, 0x3c, 0x54 } \
  }

#define TCG2_PHYSICAL_PRESENCE_VARIABLE  L"Tcg2PhysicalPresence"

typedef struct {
  UINT8   PPRequest;      ///< Physical Presence request command.
  UINT32  PPRequestParameter; ///< Physical Presence request Parameter.
  UINT8   LastPPRequest;
  UINT32  PPResponse;
} EFI_TCG2_PHYSICAL_PRESENCE;

//
// This variable is used to save TCG2 Management Flags and corresponding operations.
// It should be protected from malicious software (e.g. Set it as read-only variable).
//
#define TCG2_PHYSICAL_PRESENCE_FLAGS_VARIABLE  L"Tcg2PhysicalPresenceFlags"
typedef struct {
  UINT32  PPFlags;
} EFI_TCG2_PHYSICAL_PRESENCE_FLAGS;

extern EFI_GUID  gEfiTcg2PhysicalPresenceGuid;

#endif