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

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

1.1     ! nbrk        1: /*     $OpenBSD: cd1400reg.h,v 1.4 1998/05/20 19:29:23 deraadt Exp $   */
        !             2: /*     $NetBSD: cd1400reg.h,v 1.3 1996/09/24 18:02:33 christos Exp $   */
        !             3:
        !             4: /*-
        !             5:  * cyclades cyclom-y serial driver
        !             6:  *     Andrew Herbert <andrew@werple.apana.org.au>, 17 August 1993
        !             7:  *
        !             8:  * Copyright (c) 1993 Andrew Herbert.
        !             9:  * All rights reserved.
        !            10:  *
        !            11:  * Redistribution and use in source and binary forms, with or without
        !            12:  * modification, are permitted provided that the following conditions
        !            13:  * are met:
        !            14:  * 1. Redistributions of source code must retain the above copyright
        !            15:  *    notice, this list of conditions and the following disclaimer.
        !            16:  * 2. Redistributions in binary form must reproduce the above copyright
        !            17:  *    notice, this list of conditions and the following disclaimer in the
        !            18:  *    documentation and/or other materials provided with the distribution.
        !            19:  * 3. The name Andrew Herbert may not be used to endorse or promote products
        !            20:  *    derived from this software without specific prior written permission.
        !            21:  *
        !            22:  * THIS SOFTWARE IS PROVIDED BY ``AS IS'' AND ANY EXPRESS OR IMPLIED
        !            23:  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
        !            24:  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.  IN
        !            25:  * NO EVENT SHALL I BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
        !            26:  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
        !            27:  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
        !            28:  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
        !            29:  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
        !            30:  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
        !            31:  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
        !            32:  */
        !            33:
        !            34: /*
        !            35:  * Definitions for Cirrus Logic CD1400 serial/parallel chips.
        !            36:  */
        !            37:
        !            38: #define        CD1400_NO_OF_CHANNELS   4       /* 4 serial channels per chip */
        !            39: #define        CD1400_RX_FIFO_SIZE     12
        !            40: #define        CD1400_TX_FIFO_SIZE     12
        !            41: #define        CD1400_PAR_FIFO_SIZE    30
        !            42:
        !            43: /*
        !            44:  * Global registers.
        !            45:  */
        !            46: #define        CD1400_GFRCR            0x40    /* global firmware revision code */
        !            47: #define        CD1400_CAR              0x68    /* channel access */
        !            48: #define        CD1400_CAR_CHAN                 (3<<0)  /* channel select */
        !            49: #define        CD1400_GCR              0x4B    /* global configuration */
        !            50: #define        CD1400_GCR_PARALLEL             (1<<7)  /* channel 0 is parallel */
        !            51: #define        CD1400_SVRR             0x67    /* service request */
        !            52: #define        CD1400_SVRR_MDMCH               (1<<2)
        !            53: #define        CD1400_SVRR_TXRDY               (1<<1)
        !            54: #define        CD1400_SVRR_RXRDY               (1<<0)
        !            55: #define        CD1400_RICR             0x44    /* receive interrupting channel */
        !            56: #define        CD1400_TICR             0x45    /* transmit interrupting channel */
        !            57: #define        CD1400_MICR             0x46    /* modem interrupting channel */
        !            58: #define        CD1400_RIR              0x6B    /* receive interrupt status */
        !            59: #define        CD1400_RIR_RDIREQ               (1<<7)  /* rx service required */
        !            60: #define        CD1400_RIR_RBUSY                (1<<6)  /* rx service in progress */
        !            61: #define        CD1400_RIR_CHAN                 (3<<0)  /* channel select */
        !            62: #define        CD1400_TIR              0x6A    /* transmit interrupt status */
        !            63: #define        CD1400_TIR_RDIREQ               (1<<7)  /* tx service required */
        !            64: #define        CD1400_TIR_RBUSY                (1<<6)  /* tx service in progress */
        !            65: #define        CD1400_TIR_CHAN                 (3<<0)  /* channel select */
        !            66: #define        CD1400_MIR              0x69    /* modem interrupt status */
        !            67: #define        CD1400_MIR_RDIREQ               (1<<7)  /* modem service required */
        !            68: #define        CD1400_MIR_RBUSY                (1<<6)  /* modem service in progress */
        !            69: #define        CD1400_MIR_CHAN                 (3<<0)  /* channel select */
        !            70: #define        CD1400_PPR              0x7E    /* prescaler period */
        !            71: #define        CD1400_PPR_PRESCALER            512
        !            72:
        !            73: /*
        !            74:  * Virtual registers.
        !            75:  */
        !            76: #define        CD1400_RIVR             0x43    /* receive interrupt vector */
        !            77: #define        CD1400_RIVR_EXCEPTION           (1<<2)  /* receive exception bit */
        !            78: #define        CD1400_TIVR             0x42    /* transmit interrupt vector */
        !            79: #define        CD1400_MIVR             0x41    /* modem interrupt vector */
        !            80: #define        CD1400_TDR              0x63    /* transmit data */
        !            81: #define        CD1400_RDSR             0x62    /* receive data/status */
        !            82: #define        CD1400_RDSR_TIMEOUT             (1<<7)  /* rx timeout */
        !            83: #define        CD1400_RDSR_SPECIAL_SHIFT       4       /* rx special char shift */
        !            84: #define        CD1400_RDSR_SPECIAL             (7<<4)  /* rx special char */
        !            85: #define        CD1400_RDSR_BREAK               (1<<3)  /* rx break */
        !            86: #define        CD1400_RDSR_PE                  (1<<2)  /* rx parity error */
        !            87: #define        CD1400_RDSR_FE                  (1<<1)  /* rx framing error */
        !            88: #define        CD1400_RDSR_OE                  (1<<0)  /* rx overrun error */
        !            89: #define        CD1400_MISR             0x4C    /* modem interrupt status */
        !            90: #define        CD1400_MISR_DSRd                (1<<7)  /* DSR delta */
        !            91: #define        CD1400_MISR_CTSd                (1<<6)  /* CTS delta */
        !            92: #define        CD1400_MISR_RId                 (1<<5)  /* RI delta */
        !            93: #define        CD1400_MISR_CDd                 (1<<4)  /* CD delta */
        !            94: #define        CD1400_EOSRR            0x60    /* end of service request */
        !            95:
        !            96: /*
        !            97:  * Channel registers.
        !            98:  */
        !            99: #define        CD1400_LIVR             0x18    /* local interrupt vector */
        !           100: #define        CD1400_CCR              0x05    /* channel control */
        !           101: #define        CD1400_CCR_CMDRESET             (1<<7)  /* enables following: */
        !           102: #define        CD1400_CCR_FTF                          (1<<1)  /* flush tx fifo */
        !           103: #define        CD1400_CCR_FULLRESET                    (1<<0)  /* full reset */
        !           104: #define        CD1400_CCR_CMDCORCHG            (1<<6)  /* enables following: */
        !           105: #define        CD1400_CCR_COR3                         (1<<3)  /* COR3 changed */
        !           106: #define        CD1400_CCR_COR2                         (1<<2)  /* COR2 changed */
        !           107: #define        CD1400_CCR_COR1                         (1<<1)  /* COR1 changed */
        !           108: #define        CD1400_CCR_CMDSENDSC            (1<<5)  /* enables following: */
        !           109: #define        CD1400_CCR_SC                           (7<<0)  /* special char 1-4 */
        !           110: #define        CD1400_CCR_CMDCHANCTL           (1<<4)  /* enables following: */
        !           111: #define        CD1400_CCR_XMTEN                        (1<<3)  /* tx enable */
        !           112: #define        CD1400_CCR_XMTDIS                       (1<<2)  /* tx disable */
        !           113: #define        CD1400_CCR_RCVEN                        (1<<1)  /* rx enable */
        !           114: #define        CD1400_CCR_RCVDIS                       (1<<0)  /* rx disable */
        !           115: #define        CD1400_SRER             0x06    /* service request enable */
        !           116: #define        CD1400_SRER_MDMCH               (1<<7)  /* modem change */
        !           117: #define        CD1400_SRER_RXDATA              (1<<4)  /* rx data */
        !           118: #define        CD1400_SRER_TXRDY               (1<<2)  /* tx fifo empty */
        !           119: #define        CD1400_SRER_TXMPTY              (1<<1)  /* tx shift reg empty */
        !           120: #define        CD1400_SRER_NNDT                (1<<0)  /* no new data */
        !           121: #define        CD1400_COR1             0x08    /* channel option 1 */
        !           122: #define        CD1400_COR1_PARODD              (1<<7)
        !           123: #define        CD1400_COR1_PARNORMAL           (2<<5)
        !           124: #define        CD1400_COR1_PARFORCE            (1<<5)  /* odd/even = force 1/0 */
        !           125: #define        CD1400_COR1_PARNONE             (0<<5)
        !           126: #define        CD1400_COR1_NOINPCK             (1<<4)
        !           127: #define        CD1400_COR1_STOP2               (2<<2)
        !           128: #define        CD1400_COR1_STOP15              (1<<2)  /* 1.5 stop bits */
        !           129: #define        CD1400_COR1_STOP1               (0<<2)
        !           130: #define        CD1400_COR1_CS8                 (3<<0)
        !           131: #define        CD1400_COR1_CS7                 (2<<0)
        !           132: #define        CD1400_COR1_CS6                 (1<<0)
        !           133: #define        CD1400_COR1_CS5                 (0<<0)
        !           134: #define        CD1400_COR2             0x09    /* channel option 2 */
        !           135: #define        CD1400_COR2_IXANY               (1<<7)  /* implied XON mode */
        !           136: #define        CD1400_COR2_IXOFF               (1<<6)  /* in-band tx flow control */
        !           137: #define        CD1400_COR2_ETC                 (1<<5)  /* embedded tx command */
        !           138: #define        CD1400_COR2_LLM                 (1<<4)  /* local loopback mode */
        !           139: #define        CD1400_COR2_RLM                 (1<<3)  /* remote loopback mode */
        !           140: #define        CD1400_COR2_RTSAO               (1<<2)  /* RTS auto output */
        !           141: #define        CD1400_COR2_CCTS_OFLOW          (1<<1)  /* CTS auto enable */
        !           142: #define        CD1400_COR2_CDSR_OFLOW          (1<<0)  /* DSR auto enable */
        !           143: #define        CD1400_COR3             0x0A    /* channel option 3 */
        !           144: #define        CD1400_COR3_SCDRNG              (1<<7)  /* special char detect range */
        !           145: #define        CD1400_COR3_SCD34               (1<<6)  /* special char detect 3-4 */
        !           146: #define        CD1400_COR3_FTC                 (1<<5)  /* flow control transparency */
        !           147: #define        CD1400_COR3_SCD12               (1<<4)  /* special char detect 1-2 */
        !           148: #define        CD1400_COR3_RXTH                (15<<0) /* rx fifo threshold */
        !           149: #define        CD1400_COR4             0x1E    /* channel option 4 */
        !           150: #define        CD1400_COR4_IGNCR               (1<<7)
        !           151: #define        CD1400_COR4_ICRNL               (1<<6)
        !           152: #define        CD1400_COR4_INLCR               (1<<5)
        !           153: #define        CD1400_COR4_IGNBRK              (1<<4)
        !           154: #define        CD1400_COR4_NOBRKINT            (1<<3)
        !           155: #define        CD1400_COR4_PFO_ESC             (4<<0)  /* parity/framing/overrun... */
        !           156: #define        CD1400_COR4_PFO_NUL             (3<<0)
        !           157: #define        CD1400_COR4_PFO_DISCARD         (2<<0)
        !           158: #define        CD1400_COR4_PFO_GOOD            (1<<0)
        !           159: #define        CD1400_COR4_PFO_EXCEPTION       (0<<0)
        !           160: #define        CD1400_COR5             0x1F    /* channel option 5 */
        !           161: #define        CD1400_COR5_ISTRIP              (1<<7)
        !           162: #define        CD1400_COR5_LNEXT               (1<<6)
        !           163: #define        CD1400_COR5_CMOE                (1<<5)  /* char matching on error */
        !           164: #define        CD1400_COR5_EBD                 (1<<2)  /* end of break detected */
        !           165: #define        CD1400_COR5_ONLCR               (1<<1)
        !           166: #define        CD1400_COR5_OCRNL               (1<<0)
        !           167: #define        CD1400_CCSR             0x0B    /* channel control status */
        !           168: #define        CD1400_RDCR             0x0E    /* received data count */
        !           169: #define        CD1400_SCHR1            0x1A    /* special character 1 */
        !           170: #define        CD1400_SCHR2            0x1B    /* special character 2 */
        !           171: #define        CD1400_SCHR3            0x1C    /* special character 3 */
        !           172: #define        CD1400_SCHR4            0x1D    /* special character 4 */
        !           173: #define        CD1400_SCRL             0x22    /* special character range, low */
        !           174: #define        CD1400_SCRH             0x23    /* special character range, high */
        !           175: #define        CD1400_LNC              0x24    /* lnext character */
        !           176: #define        CD1400_MCOR1            0x15    /* modem change option 1 */
        !           177: #define        CD1400_MCOR1_DSRzd              (1<<7)  /* DSR one-to-zero delta */
        !           178: #define        CD1400_MCOR1_CTSzd              (1<<6)
        !           179: #define        CD1400_MCOR1_RIzd               (1<<5)
        !           180: #define        CD1400_MCOR1_CDzd               (1<<4)
        !           181: #define        CD1400_MCOR1_DTRth              (15<<0) /* dtrflow threshold */
        !           182: #define        CD1400_MCOR2            0x16    /* modem change option 2 */
        !           183: #define        CD1400_MCOR2_DSRod              (1<<7)  /* DSR zero-to-one delta */
        !           184: #define        CD1400_MCOR2_CTSod              (1<<6)
        !           185: #define        CD1400_MCOR2_RIod               (1<<5)
        !           186: #define        CD1400_MCOR2_CDod               (1<<4)
        !           187: #define        CD1400_RTPR             0x21    /* receive timeout period */
        !           188: #define        CD1400_MSVR1            0x6C    /* modem signal value 1 */
        !           189: #define        CD1400_MSVR1_RTS                (1<<0)  /* RTS line (r/w) */
        !           190: #define        CD1400_MSVR2            0x6D    /* modem signal value 2 */
        !           191: #define        CD1400_MSVR2_DSR                (1<<7)  /* !DSR line (r) */
        !           192: #define        CD1400_MSVR2_CTS                (1<<6)  /* !CTS line (r) */
        !           193: #define        CD1400_MSVR2_RI                 (1<<5)  /* !RI line (r) */
        !           194: #define        CD1400_MSVR2_CD                 (1<<4)  /* !CD line (r) */
        !           195: #define        CD1400_MSVR2_DTR                (1<<1)  /* DTR line (r/w) */
        !           196: #define        CD1400_PSVR             0x6F    /* printer signal value */
        !           197: #define        CD1400_RBPR             0x78    /* receive baud rate period */
        !           198: #define        CD1400_RCOR             0x7C    /* receive clock option */
        !           199: #define        CD1400_TBPR             0x72    /* transmit baud rate period */
        !           200: #define        CD1400_TCOR             0x76    /* transmit clock option */

CVSweb