mirror of
https://github.com/reactos/reactos.git
synced 2025-01-01 12:04:51 +00:00
154 lines
4.6 KiB
C
154 lines
4.6 KiB
C
/*
|
|
* COPYRIGHT: GPL - See COPYING in the top level directory
|
|
* PROJECT: ReactOS Virtual DOS Machine
|
|
* FILE: subsystems/mvdm/ntvdm/hardware/cmos.h
|
|
* PURPOSE: CMOS Real Time Clock emulation
|
|
* PROGRAMMERS: Aleksandar Andrejevic <theflash AT sdf DOT lonestar DOT org>
|
|
*/
|
|
|
|
#ifndef _CMOS_H_
|
|
#define _CMOS_H_
|
|
|
|
/* DEFINES ********************************************************************/
|
|
|
|
#define RTC_IRQ_NUMBER 8
|
|
#define CMOS_ADDRESS_PORT 0x70
|
|
#define CMOS_DATA_PORT 0x71
|
|
#define CMOS_DISABLE_NMI (1 << 7)
|
|
#define CMOS_BATTERY_OK 0x80
|
|
|
|
/* Status Register B flags */
|
|
#define CMOS_STB_DST (1 << 0)
|
|
#define CMOS_STB_24HOUR (1 << 1)
|
|
#define CMOS_STB_BINARY (1 << 2)
|
|
#define CMOS_STB_SQUARE_WAVE (1 << 3)
|
|
#define CMOS_STB_INT_ON_UPDATE (1 << 4)
|
|
#define CMOS_STB_INT_ON_ALARM (1 << 5)
|
|
#define CMOS_STB_INT_PERIODIC (1 << 6)
|
|
#define CMOS_STB_UPDATE_CYCLE (1 << 7)
|
|
|
|
/* Status Register C flags */
|
|
#define CMOS_STC_UF (1 << 4)
|
|
#define CMOS_STC_AF (1 << 5)
|
|
#define CMOS_STC_PF (1 << 6)
|
|
#define CMOS_STC_IRQF (1 << 7)
|
|
|
|
/* Default register values */
|
|
#define CMOS_DEFAULT_STA 0x26
|
|
#define CMOS_DEFAULT_STB CMOS_STB_24HOUR
|
|
|
|
// Bit 0: Floppy, Bit 1: FPU, Bit 2: Mouse, Bits 4-5: 80x25 Color Video, Bits 6-7: 2 floppy drives
|
|
#define CMOS_EQUIPMENT_LIST 0x6F
|
|
|
|
|
|
#define WRITE_CMOS_DATA(Cmos, Value) \
|
|
((Cmos).StatusRegB & CMOS_STB_BINARY) ? (Value) : BCD_TO_BINARY(Value)
|
|
|
|
#define READ_CMOS_DATA(Cmos, Value) \
|
|
((Cmos).StatusRegB & CMOS_STB_BINARY) ? (Value) : BINARY_TO_BCD(Value)
|
|
|
|
typedef enum _CMOS_REGISTERS
|
|
{
|
|
CMOS_REG_SECONDS,
|
|
CMOS_REG_ALARM_SEC,
|
|
CMOS_REG_MINUTES,
|
|
CMOS_REG_ALARM_MIN,
|
|
CMOS_REG_HOURS,
|
|
CMOS_REG_ALARM_HRS,
|
|
CMOS_REG_DAY_OF_WEEK,
|
|
CMOS_REG_DAY,
|
|
CMOS_REG_MONTH,
|
|
CMOS_REG_YEAR,
|
|
CMOS_REG_STATUS_A,
|
|
CMOS_REG_STATUS_B,
|
|
CMOS_REG_STATUS_C,
|
|
CMOS_REG_STATUS_D,
|
|
CMOS_REG_DIAGNOSTICS,
|
|
CMOS_REG_SHUTDOWN_STATUS,
|
|
CMOS_REG_EQUIPMENT_LIST = 0x14,
|
|
CMOS_REG_BASE_MEMORY_LOW = 0x15,
|
|
CMOS_REG_BASE_MEMORY_HIGH = 0x16,
|
|
CMOS_REG_EXT_MEMORY_LOW = 0x17,
|
|
CMOS_REG_EXT_MEMORY_HIGH = 0x18,
|
|
CMOS_REG_SYSOP = 0x2D,
|
|
CMOS_REG_ACTUAL_EXT_MEMORY_LOW = 0x30,
|
|
CMOS_REG_ACTUAL_EXT_MEMORY_HIGH = 0x31,
|
|
CMOS_REG_CENTURY = 0x32,
|
|
CMOS_REG_MAX = 0x40
|
|
} CMOS_REGISTERS, *PCMOS_REGISTERS;
|
|
|
|
/*
|
|
* CMOS Memory Map
|
|
*
|
|
* See the following documentation for more information:
|
|
* http://www.intel-assembler.it/portale/5/cmos-memory-map-123/cmos-memory-map-123.asp
|
|
* http://wiki.osdev.org/CMOS
|
|
* http://www.walshcomptech.com/ohlandl/config/cmos_registers.html
|
|
* http://www.fysnet.net/cmosinfo.htm
|
|
* http://www.bioscentral.com/misc/cmosmap.htm
|
|
*/
|
|
#pragma pack(push, 1)
|
|
typedef struct
|
|
{
|
|
BYTE Second; // 0x00
|
|
BYTE AlarmSecond; // 0x01
|
|
BYTE Minute; // 0x02
|
|
BYTE AlarmMinute; // 0x03
|
|
BYTE Hour; // 0x04
|
|
BYTE AlarmHour; // 0x05
|
|
BYTE DayOfWeek; // 0x06
|
|
BYTE Day; // 0x07
|
|
BYTE Month; // 0x08
|
|
BYTE Year; // 0x09
|
|
|
|
BYTE StatusRegA; // 0x0a
|
|
BYTE StatusRegB; // 0x0b
|
|
} CMOS_CLOCK, *PCMOS_CLOCK;
|
|
|
|
typedef struct
|
|
{
|
|
union
|
|
{
|
|
struct
|
|
{
|
|
CMOS_CLOCK; // 0x00 - 0x0b
|
|
BYTE StatusRegC; // 0x0c
|
|
BYTE StatusRegD; // 0x0d
|
|
BYTE Diagnostics; // 0x0e
|
|
BYTE ShutdownStatus; // 0x0f
|
|
BYTE FloppyDrivesType; // 0x10
|
|
BYTE Reserved0; // 0x11
|
|
BYTE HardDrivesType; // 0x12
|
|
BYTE Reserved1; // 0x13
|
|
BYTE EquipmentList; // 0x14
|
|
BYTE BaseMemoryLow; // 0x15
|
|
BYTE BaseMemoryHigh; // 0x16
|
|
BYTE ExtMemoryLow; // 0x17
|
|
BYTE ExtMemoryHigh; // 0x18
|
|
BYTE ExtHardDrivesType[2]; // 0x19 - 0x1a
|
|
BYTE Reserved2[0x15]; // 0x1b
|
|
BYTE ActualExtMemoryLow; // 0x30
|
|
BYTE ActualExtMemoryHigh; // 0x31
|
|
BYTE Century; // 0x32
|
|
};
|
|
BYTE Regs1[0x10]; // 0x00 - 0x0f
|
|
BYTE Regs [0x40]; // 0x00 - 0x3f
|
|
};
|
|
|
|
/*
|
|
* Extended information 0x40 - 0x7f
|
|
*/
|
|
} CMOS_MEMORY, *PCMOS_MEMORY;
|
|
#pragma pack(pop)
|
|
|
|
C_ASSERT(sizeof(CMOS_MEMORY) == 0x40);
|
|
|
|
/* FUNCTIONS ******************************************************************/
|
|
|
|
BOOLEAN IsNmiEnabled(VOID);
|
|
DWORD RtcGetTicksPerSecond(VOID);
|
|
|
|
VOID CmosInitialize(VOID);
|
|
VOID CmosCleanup(VOID);
|
|
|
|
#endif /* _CMOS_H_ */
|