summaryrefslogtreecommitdiff
path: root/ArmPkg/Include/Library/ArmArchTimer.h
blob: eb7e87d3c4fcec731b4f8d05008ac52ce87360cd (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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
/** @file

  Copyright (c) 2011 - 2013, ARM Ltd. All rights reserved.<BR>

  This program and the accompanying materials
  are licensed and made available under the terms and conditions of the BSD License
  which accompanies this distribution.  The full text of the license may be found at
  http://opensource.org/licenses/bsd-license.php

  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
  WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.

**/

#ifndef __ARM_ARCH_TIMER_H__
#define __ARM_ARCH_TIMER_H__

#define ARM_ARCH_TIMER_ENABLE           (1 << 0)
#define ARM_ARCH_TIMER_IMASK            (1 << 1)
#define ARM_ARCH_TIMER_ISTATUS          (1 << 2)

typedef enum {
  CntFrq = 0,
  CntPct,
  CntkCtl,
  CntpTval,
  CntpCtl,
  CntvTval,
  CntvCtl,
  CntvCt,
  CntpCval,
  CntvCval,
  CntvOff,
  CnthCtl,
  CnthpTval,
  CnthpCtl,
  CnthpCval,
  RegMaximum
} ARM_ARCH_TIMER_REGS;

VOID
EFIAPI
ArmArchTimerReadReg (
  IN   ARM_ARCH_TIMER_REGS   Reg,
  OUT  VOID                  *DstBuf
  );

VOID
EFIAPI
ArmArchTimerWriteReg (
  IN   ARM_ARCH_TIMER_REGS   Reg,
  IN   VOID                  *SrcBuf
  );

VOID
EFIAPI
ArmArchTimerEnableTimer (
  VOID
  );

VOID
EFIAPI
ArmArchTimerDisableTimer (
  VOID
  );

VOID
EFIAPI
ArmArchTimerSetTimerFreq (
  IN   UINTN  FreqInHz
  );

UINTN
EFIAPI
ArmArchTimerGetTimerFreq (
  VOID
  );

VOID
EFIAPI
ArmArchTimerSetTimerVal (
  IN   UINTN   Val
  );

UINTN
EFIAPI
ArmArchTimerGetTimerVal (
  VOID
  );

UINT64
EFIAPI
ArmArchTimerGetSystemCount (
  VOID
  );

UINTN
EFIAPI
ArmArchTimerGetTimerCtrlReg (
  VOID
  );

VOID
EFIAPI
ArmArchTimerSetTimerCtrlReg (
  UINTN Val
  );

VOID
EFIAPI
ArmArchTimerSetCompareVal (
  IN   UINT64   Val
  );

#endif // __ARM_ARCH_TIMER_H__