1 /*
2 * PROJECT: ReactOS HAL
3 * LICENSE: BSD - See COPYING.ARM in the top level directory
4 * FILE: hal/halarm/generic/timer.c
5 * PURPOSE: Timer Routines
6 * PROGRAMMERS: ReactOS Portable Systems Group
7 */
8
9 /* INCLUDES *******************************************************************/
10
11 #include <hal.h>
12 #define NDEBUG
13 #include <debug.h>
14
15 VOID
16 FASTCALL
17 KeUpdateSystemTime(
18 IN PKTRAP_FRAME TrapFrame,
19 IN ULONG Increment,
20 IN KIRQL OldIrql
21 );
22
23 /* GLOBALS ********************************************************************/
24
25 ULONG HalpCurrentTimeIncrement, HalpNextTimeIncrement, HalpNextIntervalCount;
26
27 /* PRIVATE FUNCTIONS **********************************************************/
28
29 VOID
HalpClockInterrupt(VOID)30 HalpClockInterrupt(VOID)
31 {
32 /* Clear the interrupt */
33 ASSERT(KeGetCurrentIrql() == CLOCK2_LEVEL);
34 WRITE_REGISTER_ULONG(TIMER0_INT_CLEAR, 1);
35
36 /* FIXME: Update HAL Perf counters */
37
38 /* FIXME: Check if someone changed the clockrate */
39
40 /* Call the kernel */
41 KeUpdateSystemTime(KeGetCurrentThread()->TrapFrame,
42 HalpCurrentTimeIncrement,
43 CLOCK2_LEVEL);
44 }
45
46 VOID
HalpStallInterrupt(VOID)47 HalpStallInterrupt(VOID)
48 {
49 /* Clear the interrupt */
50 WRITE_REGISTER_ULONG(TIMER0_INT_CLEAR, 1);
51 }
52
53 VOID
HalpInitializeClock(VOID)54 HalpInitializeClock(VOID)
55 {
56 PKPCR Pcr = KeGetPcr();
57 ULONG ClockInterval;
58 SP804_CONTROL_REGISTER ControlRegister;
59
60 /* Setup the clock and profile interrupt */
61 Pcr->InterruptRoutine[CLOCK2_LEVEL] = HalpStallInterrupt;
62
63 /*
64 * Configure the interval to 10ms
65 * (INTERVAL (10ms) * TIMCLKfreq (1MHz))
66 * --------------------------------------- == 10^4
67 * (TIMCLKENXdiv (1) * PRESCALEdiv (1))
68 */
69 ClockInterval = 0x2710;
70
71 /* Configure the timer */
72 ControlRegister.AsUlong = 0;
73 ControlRegister.Wide = TRUE;
74 ControlRegister.Periodic = TRUE;
75 ControlRegister.Interrupt = TRUE;
76 ControlRegister.Enabled = TRUE;
77
78 /* Enable the timer */
79 WRITE_REGISTER_ULONG(TIMER0_LOAD, ClockInterval);
80 WRITE_REGISTER_ULONG(TIMER0_CONTROL, ControlRegister.AsUlong);
81 }
82
83 /* PUBLIC FUNCTIONS ***********************************************************/
84
85 /*
86 * @implemented
87 */
88 VOID
89 NTAPI
HalCalibratePerformanceCounter(IN volatile PLONG Count,IN ULONGLONG NewCount)90 HalCalibratePerformanceCounter(IN volatile PLONG Count,
91 IN ULONGLONG NewCount)
92 {
93 UNIMPLEMENTED;
94 while (TRUE);
95 }
96
97 /*
98 * @implemented
99 */
100 ULONG
101 NTAPI
HalSetTimeIncrement(IN ULONG Increment)102 HalSetTimeIncrement(IN ULONG Increment)
103 {
104 UNIMPLEMENTED;
105 while (TRUE);
106 return Increment;
107 }
108
109 /*
110 * @implemented
111 */
112 VOID
113 NTAPI
KeStallExecutionProcessor(IN ULONG Microseconds)114 KeStallExecutionProcessor(IN ULONG Microseconds)
115 {
116 SP804_CONTROL_REGISTER ControlRegister;
117
118 /* Enable the timer */
119 WRITE_REGISTER_ULONG(TIMER1_LOAD, Microseconds);
120
121 /* Configure the timer */
122 ControlRegister.AsUlong = 0;
123 ControlRegister.OneShot = TRUE;
124 ControlRegister.Wide = TRUE;
125 ControlRegister.Periodic = TRUE;
126 ControlRegister.Enabled = TRUE;
127 WRITE_REGISTER_ULONG(TIMER1_CONTROL, ControlRegister.AsUlong);
128
129 /* Now we will loop until the timer reached 0 */
130 while (READ_REGISTER_ULONG(TIMER1_VALUE));
131 }
132
133 /*
134 * @implemented
135 */
136 LARGE_INTEGER
137 NTAPI
KeQueryPerformanceCounter(IN PLARGE_INTEGER PerformanceFreq)138 KeQueryPerformanceCounter(IN PLARGE_INTEGER PerformanceFreq)
139 {
140 LARGE_INTEGER Value;
141
142 UNIMPLEMENTED;
143 while (TRUE);
144
145 Value.QuadPart = 0;
146 return Value;
147 }
148
149 /* EOF */
150