Home | History | Annotate | Line # | Download | only in common
dca.c revision 1.4
      1 /*	$NetBSD: dca.c,v 1.4 2003/11/14 16:52:40 tsutsui Exp $	*/
      2 
      3 /*
      4  * Copyright (c) 1990, 1993
      5  *	The Regents of the University of California.  All rights reserved.
      6  *
      7  * This code is derived from software contributed to Berkeley by
      8  * the Systems Programming Group of the University of Utah Computer
      9  * Science Department.
     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. Neither the name of the University nor the names of its contributors
     20  *    may be used to endorse or promote products derived from this software
     21  *    without specific prior written permission.
     22  *
     23  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     24  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     25  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     26  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     27  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     28  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     29  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     30  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     31  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     32  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     33  * SUCH DAMAGE.
     34  *
     35  *	@(#)dca.c	8.1 (Berkeley) 6/10/93
     36  */
     37 /*
     38  * Copyright (c) 1988 University of Utah.
     39  *
     40  * This code is derived from software contributed to Berkeley by
     41  * the Systems Programming Group of the University of Utah Computer
     42  * Science Department.
     43  *
     44  * Redistribution and use in source and binary forms, with or without
     45  * modification, are permitted provided that the following conditions
     46  * are met:
     47  * 1. Redistributions of source code must retain the above copyright
     48  *    notice, this list of conditions and the following disclaimer.
     49  * 2. Redistributions in binary form must reproduce the above copyright
     50  *    notice, this list of conditions and the following disclaimer in the
     51  *    documentation and/or other materials provided with the distribution.
     52  * 3. All advertising materials mentioning features or use of this software
     53  *    must display the following acknowledgement:
     54  *	This product includes software developed by the University of
     55  *	California, Berkeley and its contributors.
     56  * 4. Neither the name of the University nor the names of its contributors
     57  *    may be used to endorse or promote products derived from this software
     58  *    without specific prior written permission.
     59  *
     60  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     61  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     62  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     63  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     64  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     65  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     66  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     67  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     68  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     69  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     70  * SUCH DAMAGE.
     71  *
     72  *	@(#)dca.c	8.1 (Berkeley) 6/10/93
     73  */
     74 
     75 #ifdef DCACONSOLE
     76 #include <sys/param.h>
     77 #include <dev/cons.h>
     78 
     79 #include <hp300/stand/common/dcareg.h>
     80 #include <hp300/stand/common/consdefs.h>
     81 #include <hp300/stand/common/samachdep.h>
     82 
     83 /* If not using 4.4 devs */
     84 #ifndef dca_reset
     85 #define dca_id dca_irid
     86 #define dca_reset dca_id
     87 #endif
     88 
     89 struct dcadevice *dcacnaddr = 0;
     90 
     91 #define DCACONSCODE	9	/* XXX */
     92 
     93 void
     94 dcaprobe(cp)
     95 	struct consdev *cp;
     96 {
     97 	struct dcadevice *dca;
     98 
     99 	dcacnaddr = (struct dcadevice *) sctoaddr(DCACONSCODE);
    100 	if (badaddr((char *)dcacnaddr)) {
    101 		cp->cn_pri = CN_DEAD;
    102 		return;
    103 	}
    104 #ifdef FORCEDCACONSOLE
    105 	cp->cn_pri = CN_REMOTE;
    106 #else
    107 	dca = dcacnaddr;
    108 	switch (dca->dca_id) {
    109 	case DCAID0:
    110 	case DCAID1:
    111 		cp->cn_pri = CN_NORMAL;
    112 		break;
    113 	case DCAREMID0:
    114 	case DCAREMID1:
    115 		cp->cn_pri = CN_REMOTE;
    116 		break;
    117 	default:
    118 		cp->cn_pri = CN_DEAD;
    119 		break;
    120 	}
    121 
    122 #endif
    123 	curcons_scode = DCACONSCODE;
    124 }
    125 
    126 void
    127 dcainit(cp)
    128 	struct consdev *cp;
    129 {
    130 	struct dcadevice *dca = dcacnaddr;
    131 
    132 	dca->dca_reset = 0xFF;
    133 	DELAY(100);
    134 	dca->dca_ic = 0;
    135 	dca->dca_cfcr = CFCR_DLAB;
    136 	dca->dca_data = DCABRD(9600) & 0xFF;
    137 	dca->dca_ier = DCABRD(9600) >> 8;
    138 	dca->dca_cfcr = CFCR_8BITS;
    139 	dca->dca_fifo =
    140 	    FIFO_ENABLE | FIFO_RCV_RST | FIFO_XMT_RST | FIFO_TRIGGER_1;
    141 	dca->dca_mcr = MCR_DTR | MCR_RTS;
    142 }
    143 
    144 /* ARGSUSED */
    145 #ifndef SMALL
    146 int
    147 dcagetchar(dev)
    148 	dev_t dev;
    149 {
    150 	struct dcadevice *dca = dcacnaddr;
    151 	short stat;
    152 	int c;
    153 
    154 	if (((stat = dca->dca_lsr) & LSR_RXRDY) == 0)
    155 		return 0;
    156 	c = dca->dca_data;
    157 	return c;
    158 }
    159 #else
    160 int
    161 dcagetchar(dev)
    162 	dev_t dev;
    163 {
    164 
    165 	return 0;
    166 }
    167 #endif
    168 
    169 /* ARGSUSED */
    170 void
    171 dcaputchar(dev, c)
    172 	dev_t dev;
    173 	int c;
    174 {
    175 	struct dcadevice *dca = dcacnaddr;
    176 	int timo;
    177 	short stat;
    178 
    179 	/* wait a reasonable time for the transmitter to come ready */
    180 	timo = 50000;
    181 	while (((stat = dca->dca_lsr) & LSR_TXRDY) == 0 && --timo)
    182 		;
    183 	dca->dca_data = c;
    184 	/* wait for this transmission to complete */
    185 	timo = 1000000;
    186 	while (((stat = dca->dca_lsr) & LSR_TXRDY) == 0 && --timo)
    187 		;
    188 }
    189 #endif
    190