ReactOS 0.4.15-dev-8632-gbc8c7d1
cmos.c
Go to the documentation of this file.
1/*
2 * PROJECT: ReactOS HAL
3 * LICENSE: GPL - See COPYING in the top level directory
4 * PURPOSE: CMOS Access Routines (Real Time Clock and LastKnownGood)
5 * PROGRAMMERS: Alex Ionescu (alex.ionescu@reactos.org)
6 * Eric Kohl
7 */
8
9/* INCLUDES ******************************************************************/
10
11#include <hal.h>
12
13#define NDEBUG
14#include <debug.h>
15
16/* GLOBALS *******************************************************************/
17
19
20/* PRIVATE FUNCTIONS *********************************************************/
21
26{
27 /* Select the register */
29
30 /* Query the value */
32}
33
35VOID
39{
40 /* Select the register */
42
43 /* Write the value */
45}
46
54{
58
59 /* Do nothing if we don't have a length */
60 if (!Length) return 0;
61
62 /* Acquire CMOS Lock */
64
65 /* Check if this is simple CMOS */
66 if (BusNumber == 0)
67 {
68 /* Loop the buffer up to 0xFF */
69 while ((Len > 0) && (Address < 0x100))
70 {
71 /* Read the data */
73
74 /* Update position and length */
75 Ptr++;
76 Address++;
77 Len--;
78 }
79 }
80 else if (BusNumber == 1)
81 {
82 /* Loop the buffer up to 0xFFFF */
83 while ((Len > 0) && (Address < 0x10000))
84 {
85 /* Write the data */
87
88 /* Update position and length */
89 Ptr++;
90 Address++;
91 Len--;
92 }
93 }
94
95 /* Release CMOS Lock */
97
98 /* Return length read */
99 return Length - Len;
100}
101
102ULONG
103NTAPI
109{
112 ULONG Len = Length;
113
114 /* Do nothing if we don't have a length */
115 if (!Length) return 0;
116
117 /* Acquire CMOS Lock */
119
120 /* Check if this is simple CMOS */
121 if (BusNumber == 0)
122 {
123 /* Loop the buffer up to 0xFF */
124 while ((Len > 0) && (Address < 0x100))
125 {
126 /* Write the data */
128
129 /* Update position and length */
130 Ptr++;
131 Address++;
132 Len--;
133 }
134 }
135 else if (BusNumber == 1)
136 {
137 /* Loop the buffer up to 0xFFFF */
138 while ((Len > 0) && (Address < 0x10000))
139 {
140 /* Write the data */
142
143 /* Update position and length */
144 Ptr++;
145 Address++;
146 Len--;
147 }
148 }
149
150 /* Release CMOS Lock */
152
153 /* Return length read */
154 return Length - Len;
155}
156
157CODE_SEG("INIT")
158VOID
159NTAPI
161{
162 /* Set default century offset byte */
164
165 /* No support for EISA or MCA */
167}
168
169/* PUBLIC FUNCTIONS **********************************************************/
170
171/*
172 * @implemented
173 */
175NTAPI
177 _In_ PCH Name,
180{
181 UCHAR Val;
182
183 /* Only variable supported on x86 */
184 if (_stricmp(Name, "LastKnownGood")) return ENOENT;
185
186 /* Acquire CMOS Lock */
188
189 /* Query the current value */
190 Val = HalpReadCmos(RTC_REGISTER_B) & 0x01;
191
192 /* Release CMOS lock */
194
195 /* Check the flag */
196 if (Val)
197 {
198 /* Return false */
199 strncpy(Value, "FALSE", ValueLength);
200 }
201 else
202 {
203 /* Return true */
204 strncpy(Value, "TRUE", ValueLength);
205 }
206
207 /* Return success */
208 return ESUCCESS;
209}
210
211/*
212 * @implemented
213 */
215NTAPI
217 IN PCH Value)
218{
219 UCHAR Val;
220
221 /* Only variable supported on x86 */
222 if (_stricmp(Name, "LastKnownGood")) return ENOMEM;
223
224 /* Check if this is true or false */
225 if (!_stricmp(Value, "TRUE"))
226 {
227 /* It's true, acquire CMOS lock */
229
230 /* Read the current value and add the flag */
231 Val = HalpReadCmos(RTC_REGISTER_B) | 1;
232 }
233 else if (!_stricmp(Value, "FALSE"))
234 {
235 /* It's false, acquire CMOS lock */
237
238 /* Read the current value and mask out the flag */
239 Val = HalpReadCmos(RTC_REGISTER_B) & ~1;
240 }
241 else
242 {
243 /* Fail */
244 return ENOMEM;
245 }
246
247 /* Write new value */
249
250 /* Release the lock and return success */
252 return ESUCCESS;
253}
254
255/*
256 * @implemented
257 */
259NTAPI
261{
262 /* Acquire CMOS Lock */
264
265 /* Loop while update is in progress */
267
268 /* Set the time data */
269 Time->Second = BCD_INT(HalpReadCmos(0));
270 Time->Minute = BCD_INT(HalpReadCmos(2));
271 Time->Hour = BCD_INT(HalpReadCmos(4));
272 Time->Weekday = BCD_INT(HalpReadCmos(6));
273 Time->Day = BCD_INT(HalpReadCmos(7));
274 Time->Month = BCD_INT(HalpReadCmos(8));
275 Time->Year = BCD_INT(HalpReadCmos(9));
276 Time->Milliseconds = 0;
277
278 /* FIXME: Check century byte */
279
280 /* Compensate for the century field */
281 Time->Year += (Time->Year > 80) ? 1900: 2000;
282
283 /* Release CMOS lock */
285
286 /* Always return TRUE */
287 return TRUE;
288}
289
290/*
291 * @implemented
292 */
294NTAPI
296{
297 /* Acquire CMOS Lock */
299
300 /* Loop while update is in progress */
302
303 /* Write time fields to CMOS RTC */
304 HalpWriteCmos(0, INT_BCD(Time->Second));
305 HalpWriteCmos(2, INT_BCD(Time->Minute));
306 HalpWriteCmos(4, INT_BCD(Time->Hour));
307 HalpWriteCmos(6, INT_BCD(Time->Weekday));
308 HalpWriteCmos(7, INT_BCD(Time->Day));
309 HalpWriteCmos(8, INT_BCD(Time->Month));
310 HalpWriteCmos(9, INT_BCD(Time->Year % 100));
311
312 /* FIXME: Set the century byte */
313
314 /* Release CMOS lock */
316
317 /* Always return TRUE */
318 return TRUE;
319}
#define CODE_SEG(...)
unsigned char BOOLEAN
#define ENOENT
Definition: acclib.h:79
#define ENOMEM
Definition: acclib.h:84
char * strncpy(char *DstString, const char *SrcString, ACPI_SIZE Count)
Definition: utclib.c:427
ULONG HalpBusType
Definition: pcibus.c:18
#define _stricmp
Definition: cat.c:22
Definition: bufpool.h:45
#define _Requires_lock_held_(lock)
#define Len
Definition: deflate.h:82
#define TRUE
Definition: types.h:120
_Must_inspect_result_ _In_ PFSRTL_PER_STREAM_CONTEXT Ptr
Definition: fsrtlfuncs.h:898
BOOLEAN NTAPI HalQueryRealTimeClock(OUT PTIME_FIELDS Time)
Definition: cmos.c:260
ARC_STATUS NTAPI HalGetEnvironmentVariable(_In_ PCH Name, _In_ USHORT ValueLength, _Out_writes_z_(ValueLength) PCH Value)
Definition: cmos.c:176
ULONG NTAPI HalpSetCmosData(_In_ ULONG BusNumber, _In_ ULONG SlotNumber, _In_reads_bytes_(Length) PVOID Buffer, _In_ ULONG Length)
Definition: cmos.c:104
VOID NTAPI HalpInitializeCmos(VOID)
Definition: cmos.c:160
BOOLEAN NTAPI HalSetRealTimeClock(IN PTIME_FIELDS Time)
Definition: cmos.c:295
ARC_STATUS NTAPI HalSetEnvironmentVariable(IN PCH Name, IN PCH Value)
Definition: cmos.c:216
ULONG NTAPI HalpGetCmosData(_In_ ULONG BusNumber, _In_ ULONG SlotNumber, _Out_writes_bytes_(Length) PVOID Buffer, _In_ ULONG Length)
Definition: cmos.c:49
UCHAR HalpCmosCenturyOffset
Definition: cmos.c:18
KSPIN_LOCK HalpSystemHardwareLock
Definition: spinlock.c:25
VOID NTAPI HalpReleaseCmosSpinLock(VOID)
Definition: spinlock.c:243
VOID NTAPI HalpAcquireCmosSpinLock(VOID)
Definition: spinlock.c:226
VOID NTAPI HalpWriteCmos(_In_ UCHAR Reg, _In_ UCHAR Value)
Definition: cmos.c:132
UCHAR NTAPI HalpReadCmos(_In_ UCHAR Reg)
Definition: cmos.c:123
#define RTC_REGISTER_B
Definition: halhw.h:15
#define CMOS_CONTROL_PORT
Definition: halhw.h:11
#define CMOS_DATA_PORT
Definition: halhw.h:12
#define INT_BCD(int)
Definition: halp.h:73
#define ASSERT(a)
Definition: mode.c:44
static PLARGE_INTEGER Time
Definition: time.c:105
#define _In_reads_bytes_(size)
Definition: ms_sal.h:321
#define _Out_writes_z_(size)
Definition: ms_sal.h:352
#define _Out_writes_bytes_(size)
Definition: ms_sal.h:350
#define _In_
Definition: ms_sal.h:308
#define MACHINE_TYPE_ISA
Definition: ketypes.h:113
CHAR * PCH
Definition: ntbasedef.h:391
_In_ ULONG _In_ ULONG _In_ ULONG Length
Definition: ntddpcm.h:102
#define BCD_INT(bcd)
Definition: hwinfo.c:13
#define READ_PORT_UCHAR(p)
Definition: pc98vid.h:22
#define WRITE_PORT_UCHAR(p, d)
Definition: pc98vid.h:21
unsigned short USHORT
Definition: pedump.c:61
static WCHAR Address[46]
Definition: ping.c:68
@ ESUCCESS
Definition: arc.h:32
ULONG ARC_STATUS
Definition: arc.h:4
#define NTAPI
Definition: typedefs.h:36
#define IN
Definition: typedefs.h:39
unsigned char * PUCHAR
Definition: typedefs.h:53
uint32_t ULONG
Definition: typedefs.h:59
#define OUT
Definition: typedefs.h:40
_Must_inspect_result_ _In_ WDFKEY _In_ PCUNICODE_STRING _In_ ULONG ValueLength
Definition: wdfregistry.h:275
_Must_inspect_result_ _In_ WDFKEY _In_ PCUNICODE_STRING _Out_opt_ PUSHORT _Inout_opt_ PUNICODE_STRING Value
Definition: wdfregistry.h:413
_In_ WDFIORESREQLIST _In_ ULONG SlotNumber
Definition: wdfresource.h:68
#define RTC_REG_A_UIP
Definition: xboxrtc.c:22
#define RTC_REGISTER_A
Definition: xboxrtc.c:21
_In_opt_ PUNICODE_STRING _In_ PDRIVER_OBJECT _In_ PDEVICE_OBJECT _In_ INTERFACE_TYPE _In_ ULONG BusNumber
Definition: halfuncs.h:160
unsigned char UCHAR
Definition: xmlstorage.h:181