Home | History | Annotate | Line # | Download | only in common
dcm.c revision 1.2.56.1
      1  1.2.56.1    skrll /*	$NetBSD: dcm.c,v 1.2.56.1 2004/08/03 10:34:37 skrll Exp $	*/
      2       1.1  thorpej 
      3       1.1  thorpej /*
      4       1.1  thorpej  * Copyright (c) 1990, 1993
      5       1.1  thorpej  *	The Regents of the University of California.  All rights reserved.
      6       1.1  thorpej  *
      7       1.1  thorpej  * This code is derived from software contributed to Berkeley by
      8       1.1  thorpej  * the Systems Programming Group of the University of Utah Computer
      9       1.1  thorpej  * Science Department.
     10       1.1  thorpej  *
     11       1.1  thorpej  * Redistribution and use in source and binary forms, with or without
     12       1.1  thorpej  * modification, are permitted provided that the following conditions
     13       1.1  thorpej  * are met:
     14       1.1  thorpej  * 1. Redistributions of source code must retain the above copyright
     15       1.1  thorpej  *    notice, this list of conditions and the following disclaimer.
     16       1.1  thorpej  * 2. Redistributions in binary form must reproduce the above copyright
     17       1.1  thorpej  *    notice, this list of conditions and the following disclaimer in the
     18       1.1  thorpej  *    documentation and/or other materials provided with the distribution.
     19  1.2.56.1    skrll  * 3. Neither the name of the University nor the names of its contributors
     20  1.2.56.1    skrll  *    may be used to endorse or promote products derived from this software
     21  1.2.56.1    skrll  *    without specific prior written permission.
     22  1.2.56.1    skrll  *
     23  1.2.56.1    skrll  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     24  1.2.56.1    skrll  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     25  1.2.56.1    skrll  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     26  1.2.56.1    skrll  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     27  1.2.56.1    skrll  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     28  1.2.56.1    skrll  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     29  1.2.56.1    skrll  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     30  1.2.56.1    skrll  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     31  1.2.56.1    skrll  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     32  1.2.56.1    skrll  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     33  1.2.56.1    skrll  * SUCH DAMAGE.
     34  1.2.56.1    skrll  *
     35  1.2.56.1    skrll  *	@(#)dcm.c	8.1 (Berkeley) 6/10/93
     36  1.2.56.1    skrll  */
     37  1.2.56.1    skrll /*
     38  1.2.56.1    skrll  * Copyright (c) 1988 University of Utah.
     39  1.2.56.1    skrll  *
     40  1.2.56.1    skrll  * This code is derived from software contributed to Berkeley by
     41  1.2.56.1    skrll  * the Systems Programming Group of the University of Utah Computer
     42  1.2.56.1    skrll  * Science Department.
     43  1.2.56.1    skrll  *
     44  1.2.56.1    skrll  * Redistribution and use in source and binary forms, with or without
     45  1.2.56.1    skrll  * modification, are permitted provided that the following conditions
     46  1.2.56.1    skrll  * are met:
     47  1.2.56.1    skrll  * 1. Redistributions of source code must retain the above copyright
     48  1.2.56.1    skrll  *    notice, this list of conditions and the following disclaimer.
     49  1.2.56.1    skrll  * 2. Redistributions in binary form must reproduce the above copyright
     50  1.2.56.1    skrll  *    notice, this list of conditions and the following disclaimer in the
     51  1.2.56.1    skrll  *    documentation and/or other materials provided with the distribution.
     52       1.1  thorpej  * 3. All advertising materials mentioning features or use of this software
     53       1.1  thorpej  *    must display the following acknowledgement:
     54       1.1  thorpej  *	This product includes software developed by the University of
     55       1.1  thorpej  *	California, Berkeley and its contributors.
     56       1.1  thorpej  * 4. Neither the name of the University nor the names of its contributors
     57       1.1  thorpej  *    may be used to endorse or promote products derived from this software
     58       1.1  thorpej  *    without specific prior written permission.
     59       1.1  thorpej  *
     60       1.1  thorpej  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     61       1.1  thorpej  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     62       1.1  thorpej  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     63       1.1  thorpej  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     64       1.1  thorpej  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     65       1.1  thorpej  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     66       1.1  thorpej  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     67       1.1  thorpej  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     68       1.1  thorpej  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     69       1.1  thorpej  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     70       1.1  thorpej  * SUCH DAMAGE.
     71       1.1  thorpej  *
     72       1.1  thorpej  *	@(#)dcm.c	8.1 (Berkeley) 6/10/93
     73       1.1  thorpej  */
     74       1.1  thorpej 
     75       1.1  thorpej #ifdef DCMCONSOLE
     76       1.1  thorpej #include <sys/param.h>
     77       1.1  thorpej #include <dev/cons.h>
     78       1.1  thorpej 
     79       1.1  thorpej #include <hp300/dev/dcmreg.h>
     80       1.1  thorpej 
     81       1.1  thorpej #include <hp300/stand/common/consdefs.h>
     82       1.1  thorpej #include <hp300/stand/common/samachdep.h>
     83       1.1  thorpej #include <hp300/stand/common/device.h>
     84       1.1  thorpej 
     85       1.1  thorpej struct dcmdevice *dcmcnaddr = NULL;
     86       1.1  thorpej 
     87       1.2   scottr #define	DCMCONUNIT	1	/* XXX */
     88       1.1  thorpej 
     89       1.1  thorpej void
     90       1.1  thorpej dcmprobe(cp)
     91       1.1  thorpej 	struct consdev *cp;
     92       1.1  thorpej {
     93  1.2.56.1    skrll 	struct hp_hw *hw;
     94  1.2.56.1    skrll 	struct dcmdevice *dcm;
     95       1.1  thorpej 
     96       1.1  thorpej 	for (hw = sc_table; hw < &sc_table[MAXCTLRS]; hw++)
     97       1.1  thorpej 		if (HW_ISDEV(hw, D_COMMDCM) && !badaddr((caddr_t)hw->hw_kva))
     98       1.1  thorpej 			break;
     99       1.1  thorpej 	if (!HW_ISDEV(hw, D_COMMDCM)) {
    100       1.1  thorpej 		cp->cn_pri = CN_DEAD;
    101       1.1  thorpej 		return;
    102       1.1  thorpej 	}
    103       1.1  thorpej 	dcmcnaddr = (struct dcmdevice *) hw->hw_kva;
    104       1.1  thorpej 
    105       1.2   scottr #ifdef FORCEDCMCONSOLE
    106       1.2   scottr 	cp->cn_pri = CN_REMOTE;
    107       1.2   scottr #else
    108       1.1  thorpej 	dcm = dcmcnaddr;
    109       1.1  thorpej 	switch (dcm->dcm_rsid) {
    110       1.1  thorpej 	case DCMID:
    111       1.1  thorpej 		cp->cn_pri = CN_NORMAL;
    112       1.1  thorpej 		break;
    113       1.1  thorpej 	case DCMID|DCMCON:
    114       1.1  thorpej 		cp->cn_pri = CN_REMOTE;
    115       1.1  thorpej 		break;
    116       1.1  thorpej 	default:
    117       1.1  thorpej 		cp->cn_pri = CN_DEAD;
    118       1.1  thorpej 		break;
    119       1.1  thorpej 	}
    120       1.1  thorpej 
    121       1.1  thorpej 	curcons_scode = hw->hw_sc;
    122       1.2   scottr #endif
    123       1.1  thorpej }
    124       1.1  thorpej 
    125       1.1  thorpej void
    126       1.1  thorpej dcminit(cp)
    127       1.1  thorpej 	struct consdev *cp;
    128       1.1  thorpej {
    129  1.2.56.1    skrll 	struct dcmdevice *dcm = dcmcnaddr;
    130  1.2.56.1    skrll 	int port = DCMCONUNIT;
    131       1.1  thorpej 
    132       1.1  thorpej 	dcm->dcm_ic = IC_ID;
    133       1.1  thorpej 	while (dcm->dcm_thead[port].ptr != dcm->dcm_ttail[port].ptr)
    134       1.1  thorpej 		;
    135       1.1  thorpej 	dcm->dcm_data[port].dcm_baud = BR_9600;
    136       1.1  thorpej 	dcm->dcm_data[port].dcm_conf = LC_8BITS | LC_1STOP;
    137       1.1  thorpej 	SEM_LOCK(dcm);
    138       1.1  thorpej 	dcm->dcm_cmdtab[port].dcm_data |= CT_CON;
    139       1.1  thorpej 	dcm->dcm_cr |= (1 << port);
    140       1.1  thorpej 	SEM_UNLOCK(dcm);
    141       1.1  thorpej 	DELAY(15000);
    142       1.1  thorpej }
    143       1.1  thorpej 
    144       1.1  thorpej /* ARGSUSED */
    145       1.1  thorpej #ifndef SMALL
    146       1.1  thorpej int
    147       1.1  thorpej dcmgetchar(dev)
    148       1.1  thorpej 	dev_t dev;
    149       1.1  thorpej {
    150  1.2.56.1    skrll 	struct dcmdevice *dcm = dcmcnaddr;
    151  1.2.56.1    skrll 	struct dcmrfifo *fifo;
    152  1.2.56.1    skrll 	struct dcmpreg *pp;
    153  1.2.56.1    skrll 	unsigned int head;
    154       1.1  thorpej 	int c, stat, port;
    155       1.1  thorpej 
    156       1.1  thorpej 	port = DCMCONUNIT;
    157       1.1  thorpej 	pp = dcm_preg(dcm, port);
    158       1.1  thorpej 	head = pp->r_head & RX_MASK;
    159       1.1  thorpej 	if (head == (pp->r_tail & RX_MASK))
    160  1.2.56.1    skrll 		return 0;
    161       1.1  thorpej 	fifo = &dcm->dcm_rfifos[3-port][head>>1];
    162       1.1  thorpej 	c = fifo->data_char;
    163       1.1  thorpej 	stat = fifo->data_stat;
    164       1.1  thorpej 	pp->r_head = (head + 2) & RX_MASK;
    165       1.1  thorpej 	SEM_LOCK(dcm);
    166       1.1  thorpej 	stat = dcm->dcm_iir;
    167       1.1  thorpej 	SEM_UNLOCK(dcm);
    168  1.2.56.1    skrll 	return c;
    169       1.1  thorpej }
    170       1.1  thorpej #else
    171       1.1  thorpej int
    172       1.1  thorpej dcmgetchar(dev)
    173       1.1  thorpej 	dev_t dev;
    174       1.1  thorpej {
    175  1.2.56.1    skrll 
    176  1.2.56.1    skrll 	return 0;
    177       1.1  thorpej }
    178       1.1  thorpej #endif
    179       1.1  thorpej 
    180       1.1  thorpej /* ARGSUSED */
    181       1.1  thorpej void
    182       1.1  thorpej dcmputchar(dev, c)
    183       1.1  thorpej 	dev_t dev;
    184  1.2.56.1    skrll 	int c;
    185       1.1  thorpej {
    186  1.2.56.1    skrll 	struct dcmdevice *dcm = dcmcnaddr;
    187  1.2.56.1    skrll 	struct dcmpreg *pp;
    188  1.2.56.1    skrll 	int timo;
    189  1.2.56.1    skrll 	unsigned int tail;
    190       1.1  thorpej 	int port, stat;
    191       1.1  thorpej 
    192       1.1  thorpej 	port = DCMCONUNIT;
    193       1.1  thorpej 	pp = dcm_preg(dcm, port);
    194       1.1  thorpej 	tail = pp->t_tail & TX_MASK;
    195       1.1  thorpej 	timo = 50000;
    196       1.1  thorpej 	while (tail != (pp->t_head & TX_MASK) && --timo)
    197       1.1  thorpej 		;
    198       1.1  thorpej 	dcm->dcm_tfifos[3-port][tail].data_char = c;
    199       1.1  thorpej 	pp->t_tail = tail = (tail + 1) & TX_MASK;
    200       1.1  thorpej 	SEM_LOCK(dcm);
    201       1.1  thorpej 	dcm->dcm_cmdtab[port].dcm_data |= CT_TX;
    202       1.1  thorpej 	dcm->dcm_cr |= (1 << port);
    203       1.1  thorpej 	SEM_UNLOCK(dcm);
    204       1.1  thorpej 	timo = 1000000;
    205       1.1  thorpej 	while (tail != (pp->t_head & TX_MASK) && --timo)
    206       1.1  thorpej 		;
    207       1.1  thorpej 	SEM_LOCK(dcm);
    208       1.1  thorpej 	stat = dcm->dcm_iir;
    209       1.1  thorpej 	SEM_UNLOCK(dcm);
    210       1.1  thorpej }
    211       1.1  thorpej #endif
    212