15b81b6b3SRodney W. Grimes /*- 251369649SPedro F. Giffuni * SPDX-License-Identifier: BSD-3-Clause 351369649SPedro F. Giffuni * 45b81b6b3SRodney W. Grimes * Copyright (c) 1990 The Regents of the University of California. 55b81b6b3SRodney W. Grimes * All rights reserved. 65b81b6b3SRodney W. Grimes * 75b81b6b3SRodney W. Grimes * This code is derived from software contributed to Berkeley by 85b81b6b3SRodney W. Grimes * William Jolitz. 95b81b6b3SRodney W. Grimes * 105b81b6b3SRodney W. Grimes * Redistribution and use in source and binary forms, with or without 115b81b6b3SRodney W. Grimes * modification, are permitted provided that the following conditions 125b81b6b3SRodney W. Grimes * are met: 135b81b6b3SRodney W. Grimes * 1. Redistributions of source code must retain the above copyright 145b81b6b3SRodney W. Grimes * notice, this list of conditions and the following disclaimer. 155b81b6b3SRodney W. Grimes * 2. Redistributions in binary form must reproduce the above copyright 165b81b6b3SRodney W. Grimes * notice, this list of conditions and the following disclaimer in the 175b81b6b3SRodney W. Grimes * documentation and/or other materials provided with the distribution. 18fbbd9655SWarner Losh * 3. Neither the name of the University nor the names of its contributors 195b81b6b3SRodney W. Grimes * may be used to endorse or promote products derived from this software 205b81b6b3SRodney W. Grimes * without specific prior written permission. 215b81b6b3SRodney W. Grimes * 225b81b6b3SRodney W. Grimes * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 235b81b6b3SRodney W. Grimes * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 245b81b6b3SRodney W. Grimes * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 255b81b6b3SRodney W. Grimes * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 265b81b6b3SRodney W. Grimes * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 275b81b6b3SRodney W. Grimes * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 285b81b6b3SRodney W. Grimes * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 295b81b6b3SRodney W. Grimes * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 305b81b6b3SRodney W. Grimes * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 315b81b6b3SRodney W. Grimes * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 325b81b6b3SRodney W. Grimes * SUCH DAMAGE. 335b81b6b3SRodney W. Grimes */ 345b81b6b3SRodney W. Grimes 3513c0dce6SGarrett Wollman #ifndef _I386_ISA_RTC_H_ 3613c0dce6SGarrett Wollman #define _I386_ISA_RTC_H_ 1 3713c0dce6SGarrett Wollman 385b81b6b3SRodney W. Grimes /* 393bc7e565SPoul-Henning Kamp * MC146818 RTC Register locations 405b81b6b3SRodney W. Grimes */ 415b81b6b3SRodney W. Grimes 425b81b6b3SRodney W. Grimes #define RTC_SEC 0x00 /* seconds */ 435b81b6b3SRodney W. Grimes #define RTC_SECALRM 0x01 /* seconds alarm */ 445b81b6b3SRodney W. Grimes #define RTC_MIN 0x02 /* minutes */ 455b81b6b3SRodney W. Grimes #define RTC_MINALRM 0x03 /* minutes alarm */ 465b81b6b3SRodney W. Grimes #define RTC_HRS 0x04 /* hours */ 475b81b6b3SRodney W. Grimes #define RTC_HRSALRM 0x05 /* hours alarm */ 485b81b6b3SRodney W. Grimes #define RTC_WDAY 0x06 /* week day */ 495b81b6b3SRodney W. Grimes #define RTC_DAY 0x07 /* day of month */ 505b81b6b3SRodney W. Grimes #define RTC_MONTH 0x08 /* month of year */ 515b81b6b3SRodney W. Grimes #define RTC_YEAR 0x09 /* month of year */ 528ea83850SGarrett Wollman 535b81b6b3SRodney W. Grimes #define RTC_STATUSA 0x0a /* status register A */ 545b81b6b3SRodney W. Grimes #define RTCSA_TUP 0x80 /* time update, don't look now */ 553bc7e565SPoul-Henning Kamp #define RTCSA_RESET 0x70 /* reset divider */ 568ea83850SGarrett Wollman #define RTCSA_DIVIDER 0x20 /* divider correct for 32768 Hz */ 573bc7e565SPoul-Henning Kamp #define RTCSA_8192 0x03 /* 8192 Hz interrupt */ 588ea83850SGarrett Wollman #define RTCSA_4096 0x04 598ea83850SGarrett Wollman #define RTCSA_2048 0x05 608ea83850SGarrett Wollman #define RTCSA_1024 0x06 /* default for profiling */ 618ea83850SGarrett Wollman #define RTCSA_PROF RTCSA_1024 628ea83850SGarrett Wollman #define RTC_PROFRATE 1024 638ea83850SGarrett Wollman #define RTCSA_512 0x07 648ea83850SGarrett Wollman #define RTCSA_256 0x08 658ea83850SGarrett Wollman #define RTCSA_128 0x09 668ea83850SGarrett Wollman #define RTCSA_NOPROF RTCSA_128 678ea83850SGarrett Wollman #define RTC_NOPROFRATE 128 688ea83850SGarrett Wollman #define RTCSA_64 0x0a 693bc7e565SPoul-Henning Kamp #define RTCSA_32 0x0b /* 32 Hz interrupt */ 705b81b6b3SRodney W. Grimes 715b81b6b3SRodney W. Grimes #define RTC_STATUSB 0x0b /* status register B */ 723bc7e565SPoul-Henning Kamp #define RTCSB_DST 0x01 /* USA Daylight Savings Time enable */ 737b915aa6SAndrey A. Chernov #define RTCSB_24HR 0x02 /* 0 = 12 hours, 1 = 24 hours */ 747b915aa6SAndrey A. Chernov #define RTCSB_BCD 0x04 /* 0 = BCD, 1 = Binary coded time */ 757b915aa6SAndrey A. Chernov #define RTCSB_SQWE 0x08 /* 1 = output sqare wave at SQW pin */ 767b915aa6SAndrey A. Chernov #define RTCSB_UINTR 0x10 /* 1 = enable update-ended interrupt */ 777b915aa6SAndrey A. Chernov #define RTCSB_AINTR 0x20 /* 1 = enable alarm interrupt */ 787b915aa6SAndrey A. Chernov #define RTCSB_PINTR 0x40 /* 1 = enable periodic clock interrupt */ 798ea83850SGarrett Wollman #define RTCSB_HALT 0x80 /* stop clock updates */ 805b81b6b3SRodney W. Grimes 815b81b6b3SRodney W. Grimes #define RTC_INTR 0x0c /* status register C (R) interrupt source */ 825b81b6b3SRodney W. Grimes #define RTCIR_UPDATE 0x10 /* update intr */ 835b81b6b3SRodney W. Grimes #define RTCIR_ALARM 0x20 /* alarm intr */ 845b81b6b3SRodney W. Grimes #define RTCIR_PERIOD 0x40 /* periodic intr */ 855b81b6b3SRodney W. Grimes #define RTCIR_INT 0x80 /* interrupt output signal */ 865b81b6b3SRodney W. Grimes 875b81b6b3SRodney W. Grimes #define RTC_STATUSD 0x0d /* status register D (R) Lost Power */ 883bc7e565SPoul-Henning Kamp #define RTCSD_PWR 0x80 /* clock power OK */ 895b81b6b3SRodney W. Grimes 905b81b6b3SRodney W. Grimes #define RTC_DIAG 0x0e /* status register E - bios diagnostic */ 915b81b6b3SRodney W. Grimes #define RTCDG_BITS "\020\010clock_battery\007ROM_cksum\006config_unit\005memory_size\004fixed_disk\003invalid_time" 925b81b6b3SRodney W. Grimes 935b81b6b3SRodney W. Grimes #define RTC_RESET 0x0f /* status register F - reset code byte */ 945b81b6b3SRodney W. Grimes #define RTCRS_RST 0x00 /* normal reset */ 955b81b6b3SRodney W. Grimes #define RTCRS_LOAD 0x04 /* load system */ 965b81b6b3SRodney W. Grimes 975b81b6b3SRodney W. Grimes #define RTC_FDISKETTE 0x10 /* diskette drive type in upper/lower nibble */ 985b81b6b3SRodney W. Grimes #define RTCFDT_NONE 0 /* none present */ 995b81b6b3SRodney W. Grimes #define RTCFDT_360K 0x10 /* 360K */ 1005b81b6b3SRodney W. Grimes #define RTCFDT_12M 0x20 /* 1.2M */ 101159569a4SAndrey A. Chernov #define RTCFDT_720K 0x30 /* 720K */ 1025b81b6b3SRodney W. Grimes #define RTCFDT_144M 0x40 /* 1.44M */ 10386a727d9SJoerg Wunsch #define RTCFDT_288M_1 0x50 /* 2.88M, some BIOSes */ 104290dd077SJoerg Wunsch #define RTCFDT_288M 0x60 /* 2.88M */ 1055b81b6b3SRodney W. Grimes 1065b81b6b3SRodney W. Grimes #define RTC_BASELO 0x15 /* low byte of basemem size */ 1075b81b6b3SRodney W. Grimes #define RTC_BASEHI 0x16 /* high byte of basemem size */ 1085b81b6b3SRodney W. Grimes #define RTC_EXTLO 0x17 /* low byte of extended mem size */ 1095b81b6b3SRodney W. Grimes #define RTC_EXTHI 0x18 /* low byte of extended mem size */ 1105b81b6b3SRodney W. Grimes 1117b915aa6SAndrey A. Chernov #define RTC_CENTURY 0x32 /* current century */ 1127e82012aSPoul-Henning Kamp 1137e82012aSPoul-Henning Kamp #ifdef _KERNEL 114*c7053bbeSIan Lepore extern struct mtx atrtc_time_lock; 1151703f2b4SAlexander Motin extern int atrtcclock_disable; 1167e82012aSPoul-Henning Kamp int rtcin(int reg); 1177e82012aSPoul-Henning Kamp void atrtc_restore(void); 1187e82012aSPoul-Henning Kamp void writertc(int reg, u_char val); 1197e82012aSPoul-Henning Kamp #endif 1207e82012aSPoul-Henning Kamp 12113c0dce6SGarrett Wollman #endif /* _I386_ISA_RTC_H_ */ 122