[BACK]Return to dp857xreg.h CVS log [TXT][DIR] Up to [local] / sys / dev / ic

Annotation of sys/dev/ic/dp857xreg.h, Revision 1.1

1.1     ! nbrk        1: /*     $OpenBSD: dp857xreg.h,v 1.3 2003/06/09 16:34:22 deraadt Exp $ */
        !             2:
        !             3: /*
        !             4:  * Copyright (c) 1996 Per Fogelstrom
        !             5:  *
        !             6:  * Redistribution and use in source and binary forms, with or without
        !             7:  * modification, are permitted provided that the following conditions
        !             8:  * are met:
        !             9:  * 1. Redistributions of source code must retain the above copyright
        !            10:  *    notice, this list of conditions and the following disclaimer.
        !            11:  * 2. Redistributions in binary form must reproduce the above copyright
        !            12:  *    notice, this list of conditions and the following disclaimer in the
        !            13:  *    documentation and/or other materials provided with the distribution.
        !            14:  *
        !            15:  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
        !            16:  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
        !            17:  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
        !            18:  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
        !            19:  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
        !            20:  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
        !            21:  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
        !            22:  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
        !            23:  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
        !            24:  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
        !            25:  * SUCH DAMAGE.
        !            26:  *
        !            27:  */
        !            28:
        !            29: #if !defined(_DP857X_H)
        !            30: #define        _DP857X_H
        !            31:
        !            32: /*
        !            33:  *     Definition of Real Time Clock address space.
        !            34:  *
        !            35:  *     Clock is a National DP8570A RTC
        !            36:  */
        !            37: #define BSIZE           1       /* No of Bytes for Address Spacing */
        !            38: #define        MAIN_STATUS     0x00    /* Main status register         */
        !            39: /*
        !            40:  *  Registers selected with BS=0 RS=0
        !            41:  */
        !            42: #define        TIMER0_CTRL     0x01    /* Timer 0 control register     */
        !            43: #define        TIMER1_CTRL     0x02    /* Timer 0 control register     */
        !            44: #define        PERIODIC_FLAGS  0x03    /* Timer periodic flag register */
        !            45: #define        INTERRUPT_ROUT  0x04    /* Interrupt routing register   */
        !            46: /*
        !            47:  *  Registers selected with BS=0 RS=1
        !            48:  */
        !            49: #define        REAL_TIME_MODE  0x01    /* Real Time Mode register      */
        !            50: #define        OUTPUT_MODE     0x02    /* Output mode register         */
        !            51: #define        INTERRUPT_CTRL0 0x03    /* Interrupt control register 0 */
        !            52: #define        INTERRUPT_CTRL1 0x04    /* Interrupt control register 1 */
        !            53: /*
        !            54:  *  Clock and timer registers when BS=0
        !            55:  */
        !            56: #define        CLK_SUBSECONDS  0x05    /* 1/100 seconds reister        */
        !            57: #define        CLK_SECONDS     0x06    /* Seconds                      */
        !            58: #define        CLK_MINUTES     0x07    /* Minutes                      */
        !            59: #define        CLK_HOURS       0x08    /* Hours                        */
        !            60: #define        CLK_DAY         0x09    /* Day of month                 */
        !            61: #define        CLK_MONTH       0x0a    /* Month                        */
        !            62: #define        CLK_YEAR        0x0b    /* Year                         */
        !            63: #define        CLK_JULIAN_L    0x0c    /* Lsb of Julian date           */
        !            64: #define        CLK_JULIAN_H    0x0d    /* Msb of Julian date           */
        !            65: #define        CLK_WEEKDAY     0x0e    /* Day of week                  */
        !            66: #define        TIMER0_LSB      0x0f    /* Timer 0 lsb                  */
        !            67: #define        TIMER0_MSB      0x10    /* Timer 0 msb                  */
        !            68: #define        TIMER1_LSB      0x11    /* Timer 1 lsb                  */
        !            69: #define        TIMER1_MSB      0x12    /* Timer 1 msb                  */
        !            70: #define        CMP_SECONDS     0x13    /* Seconds compare              */
        !            71: #define        CMP_MINUTES     0x14    /* Minutes compare              */
        !            72: #define        CMP_HOUR        0x15    /* Hours compare                */
        !            73: #define        CMP_DAY         0x16    /* Day of month compare         */
        !            74: #define        CMP_MONTH       0x17    /* Month compare                */
        !            75: #define        CMP_WEEKDAY     0x18    /* Day of week compare          */
        !            76: #define        SAVE_SECONDS    0x19    /* Seconds time save            */
        !            77: #define        SAVE_MINUTES    0x1a    /* Minutes time save            */
        !            78: #define        SAVE_HOUR       0x1b    /* Hours time save              */
        !            79: #define        SAVE_DAY        0x1c    /* Day of month time save       */
        !            80: #define        SAVE_MONTH      0x1d    /* Month time save              */
        !            81: #define        RAM_1E          0x1e    /* Ram location 1e              */
        !            82: #define        RAM_1F          0x1f    /* Ram location 1f              */
        !            83: #define        SIZE_DP857X     0x20    /* Size of dp address map       */
        !            84:
        !            85: #define        DP_FIRSTTODREG  CLK_SUBSECONDS
        !            86: #define        DP_LASTTODREG   CLK_WEEKDAY
        !            87:
        !            88: typedef u_int dp_todregs[SIZE_DP857X];
        !            89: u_int dp857x_read(void *sc, u_int reg);
        !            90: void dp857x_write(void *sc, u_int reg, u_int datum);
        !            91:
        !            92: /*
        !            93:  * Get all of the TOD/Alarm registers
        !            94:  * Must be called at splhigh(), and with the RTC properly set up.
        !            95:  */
        !            96: #define DP857X_GETTOD(sc, regs)                                        \
        !            97:        do {                                                            \
        !            98:                int i;                                                  \
        !            99:                                                                        \
        !           100:                /* make sure clock regs are selected */                 \
        !           101:                dp857x_write(sc, MAIN_STATUS, 0);                       \
        !           102:                /* try read until no rollover */                        \
        !           103:                do {                                                    \
        !           104:                        /* read all of the tod/alarm regs */            \
        !           105:                        for (i = DP_FIRSTTODREG; i < SIZE_DP857X; i++)  \
        !           106:                                (*regs)[i] = dp857x_read(sc, i);        \
        !           107:                } while(dp857x_read(sc, PERIODIC_FLAGS) & 7);           \
        !           108:        } while (0);
        !           109:
        !           110: /*
        !           111:  * Set all of the TOD/Alarm registers
        !           112:  * Must be called at splhigh(), and with the RTC properly set up.
        !           113:  */
        !           114: #define DP857X_PUTTOD(sc, regs)                                        \
        !           115:        do {                                                            \
        !           116:                int i;                                                  \
        !           117:                                                                        \
        !           118:                /* stop updates while setting, eg clear start bit */    \
        !           119:                dp857x_write(sc, MAIN_STATUS, 0x40);                    \
        !           120:                dp857x_write(sc, REAL_TIME_MODE,                        \
        !           121:                    dp857x_read(sc, REAL_TIME_MODE) & 0xF7);            \
        !           122:                                                                        \
        !           123:                /* write all of the tod/alarm regs */                   \
        !           124:                for (i = DP_FIRSTTODREG; i <= DP_LASTTODREG; i++)       \
        !           125:                        dp857x_write(sc, i, (*regs)[i]);                \
        !           126:                                                                        \
        !           127:                /* reenable updates, eg set clock start bit */          \
        !           128:                dp857x_write(sc, REAL_TIME_MODE,                        \
        !           129:                    dp857x_read(sc, REAL_TIME_MODE) | 0x08);            \
        !           130:        } while (0);
        !           131:
        !           132: #endif /*_DP857X_H*/
        !           133:

CVSweb