blob: e4b64623316814732daeab07ba1dc2635335ac45 [file] [log] [blame]
Kevin O'Connorf076a3e2008-02-25 22:25:15 -05001// Definitions for X86 CMOS non-volatile memory access.
2//
3// Copyright (C) 2008 Kevin O'Connor <kevin@koconnor.net>
4//
Kevin O'Connorb1b7c2a2009-01-15 20:52:58 -05005// This file may be distributed under the terms of the GNU LGPLv3 license.
Kevin O'Connorf076a3e2008-02-25 22:25:15 -05006#ifndef __CMOS_H
7#define __CMOS_H
8
Kevin O'Connorf076a3e2008-02-25 22:25:15 -05009#define CMOS_RTC_SECONDS 0x00
10#define CMOS_RTC_SECONDS_ALARM 0x01
11#define CMOS_RTC_MINUTES 0x02
12#define CMOS_RTC_MINUTES_ALARM 0x03
13#define CMOS_RTC_HOURS 0x04
14#define CMOS_RTC_HOURS_ALARM 0x05
Kevin O'Connor4b60c002008-02-25 22:29:55 -050015#define CMOS_RTC_DAY_WEEK 0x06
16#define CMOS_RTC_DAY_MONTH 0x07
17#define CMOS_RTC_MONTH 0x08
18#define CMOS_RTC_YEAR 0x09
19#define CMOS_STATUS_A 0x0a
Kevin O'Connorf076a3e2008-02-25 22:25:15 -050020#define CMOS_STATUS_B 0x0b
Kevin O'Connor4b60c002008-02-25 22:29:55 -050021#define CMOS_STATUS_C 0x0c
22#define CMOS_STATUS_D 0x0d
Kevin O'Connorf076a3e2008-02-25 22:25:15 -050023#define CMOS_RESET_CODE 0x0f
24#define CMOS_FLOPPY_DRIVE_TYPE 0x10
Kevin O'Connorbdce35f2008-02-26 21:33:14 -050025#define CMOS_DISK_DATA 0x12
Kevin O'Connorf076a3e2008-02-25 22:25:15 -050026#define CMOS_EQUIPMENT_INFO 0x14
Kevin O'Connorbdce35f2008-02-26 21:33:14 -050027#define CMOS_DISK_DRIVE1_TYPE 0x19
28#define CMOS_DISK_DRIVE2_TYPE 0x1a
29#define CMOS_DISK_DRIVE1_CYL 0x1b
30#define CMOS_DISK_DRIVE2_CYL 0x24
Kevin O'Connore09b9822008-03-06 19:16:37 -050031#define CMOS_MEM_EXTMEM_LOW 0x30
32#define CMOS_MEM_EXTMEM_HIGH 0x31
Kevin O'Connor4b60c002008-02-25 22:29:55 -050033#define CMOS_CENTURY 0x32
Kevin O'Connore09b9822008-03-06 19:16:37 -050034#define CMOS_MEM_EXTMEM2_LOW 0x34
35#define CMOS_MEM_EXTMEM2_HIGH 0x35
Kevin O'Connor38fcbfe2008-02-25 22:30:47 -050036#define CMOS_BIOS_BOOTFLAG1 0x38
Kevin O'Connor15aee2e2008-03-01 13:34:04 -050037#define CMOS_BIOS_DISKTRANSFLAG 0x39
Kevin O'Connor38fcbfe2008-02-25 22:30:47 -050038#define CMOS_BIOS_BOOTFLAG2 0x3d
Kevin O'Connor59c35f22008-10-25 23:05:42 -040039#define CMOS_MEM_HIGHMEM_LOW 0x5b
40#define CMOS_MEM_HIGHMEM_MID 0x5c
41#define CMOS_MEM_HIGHMEM_HIGH 0x5d
Kevin O'Connor31bfad62008-12-16 23:50:52 -050042#define CMOS_BIOS_SMP_COUNT 0x5f
Kevin O'Connorf076a3e2008-02-25 22:25:15 -050043
Kevin O'Connorf076a3e2008-02-25 22:25:15 -050044// CMOS_FLOPPY_DRIVE_TYPE bitdefs
45#define CFD_NO_DRIVE 0
46#define CFD_360KB 1
47#define CFD_12MB 2
48#define CFD_720KB 3
49#define CFD_144MB 4
50#define CFD_288MB 5
51
Kevin O'Connor18e38b22008-12-10 20:40:13 -050052#ifndef __ASSEMBLY__
53
54#include "ioport.h" // inb, outb
55
Kevin O'Connorf076a3e2008-02-25 22:25:15 -050056static inline u8
57inb_cmos(u8 reg)
58{
Kevin O'Connor75f49b32009-03-07 00:07:24 -050059 reg |= NMI_DISABLE_BIT;
Kevin O'Connorf076a3e2008-02-25 22:25:15 -050060 outb(reg, PORT_CMOS_INDEX);
61 return inb(PORT_CMOS_DATA);
62}
63
64static inline void
65outb_cmos(u8 val, u8 reg)
66{
Kevin O'Connor75f49b32009-03-07 00:07:24 -050067 reg |= NMI_DISABLE_BIT;
Kevin O'Connorf076a3e2008-02-25 22:25:15 -050068 outb(reg, PORT_CMOS_INDEX);
69 outb(val, PORT_CMOS_DATA);
70}
71
Kevin O'Connor18e38b22008-12-10 20:40:13 -050072#endif // !__ASSEMBLY__
73
Kevin O'Connorf076a3e2008-02-25 22:25:15 -050074#endif // cmos.h