summaryrefslogtreecommitdiffstats
path: root/MdePkg/Include/IndustryStandard/ArmPerformanceMonitoringUnitTable.h
blob: fe7084cffd1d1913b7541d5ddf69d74a3ef92c01 (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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
/** @file
  ACPI Arm Performance Monitoring Unit (APMT) table
  as specified in ARM spec DEN0117

  Copyright (c) 2022, NVIDIA CORPORATION. All rights reserved.
  Copyright (c) 2022, ARM Limited. All rights reserved.
  SPDX-License-Identifier: BSD-2-Clause-Patent
**/

#ifndef ARM_PERFORMANCE_MONITORING_UNIT_TABLE_H_
#define ARM_PERFORMANCE_MONITORING_UNIT_TABLE_H_

#include <IndustryStandard/Acpi.h>

#pragma pack(1)

///
/// Arm Performance Monitoring Unit (APMT) tabl
///
typedef struct {
  EFI_ACPI_DESCRIPTION_HEADER    Header;
} EFI_ACPI_ARM_PERFORMANCE_MONITORING_UNIT_TABLE_HEADER;

///
/// APMT Revision (as defined in DEN0117.)
///
#define EFI_ACPI_ARM_PERFORMANCE_MONITORING_UNIT_TABLE_REVISION  0x00

///
/// Arm PMU Node Structure
///

// Node Flags
#define EFI_ACPI_APMT_DUAL_PAGE_EXTENSION_SUPPORTED          BIT0
#define EFI_ACPI_APMT_PROCESSOR_AFFINITY_TYPE_CONTAINER      BIT1
#define EFI_ACPI_APMT_PROCESSOR_AFFINITY_TYPE_PROCESSOR      0 // BIT 1
#define EFI_ACPI_APMT_64BIT_SINGLE_COPY_ATOMICITY_SUPPORTED  BIT2

// Interrupt Flags
#define EFI_ACPI_APMT_INTERRUPT_MODE_EDGE_TRIGGERED   BIT0
#define EFI_ACPI_APMT_INTERRUPT_MODE_LEVEL_TRIGGERED  0 // BIT 0
#define EFI_ACPI_APMT_INTERRUPT_TYPE_WIRED            0 // BIT 1

// Node Type
#define EFI_ACPI_APMT_NODE_TYPE_MEMORY_CONTROLLER  0x00
#define EFI_ACPI_APMT_NODE_TYPE_SMMU               0x01
#define EFI_ACPI_APMT_NODE_TYPE_PCIE_ROOT_COMPLEX  0x02
#define EFI_ACPI_APMT_NODE_TYPE_ACPI_DEVICE        0x03
#define EFI_ACPI_APMT_NODE_TYPE_CPU_CACHE          0x04

typedef struct {
  UINT16    Length;
  UINT8     NodeFlags;
  UINT8     NodeType;
  UINT32    Identifier;
  UINT64    NodeInstancePrimary;
  UINT32    NodeInstanceSecondary;
  UINT64    BaseAddress0;
  UINT64    BaseAddress1;
  UINT32    OverflowInterrupt;
  UINT32    Reserved1;
  UINT32    OverflowInterruptFlags;
  UINT32    ProcessorAffinity;
  UINT32    ImplementationId;
} EFI_ACPI_ARM_PERFORMANCE_MONITORING_UNIT_NODE;

#pragma pack()

#endif