xref: /reactos/hal/halarm/generic/timer.c (revision cdf90707)
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
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
47 HalpStallInterrupt(VOID)
48 {
49     /* Clear the interrupt */
50     WRITE_REGISTER_ULONG(TIMER0_INT_CLEAR, 1);
51 }
52 
53 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
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
102 HalSetTimeIncrement(IN ULONG Increment)
103 {
104     UNIMPLEMENTED;
105     while (TRUE);
106     return Increment;
107 }
108 
109 /*
110  * @implemented
111  */
112 VOID
113 NTAPI
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
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