hpib.c revision 1.1.1.1       1 /*
      2  * Copyright (c) 1982, 1990 The Regents of the University of California.
      3  * All rights reserved.
      4  *
      5  * Redistribution and use in source and binary forms, with or without
      6  * modification, are permitted provided that the following conditions
      7  * are met:
      8  * 1. Redistributions of source code must retain the above copyright
      9  *    notice, this list of conditions and the following disclaimer.
     10  * 2. Redistributions in binary form must reproduce the above copyright
     11  *    notice, this list of conditions and the following disclaimer in the
     12  *    documentation and/or other materials provided with the distribution.
     13  * 3. All advertising materials mentioning features or use of this software
     14  *    must display the following acknowledgement:
     15  *	This product includes software developed by the University of
     16  *	California, Berkeley and its contributors.
     17  * 4. Neither the name of the University nor the names of its contributors
     18  *    may be used to endorse or promote products derived from this software
     19  *    without specific prior written permission.
     20  *
     21  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     22  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     23  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     24  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     25  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     26  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     27  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     28  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     29  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     30  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     31  * SUCH DAMAGE.
     32  *
     33  *	@(#)hpib.c	7.3 (Berkeley) 12/16/90
     34  */
     35 
     36 /*
     37  * HPIB driver
     38  */
     39 #include "hpib.h"
     40 #if NHPIB > 0
     41 
     42 #include "sys/param.h"
     43 #include "sys/systm.h"
     44 #include "sys/buf.h"
     45 #include "device.h"
     46 #include "hpibvar.h"
     47 #include "dmavar.h"
     48 
     49 #include "../include/cpu.h"
     50 #include "../hp300/isr.h"
     51 
     52 int	hpibinit(), hpibstart(), hpibgo(), hpibintr(), hpibdone();
     53 struct	driver hpibdriver = {
     54 	hpibinit, "hpib", hpibstart, hpibgo, hpibintr, hpibdone,
     55 };
     56 
     57 struct	hpib_softc hpib_softc[NHPIB];
     58 struct	isr hpib_isr[NHPIB];
     59 int	nhpibppoll(), fhpibppoll();
     60 
     61 int	hpibtimeout = 100000;	/* # of status tests before we give up */
     62 int	hpibidtimeout = 20000;	/* # of status tests for hpibid() calls */
     63 int	hpibdmathresh = 3;	/* byte count beyond which to attempt dma */
     64 
     65 hpibinit(hc)
     66 	register struct hp_ctlr *hc;
     67 {
     68 	register struct hpib_softc *hs = &hpib_softc[hc->hp_unit];
     69 
     70 	if (!nhpibtype(hc) && !fhpibtype(hc))
     71 		return(0);
     72 	hs->sc_hc = hc;
     73 	hs->sc_dq.dq_unit = hc->hp_unit;
     74 	hs->sc_dq.dq_driver = &hpibdriver;
     75 	hs->sc_sq.dq_forw = hs->sc_sq.dq_back = &hs->sc_sq;
     76 	hpib_isr[hc->hp_unit].isr_intr = hpibintr;
     77 	hpib_isr[hc->hp_unit].isr_ipl = hc->hp_ipl;
     78 	hpib_isr[hc->hp_unit].isr_arg = hc->hp_unit;
     79 	isrlink(&hpib_isr[hc->hp_unit]);
     80 	hpibreset(hc->hp_unit);
     81 	return(1);
     82 }
     83 
     84 hpibreset(unit)
     85 	register int unit;
     86 {
     87 	if (hpib_softc[unit].sc_type == HPIBC)
     88 		fhpibreset(unit);
     89 	else
     90 		nhpibreset(unit);
     91 }
     92 
     93 hpibreq(dq)
     94 	register struct devqueue *dq;
     95 {
     96 	register struct devqueue *hq;
     97 
     98 	hq = &hpib_softc[dq->dq_ctlr].sc_sq;
     99 	insque(dq, hq->dq_back);
    100 	if (dq->dq_back == hq)
    101 		return(1);
    102 	return(0);
    103 }
    104 
    105 hpibfree(dq)
    106 	register struct devqueue *dq;
    107 {
    108 	register struct devqueue *hq;
    109 
    110 	hq = &hpib_softc[dq->dq_ctlr].sc_sq;
    111 	remque(dq);
    112 	if ((dq = hq->dq_forw) != hq)
    113 		(dq->dq_driver->d_start)(dq->dq_unit);
    114 }
    115 
    116 hpibid(unit, slave)
    117 {
    118 	short id;
    119 	int ohpibtimeout;
    120 
    121 	/*
    122 	 * XXX: shorten timeout value (so autoconfig doesn't take forever)
    123 	 */
    124 	ohpibtimeout = hpibtimeout;
    125 	hpibtimeout = hpibidtimeout;
    126 	if (hpibrecv(unit, 31, slave, &id, 2) != 2)
    127 		id = 0;
    128 	hpibtimeout = ohpibtimeout;
    129 	return(id);
    130 }
    131 
    132 hpibsend(unit, slave, sec, addr, cnt)
    133 	register int unit;
    134 {
    135 	if (hpib_softc[unit].sc_type == HPIBC)
    136 		return(fhpibsend(unit, slave, sec, addr, cnt));
    137 	else
    138 		return(nhpibsend(unit, slave, sec, addr, cnt));
    139 }
    140 
    141 hpibrecv(unit, slave, sec, addr, cnt)
    142 	register int unit;
    143 {
    144 	if (hpib_softc[unit].sc_type == HPIBC)
    145 		return(fhpibrecv(unit, slave, sec, addr, cnt));
    146 	else
    147 		return(nhpibrecv(unit, slave, sec, addr, cnt));
    148 }
    149 
    150 hpibpptest(unit, slave)
    151 	register int unit;
    152 {
    153 	int (*ppoll)();
    154 
    155 	ppoll = (hpib_softc[unit].sc_type == HPIBC) ? fhpibppoll : nhpibppoll;
    156 	return((*ppoll)(unit) & (0x80 >> slave));
    157 }
    158 
    159 hpibawait(unit)
    160 {
    161 	register struct hpib_softc *hs = &hpib_softc[unit];
    162 
    163 	hs->sc_flags |= HPIBF_PPOLL;
    164 	if (hs->sc_type == HPIBC)
    165 		fhpibppwatch(unit);
    166 	else
    167 		nhpibppwatch(unit);
    168 }
    169 
    170 hpibswait(unit, slave)
    171 	register int unit;
    172 {
    173 	register int timo = hpibtimeout;
    174 	register int mask, (*ppoll)();
    175 
    176 	ppoll = (hpib_softc[unit].sc_type == HPIBC) ? fhpibppoll : nhpibppoll;
    177 	mask = 0x80 >> slave;
    178 	while (((ppoll)(unit) & mask) == 0)
    179 		if (--timo == 0) {
    180 			printf("hpib%d: swait timeout\n", unit);
    181 			return(-1);
    182 		}
    183 	return(0);
    184 }
    185 
    186 hpibustart(unit)
    187 {
    188 	register struct hpib_softc *hs = &hpib_softc[unit];
    189 
    190 	if (hs->sc_type == HPIBA)
    191 		hs->sc_dq.dq_ctlr = DMA0;
    192 	else
    193 		hs->sc_dq.dq_ctlr = DMA0 | DMA1;
    194 	if (dmareq(&hs->sc_dq))
    195 		return(1);
    196 	return(0);
    197 }
    198 
    199 hpibstart(unit)
    200 {
    201 	register struct devqueue *dq;
    202 
    203 	dq = hpib_softc[unit].sc_sq.dq_forw;
    204 	(dq->dq_driver->d_go)(dq->dq_unit);
    205 }
    206 
    207 hpibgo(unit, slave, sec, addr, count, rw)
    208 	register int unit;
    209 {
    210 	if (hpib_softc[unit].sc_type == HPIBC)
    211 		fhpibgo(unit, slave, sec, addr, count, rw);
    212 	else
    213 		nhpibgo(unit, slave, sec, addr, count, rw);
    214 }
    215 
    216 hpibdone(unit)
    217 	register int unit;
    218 {
    219 	if (hpib_softc[unit].sc_type == HPIBC)
    220 		fhpibdone(unit);
    221 	else
    222 		nhpibdone(unit);
    223 }
    224 
    225 hpibintr(unit)
    226 	register int unit;
    227 {
    228 	int found;
    229 
    230 	if (hpib_softc[unit].sc_type == HPIBC)
    231 		found = fhpibintr(unit);
    232 	else
    233 		found = nhpibintr(unit);
    234 	return(found);
    235 }
    236 #endif
    237