summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/sparc/dev/magma.c1009
-rw-r--r--sys/arch/sparc/dev/magmareg.h10
2 files changed, 550 insertions, 469 deletions
diff --git a/sys/arch/sparc/dev/magma.c b/sys/arch/sparc/dev/magma.c
index 05aaf425258..4b5e4ef562f 100644
--- a/sys/arch/sparc/dev/magma.c
+++ b/sys/arch/sparc/dev/magma.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: magma.c,v 1.18 2004/09/29 07:35:11 miod Exp $ */
+/* $OpenBSD: magma.c,v 1.19 2004/11/02 21:16:10 miod Exp $ */
/*
* magma.c
*
@@ -30,7 +30,6 @@
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
-#define MAGMA_DEBUG
*/
/*
@@ -39,7 +38,6 @@
*/
#include "magma.h"
-#if NMAGMA > 0
#include <sys/param.h>
#include <sys/systm.h>
@@ -66,10 +64,10 @@
#include <dev/ic/cd1190reg.h>
#include <sparc/bppioctl.h>
-#include "magmareg.h"
+#include <sparc/dev/magmareg.h>
/*
- * Select tty soft interrupt bit based on TTY ipl. (stole from zs.c)
+ * Select tty soft interrupt bit based on TTY ipl. (stolen from zs.c)
*/
#if IPL_TTY == 1
# define IE_MSOFT IE_L1
@@ -81,7 +79,14 @@
# error "no suitable software interrupt bit"
#endif
-/* supported cards
+#ifdef MAGMA_DEBUG
+#define dprintf(x) printf x
+#else
+#define dprintf(x)
+#endif
+
+/*
+ * Supported cards table.
*
* The table below lists the cards that this driver is likely to
* be able to support.
@@ -93,7 +98,7 @@
*
* Thanks to Bruce at Magma for telling me the hardware offsets.
*/
-static struct magma_board_info supported_cards[] = {
+static const struct magma_board_info supported_cards[] = {
{
"MAGMA_Sp", "MAGMA,4_Sp", "Magma 4 Sp", 4, 0,
1, 0xa000, 0xc000, 0xe000, { 0x8000, 0, 0, 0 },
@@ -222,25 +227,25 @@ struct cfdriver mbpp_cd = {
*/
int
cd1400_compute_baud(speed, clock, cor, bpr)
-speed_t speed;
-int clock;
-int *cor, *bpr;
+ speed_t speed;
+ int clock;
+ int *cor, *bpr;
{
-int c, co, br;
+ int c, co, br;
- if( speed < 50 || speed > 150000 )
- return(1);
+ if (speed < 50 || speed > 150000)
+ return (1);
- for( c = 0, co = 8 ; co <= 2048 ; co <<= 2, c++ ) {
+ for (c = 0, co = 8 ; co <= 2048 ; co <<= 2, c++) {
br = ((clock * 1000000) + (co * speed) / 2) / (co * speed);
- if( br < 0x100 ) {
+ if (br < 0x100) {
*bpr = br;
*cor = c;
- return(0);
+ return (0);
}
}
- return(1);
+ return (1);
}
/*
@@ -248,10 +253,10 @@ int c, co, br;
*/
__inline void
cd1400_write_ccr(cd, cmd)
-struct cd1400 *cd;
-u_char cmd;
+ struct cd1400 *cd;
+ u_char cmd;
{
- while( cd1400_read_reg(cd, CD1400_CCR) )
+ while (cd1400_read_reg(cd, CD1400_CCR))
;
cd1400_write_reg(cd, CD1400_CCR, cmd);
@@ -262,10 +267,10 @@ u_char cmd;
*/
__inline u_char
cd1400_read_reg(cd, reg)
-struct cd1400 *cd;
-int reg;
+ struct cd1400 *cd;
+ int reg;
{
- return(cd->cd_reg[reg]);
+ return (cd->cd_reg[reg]);
}
/*
@@ -273,9 +278,9 @@ int reg;
*/
__inline void
cd1400_write_reg(cd, reg, value)
-struct cd1400 *cd;
-int reg;
-u_char value;
+ struct cd1400 *cd;
+ int reg;
+ u_char value;
{
cd->cd_reg[reg] = value;
}
@@ -285,10 +290,10 @@ u_char value;
*/
void
cd1400_enable_transmitter(cd, channel)
-struct cd1400 *cd;
-int channel;
+ struct cd1400 *cd;
+ int channel;
{
-register int s, srer;
+ register int s, srer;
s = spltty();
cd1400_write_reg(cd, CD1400_CAR, channel);
@@ -303,7 +308,7 @@ register int s, srer;
* CD1190 Routines
*/
-/* well, there are none yet */
+/* XXX well, there are none yet */
/************************************************************************
*
@@ -322,7 +327,7 @@ magma_match(parent, vcf, args)
{
struct confargs *ca = args;
struct romaux *ra = &ca->ca_ra;
- struct magma_board_info *card;
+ const struct magma_board_info *card;
for (card = supported_cards; ; card++) {
if (card->mb_sbusname == NULL)
@@ -334,18 +339,26 @@ magma_match(parent, vcf, args)
#if defined(MAGMA_DEBUG)
{
-int i;
-
- printf("magma: matched `%s', nvaddrs %d, nreg %d, nintr %d\n", ra->ra_name, ra->ra_nvaddrs, ra->ra_nreg, ra->ra_nintr);
- printf("magma: magma_prom `%s'\n", getpropstring(ra->ra_node, "magma_prom"));
- printf("magma: intlevels `%s'\n", getpropstring(ra->ra_node, "intlevels"));
- printf("magma: chiprev `%s'\n", getpropstring(ra->ra_node, "chiprev"));
- printf("magma: clock `%s'\n", getpropstring(ra->ra_node, "clock"));
-
- for( i = 0 ; i < ra->ra_nreg ; i++ )
- printf("magma: reg %d; ra_iospace = %d, ra_paddr = 0x%x, ra_len = %d\n", i, ra->ra_reg[i].rr_iospace, (int)ra->ra_reg[i].rr_paddr, ra->ra_reg[i].rr_len);
- for( i = 0 ; i < ra->ra_nintr ; i++ )
- printf("magma: intr %d; pri = %d, vec = %d\n", i, ra->ra_intr[i].int_pri, ra->ra_intr[i].int_vec);
+ int i;
+
+ printf("magma: matched `%s', nvaddrs %d, nreg %d, nintr %d\n",
+ ra->ra_name, ra->ra_nvaddrs, ra->ra_nreg, ra->ra_nintr);
+ printf("magma: magma_prom `%s'\n",
+ getpropstring(ra->ra_node, "magma_prom"));
+ printf("magma: intlevels `%s'\n",
+ getpropstring(ra->ra_node, "intlevels"));
+ printf("magma: chiprev `%s'\n",
+ getpropstring(ra->ra_node, "chiprev"));
+ printf("magma: clock `%s'\n",
+ getpropstring(ra->ra_node, "clock"));
+
+ for (i = 0 ; i < ra->ra_nreg ; i++)
+ printf("magma: reg %d; ra_iospace = %d, ra_paddr = 0x%x, ra_len = %d\n",
+ i, ra->ra_reg[i].rr_iospace,
+ (int)ra->ra_reg[i].rr_paddr, ra->ra_reg[i].rr_len);
+ for (i = 0 ; i < ra->ra_nintr ; i++)
+ printf("magma: intr %d; pri = %d, vec = %d\n",
+ i, ra->ra_intr[i].int_pri, ra->ra_intr[i].int_vec);
}
#endif
@@ -354,18 +367,17 @@ int i;
void
magma_attach(parent, dev, args)
-struct device *parent;
-struct device *dev;
-void *args;
+ struct device *parent;
+ struct device *dev;
+ void *args;
{
-struct confargs *ca = args;
-struct romaux *ra = &ca->ca_ra;
-struct magma_softc *sc = (struct magma_softc *)dev;
-struct magma_board_info *card;
-char magma_prom[40], *clockstr;
-int chip, cd_clock, len;
-void *base;
-
+ struct confargs *ca = args;
+ struct romaux *ra = &ca->ca_ra;
+ struct magma_softc *sc = (struct magma_softc *)dev;
+ const struct magma_board_info *card;
+ char magma_prom[40], *clockstr;
+ int chip, cd_clock, len;
+ void *base;
len = getprop(ra->ra_node, "magma_prom",
magma_prom, sizeof(magma_prom) - 1);
@@ -380,7 +392,7 @@ void *base;
break;
}
- if( card->mb_name == NULL ) {
+ if (card->mb_name == NULL) {
printf(" %s (unsupported)\n", magma_prom);
return;
}
@@ -410,8 +422,8 @@ void *base;
sc->ms_svcackt = base + card->mb_svcackt;
sc->ms_svcackm = base + card->mb_svcackm;
- /* init the cd1400 chips */
- for( chip = 0 ; chip < card->mb_ncd1400 ; chip++ ) {
+ /* Init the cd1400 chips */
+ for (chip = 0 ; chip < card->mb_ncd1400 ; chip++) {
struct cd1400 *cd = &sc->ms_cd1400[chip];
cd->cd_reg = base + card->mb_cd1400[chip];
@@ -422,7 +434,9 @@ void *base;
/* seemingly the Magma drivers just ignore the propstring */
cd->cd_chiprev = cd1400_read_reg(cd, CD1400_GFRCR);
- dprintf(("%s attach CD1400 %d addr 0x%x rev %x clock %dMHz\n", sc->ms_dev.dv_xname, chip, cd->cd_reg, cd->cd_chiprev, cd->cd_clock));
+ dprintf(("%s attach CD1400 %d addr 0x%x rev %x clock %dMHz\n",
+ sc->ms_dev.dv_xname, chip,
+ cd->cd_reg, cd->cd_chiprev, cd->cd_clock));
/* clear GFRCR */
cd1400_write_reg(cd, CD1400_GFRCR, 0x00);
@@ -431,28 +445,33 @@ void *base;
cd1400_write_ccr(cd, CD1400_CCR_CMDRESET | CD1400_CCR_FULLRESET);
/* wait for revision code to be restored */
- while( cd1400_read_reg(cd, CD1400_GFRCR) != cd->cd_chiprev )
+ while (cd1400_read_reg(cd, CD1400_GFRCR) != cd->cd_chiprev)
;
/* set the Prescaler Period Register to tick at 1ms */
- cd1400_write_reg(cd, CD1400_PPR, ((cd->cd_clock * 1000000 / CD1400_PPR_PRESCALER + 500) / 1000));
+ cd1400_write_reg(cd, CD1400_PPR,
+ ((cd->cd_clock * 1000000 / CD1400_PPR_PRESCALER + 500) /
+ 1000));
- /* The LC2+1Sp card is the only card that doesn't have a CD1190 for the
- * parallel port, but uses channel 0 of the CD1400, so we make a note
- * of it for later and set up the CD1400 for parallel mode operation.
+ /*
+ * The LC2+1Sp card is the only card that doesn't have a CD1190
+ * for the parallel port, but uses channel 0 of the CD1400, so
+ * we make a note of it for later and set up the CD1400 for
+ * parallel mode operation.
*/
- if( card->mb_npar && card->mb_ncd1190 == 0 ) {
+ if (card->mb_npar && card->mb_ncd1190 == 0) {
cd1400_write_reg(cd, CD1400_GCR, CD1400_GCR_PARALLEL);
cd->cd_parmode = 1;
}
}
/* init the cd1190 chips */
- for( chip = 0 ; chip < card->mb_ncd1190 ; chip++ ) {
- struct cd1190 *cd = &sc->ms_cd1190[chip];
+ for (chip = 0 ; chip < card->mb_ncd1190 ; chip++) {
+ struct cd1190 *cd = &sc->ms_cd1190[chip];
cd->cd_reg = base + card->mb_cd1190[chip];
- dprintf(("%s attach CD1190 %d addr 0x%x (failed)\n", sc->ms_dev.dv_xname, chip, cd->cd_reg));
+ dprintf(("%s attach CD1190 %d addr 0x%x (failed)\n",
+ sc->ms_dev.dv_xname, chip, cd->cd_reg));
/* XXX don't know anything about these chips yet */
}
@@ -482,25 +501,26 @@ void *base;
*/
int
magma_hard(arg)
-void *arg;
+ void *arg;
{
-struct magma_softc *sc = arg;
-struct cd1400 *cd;
-int chip, status = 0;
-int serviced = 0;
-int needsoftint = 0;
+ struct magma_softc *sc = arg;
+ struct cd1400 *cd;
+ int chip, status = 0;
+ int serviced = 0;
+ int needsoftint = 0;
/*
* check status of all the CD1400 chips
*/
- for( chip = 0 ; chip < sc->ms_ncd1400 ; chip++ )
+ for (chip = 0 ; chip < sc->ms_ncd1400 ; chip++)
status |= cd1400_read_reg(&sc->ms_cd1400[chip], CD1400_SVRR);
- if( ISSET(status, CD1400_SVRR_RXRDY) ) {
- u_char rivr = *sc->ms_svcackr; /* enter rx service context */
- int port = rivr >> 4;
+ if (ISSET(status, CD1400_SVRR_RXRDY)) {
+ /* enter rx service context */
+ u_char rivr = *sc->ms_svcackr;
+ int port = rivr >> 4;
- if( rivr & (1<<3) ) { /* parallel port */
+ if (rivr & (1 << 3)) { /* parallel port */
struct mbpp_port *mbpp;
int n_chars;
@@ -509,8 +529,8 @@ int needsoftint = 0;
/* don't think we have to handle exceptions */
n_chars = cd1400_read_reg(cd, CD1400_RDCR);
- while( n_chars-- ) {
- if( mbpp->mp_cnt == 0 ) {
+ while (n_chars--) {
+ if (mbpp->mp_cnt == 0) {
SET(mbpp->mp_flags, MBPPF_WAKEUP);
needsoftint = 1;
break;
@@ -520,13 +540,13 @@ int needsoftint = 0;
mbpp->mp_cnt--;
}
} else { /* serial port */
- register struct mtty_port *mtty;
- register u_char *ptr, n_chars, line_stat;
+ register struct mtty_port *mtty;
+ register u_char *ptr, n_chars, line_stat;
mtty = &sc->ms_mtty->ms_port[port];
cd = mtty->mp_cd1400;
- if( ISSET(rivr, CD1400_RIVR_EXCEPTION) ) {
+ if (ISSET(rivr, CD1400_RIVR_EXCEPTION)) {
line_stat = cd1400_read_reg(cd, CD1400_RDSR);
n_chars = 1;
} else { /* no exception, received data OK */
@@ -535,12 +555,14 @@ int needsoftint = 0;
}
ptr = mtty->mp_rput;
- while( n_chars-- ) {
+ while (n_chars--) {
*ptr++ = line_stat;
*ptr++ = cd1400_read_reg(cd, CD1400_RDSR);
- if( ptr == mtty->mp_rend ) ptr = mtty->mp_rbuf;
- if( ptr == mtty->mp_rget ) {
- if( ptr == mtty->mp_rbuf ) ptr = mtty->mp_rend;
+ if (ptr == mtty->mp_rend)
+ ptr = mtty->mp_rbuf;
+ if (ptr == mtty->mp_rget) {
+ if (ptr == mtty->mp_rbuf)
+ ptr = mtty->mp_rend;
ptr -= 2;
SET(mtty->mp_flags, MTTYF_RING_OVERFLOW);
break;
@@ -551,16 +573,18 @@ int needsoftint = 0;
needsoftint = 1;
}
- cd1400_write_reg(cd, CD1400_EOSRR, 0); /* end service context */
+ /* end service context */
+ cd1400_write_reg(cd, CD1400_EOSRR, 0);
serviced = 1;
- } /* if(rx_service...) */
+ } /* if (rx_service...) */
- if( ISSET(status, CD1400_SVRR_MDMCH) ) {
- u_char mivr = *sc->ms_svcackm; /* enter mdm service context */
- int port = mivr >> 4;
- struct mtty_port *mtty;
- int carrier;
- u_char msvr;
+ if (ISSET(status, CD1400_SVRR_MDMCH)) {
+ /* enter mdm service context */
+ u_char mivr = *sc->ms_svcackm;
+ int port = mivr >> 4;
+ struct mtty_port *mtty;
+ int carrier;
+ u_char msvr;
/*
* Handle CD (LC2+1Sp = DSR) changes.
@@ -568,60 +592,67 @@ int needsoftint = 0;
mtty = &sc->ms_mtty->ms_port[port];
cd = mtty->mp_cd1400;
msvr = cd1400_read_reg(cd, CD1400_MSVR2);
- carrier = ISSET(msvr, cd->cd_parmode ? CD1400_MSVR2_DSR : CD1400_MSVR2_CD);
+ carrier = ISSET(msvr,
+ cd->cd_parmode ? CD1400_MSVR2_DSR : CD1400_MSVR2_CD);
- if( mtty->mp_carrier != carrier ) {
+ if (mtty->mp_carrier != carrier) {
SET(mtty->mp_flags, MTTYF_CARRIER_CHANGED);
mtty->mp_carrier = carrier;
needsoftint = 1;
}
- cd1400_write_reg(cd, CD1400_EOSRR, 0); /* end service context */
+ /* end service context */
+ cd1400_write_reg(cd, CD1400_EOSRR, 0);
serviced = 1;
- } /* if(mdm_service...) */
+ } /* if (mdm_service...) */
- if( ISSET(status, CD1400_SVRR_TXRDY) ) {
- u_char tivr = *sc->ms_svcackt; /* enter tx service context */
- int port = tivr >> 4;
+ if (ISSET(status, CD1400_SVRR_TXRDY)) {
+ /* enter tx service context */
+ u_char tivr = *sc->ms_svcackt;
+ int port = tivr >> 4;
- if( tivr & (1<<3) ) { /* parallel port */
- struct mbpp_port *mbpp;
+ if (tivr & (1 << 3)) { /* parallel port */
+ struct mbpp_port *mbpp;
mbpp = &sc->ms_mbpp->ms_port[port];
cd = mbpp->mp_cd1400;
- if( mbpp->mp_cnt ) {
- int count = 0;
+ if (mbpp->mp_cnt) {
+ int count = 0;
/* fill the fifo */
- while( mbpp->mp_cnt && count++ < CD1400_PAR_FIFO_SIZE ) {
- cd1400_write_reg(cd, CD1400_TDR, *mbpp->mp_ptr);
+ while (mbpp->mp_cnt &&
+ count++ < CD1400_PAR_FIFO_SIZE) {
+ cd1400_write_reg(cd, CD1400_TDR,
+ *mbpp->mp_ptr);
mbpp->mp_ptr++;
mbpp->mp_cnt--;
}
} else {
- /* fifo is empty and we got no more data to send, so shut
- * off interrupts and signal for a wakeup, which can't be
- * done here in case we beat mbpp_send to the tsleep call
- * (we are running at >spltty)
+ /*
+ * fifo is empty and we got no more data to
+ * send, so shut off interrupts and signal for
+ * a wakeup, which can't be done here in case
+ * we beat mbpp_send to the tsleep call
+ * (we are running at psl > spltty).
*/
cd1400_write_reg(cd, CD1400_SRER, 0);
SET(mbpp->mp_flags, MBPPF_WAKEUP);
needsoftint = 1;
}
} else { /* serial port */
- struct mtty_port *mtty;
- struct tty *tp;
+ struct mtty_port *mtty;
+ struct tty *tp;
mtty = &sc->ms_mtty->ms_port[port];
cd = mtty->mp_cd1400;
tp = mtty->mp_tty;
- if( !ISSET(mtty->mp_flags, MTTYF_STOP) ) {
- register int count = 0;
+ if (!ISSET(mtty->mp_flags, MTTYF_STOP)) {
+ register int count = 0;
/* check if we should start/stop a break */
- if( ISSET(mtty->mp_flags, MTTYF_SET_BREAK) ) {
+ if (ISSET(mtty->mp_flags, MTTYF_SET_BREAK)) {
cd1400_write_reg(cd, CD1400_TDR, 0);
cd1400_write_reg(cd, CD1400_TDR, 0x81);
/* should we delay too? */
@@ -629,27 +660,31 @@ int needsoftint = 0;
count += 2;
}
- if( ISSET(mtty->mp_flags, MTTYF_CLR_BREAK) ) {
+ if (ISSET(mtty->mp_flags, MTTYF_CLR_BREAK)) {
cd1400_write_reg(cd, CD1400_TDR, 0);
cd1400_write_reg(cd, CD1400_TDR, 0x83);
CLR(mtty->mp_flags, MTTYF_CLR_BREAK);
count += 2;
}
- /* I don't quite fill the fifo in case the last one is a
- * NULL which I have to double up because its the escape
- * code for embedded transmit characters.
+ /*
+ * I don't quite fill the fifo in case the last
+ * one is a NULL which I have to double up
+ * because its the escape code for embedded
+ * transmit characters.
*/
- while( mtty->mp_txc > 0 && count < CD1400_TX_FIFO_SIZE - 1 ) {
- register u_char ch;
+ while (mtty->mp_txc > 0 &&
+ count < CD1400_TX_FIFO_SIZE - 1) {
+ register u_char ch;
ch = *mtty->mp_txp;
mtty->mp_txc--;
mtty->mp_txp++;
- if( ch == 0 ) {
- cd1400_write_reg(cd, CD1400_TDR, ch);
+ if (ch == 0) {
+ cd1400_write_reg(cd,
+ CD1400_TDR, ch);
count++;
}
@@ -658,12 +693,14 @@ int needsoftint = 0;
}
}
- /* if we ran out of work or are requested to STOP then
- * shut off the txrdy interrupts and signal DONE to flush
- * out the chars we have sent.
+ /*
+ * If we ran out of work or are requested to STOP then
+ * shut off the txrdy interrupts and signal DONE to
+ * flush out the chars we have sent.
*/
- if( mtty->mp_txc == 0 || ISSET(mtty->mp_flags, MTTYF_STOP) ) {
- register int srer;
+ if (mtty->mp_txc == 0 ||
+ ISSET(mtty->mp_flags, MTTYF_STOP)) {
+ register int srer;
srer = cd1400_read_reg(cd, CD1400_SRER);
CLR(srer, CD1400_SRER_TXRDY);
@@ -675,25 +712,26 @@ int needsoftint = 0;
}
}
- cd1400_write_reg(cd, CD1400_EOSRR, 0); /* end service context */
+ /* end service context */
+ cd1400_write_reg(cd, CD1400_EOSRR, 0);
serviced = 1;
- } /* if(tx_service...) */
+ } /* if (tx_service...) */
/* XXX service CD1190 interrupts too
- for( chip = 0 ; chip < sc->ms_ncd1190 ; chip++ ) {
+ for (chip = 0 ; chip < sc->ms_ncd1190 ; chip++) {
}
*/
- if( needsoftint ) { /* trigger the soft interrupt */
+ if (needsoftint) { /* trigger the soft interrupt */
#if defined(SUN4M)
- if( CPU_ISSUN4M )
+ if (CPU_ISSUN4M)
raise(0, IPL_TTY);
else
#endif
ienab_bis(IE_MSOFT);
}
- return(serviced);
+ return (serviced);
}
/*
@@ -705,43 +743,48 @@ int needsoftint = 0;
*/
int
magma_soft(arg)
-void *arg;
+ void *arg;
{
-struct magma_softc *sc = arg;
-struct mtty_softc *mtty = sc->ms_mtty;
-struct mbpp_softc *mbpp = sc->ms_mbpp;
-int port;
-int serviced = 0;
-int s, flags;
+ struct magma_softc *sc = arg;
+ struct mtty_softc *mtty = sc->ms_mtty;
+ struct mbpp_softc *mbpp = sc->ms_mbpp;
+ int port;
+ int serviced = 0;
+ int s, flags;
/*
* check the tty ports (if any) to see what needs doing
*/
- if( mtty ) {
- for( port = 0 ; port < mtty->ms_nports ; port++ ) {
- struct mtty_port *mp = &mtty->ms_port[port];
- struct tty *tp = mp->mp_tty;
+ if (mtty) {
+ for (port = 0 ; port < mtty->ms_nports ; port++) {
+ struct mtty_port *mp = &mtty->ms_port[port];
+ struct tty *tp = mp->mp_tty;
- if( !ISSET(tp->t_state, TS_ISOPEN) ) continue;
+ if (!ISSET(tp->t_state, TS_ISOPEN))
+ continue;
/*
* handle any received data
*/
- while( mp->mp_rget != mp->mp_rput ) {
- u_char stat;
- int data;
+ while (mp->mp_rget != mp->mp_rput) {
+ u_char stat;
+ int data;
stat = mp->mp_rget[0];
data = mp->mp_rget[1];
- mp->mp_rget = ((mp->mp_rget + 2) == mp->mp_rend) ? mp->mp_rbuf : (mp->mp_rget + 2);
+ mp->mp_rget =
+ ((mp->mp_rget + 2) == mp->mp_rend) ?
+ mp->mp_rbuf : (mp->mp_rget + 2);
- if( stat & (CD1400_RDSR_BREAK | CD1400_RDSR_FE) )
+ if (stat & (CD1400_RDSR_BREAK | CD1400_RDSR_FE))
data |= TTY_FE;
- if( stat & CD1400_RDSR_PE )
+ if (stat & CD1400_RDSR_PE)
data |= TTY_PE;
- if( stat & CD1400_RDSR_OE )
- log(LOG_WARNING, "%s%x: fifo overflow\n", mtty->ms_dev.dv_xname, port);
+ if (stat & CD1400_RDSR_OE)
+ log(LOG_WARNING,
+ "%s%x: fifo overflow\n",
+ mtty->ms_dev.dv_xname, port);
(*linesw[tp->t_line].l_rint)(data, tp);
serviced = 1;
@@ -749,51 +792,60 @@ int s, flags;
s = splhigh(); /* block out hard interrupt routine */
flags = mp->mp_flags;
- CLR(mp->mp_flags, MTTYF_DONE | MTTYF_CARRIER_CHANGED | MTTYF_RING_OVERFLOW);
+ CLR(mp->mp_flags, MTTYF_DONE | MTTYF_CARRIER_CHANGED |
+ MTTYF_RING_OVERFLOW);
splx(s); /* ok */
- if( ISSET(flags, MTTYF_CARRIER_CHANGED) ) {
- dprintf(("%s%x: cd %s\n", mtty->ms_dev.dv_xname, port, mp->mp_carrier ? "on" : "off"));
- (*linesw[tp->t_line].l_modem)(tp, mp->mp_carrier);
+ if (ISSET(flags, MTTYF_CARRIER_CHANGED)) {
+ dprintf(("%s%x: cd %s\n",
+ mtty->ms_dev.dv_xname, port,
+ mp->mp_carrier ? "on" : "off"));
+ (*linesw[tp->t_line].l_modem)(tp,
+ mp->mp_carrier);
serviced = 1;
}
- if( ISSET(flags, MTTYF_RING_OVERFLOW) ) {
- log(LOG_WARNING, "%s%x: ring buffer overflow\n", mtty->ms_dev.dv_xname, port);
+ if (ISSET(flags, MTTYF_RING_OVERFLOW)) {
+ log(LOG_WARNING,
+ "%s%x: ring buffer overflow\n",
+ mtty->ms_dev.dv_xname, port);
serviced = 1;
}
- if( ISSET(flags, MTTYF_DONE) ) {
- ndflush(&tp->t_outq, mp->mp_txp - tp->t_outq.c_cf);
+ if (ISSET(flags, MTTYF_DONE)) {
+ ndflush(&tp->t_outq,
+ mp->mp_txp - tp->t_outq.c_cf);
CLR(tp->t_state, TS_BUSY);
- (*linesw[tp->t_line].l_start)(tp); /* might be some more */
+ /* might be some more */
+ (*linesw[tp->t_line].l_start)(tp);
serviced = 1;
}
- } /* for(each mtty...) */
+ } /* for (each mtty...) */
}
/*
* check the bpp ports (if any) to see what needs doing
*/
- if( mbpp ) {
- for( port = 0 ; port < mbpp->ms_nports ; port++ ) {
- struct mbpp_port *mp = &mbpp->ms_port[port];
+ if (mbpp) {
+ for (port = 0 ; port < mbpp->ms_nports ; port++) {
+ struct mbpp_port *mp = &mbpp->ms_port[port];
- if( !ISSET(mp->mp_flags, MBPPF_OPEN) ) continue;
+ if (!ISSET(mp->mp_flags, MBPPF_OPEN))
+ continue;
s = splhigh(); /* block out hard intr routine */
flags = mp->mp_flags;
CLR(mp->mp_flags, MBPPF_WAKEUP);
splx(s);
- if( ISSET(flags, MBPPF_WAKEUP) ) {
+ if (ISSET(flags, MBPPF_WAKEUP)) {
wakeup(mp);
serviced = 1;
}
- } /* for(each mbpp...) */
+ } /* for (each mbpp...) */
}
- return(serviced);
+ return (serviced);
}
/************************************************************************
@@ -816,33 +868,35 @@ int s, flags;
int
mtty_match(parent, vcf, args)
-struct device *parent;
-void *vcf, *args;
+ struct device *parent;
+ void *vcf, *args;
{
-struct magma_softc *sc = (struct magma_softc *)parent;
+ struct magma_softc *sc = (struct magma_softc *)parent;
- return( args == mtty_match && sc->ms_board->mb_nser && sc->ms_mtty == NULL );
+ return (args == mtty_match && sc->ms_board->mb_nser &&
+ sc->ms_mtty == NULL);
}
void
mtty_attach(parent, dev, args)
-struct device *parent;
-struct device *dev;
-void *args;
+ struct device *parent;
+ struct device *dev;
+ void *args;
{
-struct magma_softc *sc = (struct magma_softc *)parent;
-struct mtty_softc *ms = (struct mtty_softc *)dev;
-int port, chip, chan;
+ struct magma_softc *sc = (struct magma_softc *)parent;
+ struct mtty_softc *ms = (struct mtty_softc *)dev;
+ int port, chip, chan;
sc->ms_mtty = ms;
dprintf((" addr 0x%x", ms));
- for( port = 0, chip = 0, chan = 0 ; port < sc->ms_board->mb_nser ; port++ ) {
- struct mtty_port *mp = &ms->ms_port[port];
- struct tty *tp;
+ for (port = chip = chan = 0 ; port < sc->ms_board->mb_nser ; port++) {
+ struct mtty_port *mp = &ms->ms_port[port];
+ struct tty *tp;
mp->mp_cd1400 = &sc->ms_cd1400[chip];
- if( mp->mp_cd1400->cd_parmode && chan == 0 ) chan = 1; /* skip channel 0 if parmode */
+ if (mp->mp_cd1400->cd_parmode && chan == 0)
+ chan = 1; /* skip channel 0 if parmode */
mp->mp_channel = chan;
tp = ttymalloc();
@@ -852,12 +906,14 @@ int port, chip, chan;
mp->mp_tty = tp;
mp->mp_rbuf = malloc(MTTY_RBUF_SIZE, M_DEVBUF, M_NOWAIT);
- if( mp->mp_rbuf == NULL ) break;
+ if (mp->mp_rbuf == NULL)
+ break;
mp->mp_rend = mp->mp_rbuf + MTTY_RBUF_SIZE;
chan = (chan + 1) % CD1400_NO_OF_CHANNELS;
- if( chan == 0 ) chip++;
+ if (chan == 0)
+ chip++;
}
ms->ms_nports = port;
@@ -869,27 +925,28 @@ int port, chip, chan;
*/
int
mttyopen(dev, flags, mode, p)
-dev_t dev;
-int flags;
-int mode;
-struct proc *p;
+ dev_t dev;
+ int flags;
+ int mode;
+ struct proc *p;
{
-int card = MAGMA_CARD(dev);
-int port = MAGMA_PORT(dev);
-struct mtty_softc *ms;
-struct mtty_port *mp;
-struct tty *tp;
-struct cd1400 *cd;
-int s;
+ int card = MAGMA_CARD(dev);
+ int port = MAGMA_PORT(dev);
+ struct mtty_softc *ms;
+ struct mtty_port *mp;
+ struct tty *tp;
+ struct cd1400 *cd;
+ int s;
- if( card >= mtty_cd.cd_ndevs || (ms = mtty_cd.cd_devs[card]) == NULL || port >= ms->ms_nports )
- return(ENXIO); /* device not configured */
+ if (card >= mtty_cd.cd_ndevs || (ms = mtty_cd.cd_devs[card]) == NULL ||
+ port >= ms->ms_nports)
+ return (ENXIO); /* device not configured */
mp = &ms->ms_port[port];
tp = mp->mp_tty;
tp->t_dev = dev;
- if( !ISSET(tp->t_state, TS_ISOPEN) ) {
+ if (!ISSET(tp->t_state, TS_ISOPEN)) {
SET(tp->t_state, TS_WOPEN);
/* set defaults */
@@ -897,11 +954,11 @@ int s;
tp->t_iflag = TTYDEF_IFLAG;
tp->t_oflag = TTYDEF_OFLAG;
tp->t_cflag = TTYDEF_CFLAG;
- if( ISSET(mp->mp_openflags, TIOCFLAG_CLOCAL) )
+ if (ISSET(mp->mp_openflags, TIOCFLAG_CLOCAL))
SET(tp->t_cflag, CLOCAL);
- if( ISSET(mp->mp_openflags, TIOCFLAG_CRTSCTS) )
+ if (ISSET(mp->mp_openflags, TIOCFLAG_CRTSCTS))
SET(tp->t_cflag, CRTSCTS);
- if( ISSET(mp->mp_openflags, TIOCFLAG_MDMBUF) )
+ if (ISSET(mp->mp_openflags, TIOCFLAG_MDMBUF))
SET(tp->t_cflag, MDMBUF);
tp->t_lflag = TTYDEF_LFLAG;
tp->t_ispeed = tp->t_ospeed = TTYDEF_SPEED;
@@ -917,7 +974,7 @@ int s;
cd1400_write_ccr(cd, CD1400_CCR_CMDRESET);
/* encode the port number in top half of LIVR */
- cd1400_write_reg(cd, CD1400_LIVR, port << 4 );
+ cd1400_write_reg(cd, CD1400_LIVR, port << 4);
/* sets parameters and raises DTR */
(void)mtty_param(tp, &tp->t_termios);
@@ -926,37 +983,40 @@ int s;
ttsetwater(tp);
/* enable service requests */
- cd1400_write_reg(cd, CD1400_SRER, CD1400_SRER_RXDATA | CD1400_SRER_MDMCH);
+ cd1400_write_reg(cd, CD1400_SRER,
+ CD1400_SRER_RXDATA | CD1400_SRER_MDMCH);
/* tell the tty about the carrier status */
- if( ISSET(mp->mp_openflags, TIOCFLAG_SOFTCAR) || mp->mp_carrier )
+ if (ISSET(mp->mp_openflags, TIOCFLAG_SOFTCAR) || mp->mp_carrier)
SET(tp->t_state, TS_CARR_ON);
else
CLR(tp->t_state, TS_CARR_ON);
- } else if( ISSET(tp->t_state, TS_XCLUDE) && p->p_ucred->cr_uid != 0 ) {
- return(EBUSY); /* superuser can break exclusive access */
+ } else if (ISSET(tp->t_state, TS_XCLUDE) && p->p_ucred->cr_uid != 0) {
+ return (EBUSY); /* superuser can break exclusive access */
} else {
s = spltty();
}
/* wait for carrier if necessary */
- if( !ISSET(flags, O_NONBLOCK) ) {
- while( !ISSET(tp->t_cflag, CLOCAL) && !ISSET(tp->t_state, TS_CARR_ON) ) {
- int error;
+ if (!ISSET(flags, O_NONBLOCK)) {
+ while (!ISSET(tp->t_cflag, CLOCAL) &&
+ !ISSET(tp->t_state, TS_CARR_ON)) {
+ int error;
SET(tp->t_state, TS_WOPEN);
- error = ttysleep(tp, &tp->t_rawq, TTIPRI | PCATCH, "mttydcd", 0);
- if( error != 0 ) {
+ error = ttysleep(tp, &tp->t_rawq, TTIPRI | PCATCH,
+ "mttydcd", 0);
+ if (error != 0) {
splx(s);
CLR(tp->t_state, TS_WOPEN);
- return(error);
+ return (error);
}
}
}
splx(s);
- return( (*linesw[tp->t_line].l_open)(dev, tp) );
+ return ((*linesw[tp->t_line].l_open)(dev, tp));
}
/*
@@ -964,26 +1024,27 @@ int s;
*/
int
mttyclose(dev, flag, mode, p)
-dev_t dev;
-int flag;
-int mode;
-struct proc *p;
+ dev_t dev;
+ int flag;
+ int mode;
+ struct proc *p;
{
-struct mtty_softc *ms = mtty_cd.cd_devs[MAGMA_CARD(dev)];
-struct mtty_port *mp = &ms->ms_port[MAGMA_PORT(dev)];
-struct tty *tp = mp->mp_tty;
-int s;
+ struct mtty_softc *ms = mtty_cd.cd_devs[MAGMA_CARD(dev)];
+ struct mtty_port *mp = &ms->ms_port[MAGMA_PORT(dev)];
+ struct tty *tp = mp->mp_tty;
+ int s;
(*linesw[tp->t_line].l_close)(tp, flag);
s = spltty();
- /* if HUPCL is set, and the tty is no longer open
- * shut down the port
+ /*
+ * If HUPCL is set, and the tty is no longer open,
+ * shut down the port.
*/
- if( ISSET(tp->t_cflag, HUPCL) || !ISSET(tp->t_state, TS_ISOPEN) ) {
- /* XXX wait until FIFO is empty before turning off the channel
- struct cd1400 *cd = mp->mp_cd1400;
- */
+ if (ISSET(tp->t_cflag, HUPCL) || !ISSET(tp->t_state, TS_ISOPEN)) {
+ /* XXX wait until FIFO is empty before turning off the channel
+ struct cd1400 *cd = mp->mp_cd1400;
+ */
/* drop DTR and RTS */
(void)mtty_modem_control(mp, 0, DMSET);
@@ -997,7 +1058,7 @@ int s;
splx(s);
ttyclose(tp);
- return(0);
+ return (0);
}
/*
@@ -1005,15 +1066,15 @@ int s;
*/
int
mttyread(dev, uio, flags)
-dev_t dev;
-struct uio *uio;
-int flags;
+ dev_t dev;
+ struct uio *uio;
+ int flags;
{
-struct mtty_softc *ms = mtty_cd.cd_devs[MAGMA_CARD(dev)];
-struct mtty_port *mp = &ms->ms_port[MAGMA_PORT(dev)];
-struct tty *tp = mp->mp_tty;
+ struct mtty_softc *ms = mtty_cd.cd_devs[MAGMA_CARD(dev)];
+ struct mtty_port *mp = &ms->ms_port[MAGMA_PORT(dev)];
+ struct tty *tp = mp->mp_tty;
- return( (*linesw[tp->t_line].l_read)(tp, uio, flags) );
+ return ((*linesw[tp->t_line].l_read)(tp, uio, flags));
}
/*
@@ -1021,15 +1082,15 @@ struct tty *tp = mp->mp_tty;
*/
int
mttywrite(dev, uio, flags)
-dev_t dev;
-struct uio *uio;
-int flags;
+ dev_t dev;
+ struct uio *uio;
+ int flags;
{
-struct mtty_softc *ms = mtty_cd.cd_devs[MAGMA_CARD(dev)];
-struct mtty_port *mp = &ms->ms_port[MAGMA_PORT(dev)];
-struct tty *tp = mp->mp_tty;
+ struct mtty_softc *ms = mtty_cd.cd_devs[MAGMA_CARD(dev)];
+ struct mtty_port *mp = &ms->ms_port[MAGMA_PORT(dev)];
+ struct tty *tp = mp->mp_tty;
- return( (*linesw[tp->t_line].l_write)(tp, uio, flags) );
+ return ((*linesw[tp->t_line].l_write)(tp, uio, flags));
}
/*
@@ -1037,12 +1098,12 @@ struct tty *tp = mp->mp_tty;
*/
struct tty *
mttytty(dev)
-dev_t dev;
+ dev_t dev;
{
-struct mtty_softc *ms = mtty_cd.cd_devs[MAGMA_CARD(dev)];
-struct mtty_port *mp = &ms->ms_port[MAGMA_PORT(dev)];
+ struct mtty_softc *ms = mtty_cd.cd_devs[MAGMA_CARD(dev)];
+ struct mtty_port *mp = &ms->ms_port[MAGMA_PORT(dev)];
- return(mp->mp_tty);
+ return (mp->mp_tty);
}
/*
@@ -1050,22 +1111,24 @@ struct mtty_port *mp = &ms->ms_port[MAGMA_PORT(dev)];
*/
int
mttyioctl(dev, cmd, data, flags, p)
-dev_t dev;
-u_long cmd;
-caddr_t data;
-int flags;
-struct proc *p;
+ dev_t dev;
+ u_long cmd;
+ caddr_t data;
+ int flags;
+ struct proc *p;
{
-struct mtty_softc *ms = mtty_cd.cd_devs[MAGMA_CARD(dev)];
-struct mtty_port *mp = &ms->ms_port[MAGMA_PORT(dev)];
-struct tty *tp = mp->mp_tty;
-int error;
+ struct mtty_softc *ms = mtty_cd.cd_devs[MAGMA_CARD(dev)];
+ struct mtty_port *mp = &ms->ms_port[MAGMA_PORT(dev)];
+ struct tty *tp = mp->mp_tty;
+ int error;
error = (*linesw[tp->t_line].l_ioctl)(tp, cmd, data, flags, p);
- if( error >= 0 ) return(error);
+ if (error >= 0)
+ return (error);
error = ttioctl(tp, cmd, data, flags, p);
- if( error >= 0 ) return(error);
+ if (error >= 0)
+ return (error);
error = 0;
@@ -1109,7 +1172,7 @@ int error;
break;
case TIOCSFLAGS:
- if( suser(p, 0) )
+ if (suser(p, 0))
error = EPERM;
else
mp->mp_openflags = *((int *)data) &
@@ -1121,7 +1184,7 @@ int error;
error = ENOTTY;
}
- return(error);
+ return (error);
}
/*
@@ -1129,17 +1192,17 @@ int error;
*/
int
mttystop(tp, flags)
-struct tty *tp;
-int flags;
+ struct tty *tp;
+ int flags;
{
-struct mtty_softc *ms = mtty_cd.cd_devs[MAGMA_CARD(tp->t_dev)];
-struct mtty_port *mp = &ms->ms_port[MAGMA_PORT(tp->t_dev)];
-int s;
+ struct mtty_softc *ms = mtty_cd.cd_devs[MAGMA_CARD(tp->t_dev)];
+ struct mtty_port *mp = &ms->ms_port[MAGMA_PORT(tp->t_dev)];
+ int s;
s = spltty();
- if( ISSET(tp->t_state, TS_BUSY) ) {
- if( !ISSET(tp->t_state, TS_TTSTOP) )
+ if (ISSET(tp->t_state, TS_BUSY)) {
+ if (!ISSET(tp->t_state, TS_TTSTOP))
SET(tp->t_state, TS_FLUSH);
/*
@@ -1150,7 +1213,7 @@ int s;
}
splx(s);
- return(0);
+ return (0);
}
/*
@@ -1158,24 +1221,26 @@ int s;
*/
void
mtty_start(tp)
-struct tty *tp;
+ struct tty *tp;
{
-struct mtty_softc *ms = mtty_cd.cd_devs[MAGMA_CARD(tp->t_dev)];
-struct mtty_port *mp = &ms->ms_port[MAGMA_PORT(tp->t_dev)];
-int s;
+ struct mtty_softc *ms = mtty_cd.cd_devs[MAGMA_CARD(tp->t_dev)];
+ struct mtty_port *mp = &ms->ms_port[MAGMA_PORT(tp->t_dev)];
+ int s;
s = spltty();
- /* we only need to do something if we are not already busy
- * or delaying or stopped
+ /*
+ * We only need to do something if we are not already busy
+ * or delaying or stopped.
*/
- if( !ISSET(tp->t_state, TS_TTSTOP | TS_TIMEOUT | TS_BUSY) ) {
+ if (!ISSET(tp->t_state, TS_TTSTOP | TS_TIMEOUT | TS_BUSY)) {
- /* if we are sleeping and output has drained below
- * low water mark, awaken
+ /*
+ * If we are sleeping and output has drained below
+ * low water mark, awaken.
*/
- if( tp->t_outq.c_cc <= tp->t_lowat ) {
- if( ISSET(tp->t_state, TS_ASLEEP) ) {
+ if (tp->t_outq.c_cc <= tp->t_lowat) {
+ if (ISSET(tp->t_state, TS_ASLEEP)) {
CLR(tp->t_state, TS_ASLEEP);
wakeup(&tp->t_outq);
}
@@ -1183,13 +1248,15 @@ int s;
selwakeup(&tp->t_wsel);
}
- /* if something to send, start transmitting
+ /*
+ * If there is something to send, start transmitting.
*/
- if( tp->t_outq.c_cc ) {
+ if (tp->t_outq.c_cc) {
mp->mp_txc = ndqb(&tp->t_outq, 0);
mp->mp_txp = tp->t_outq.c_cf;
SET(tp->t_state, TS_BUSY);
- cd1400_enable_transmitter(mp->mp_cd1400, mp->mp_channel);
+ cd1400_enable_transmitter(mp->mp_cd1400,
+ mp->mp_channel);
}
}
@@ -1208,13 +1275,13 @@ int s;
*/
int
mtty_modem_control(mp, bits, howto)
-struct mtty_port *mp;
-int bits;
-int howto;
+ struct mtty_port *mp;
+ int bits;
+ int howto;
{
-struct cd1400 *cd = mp->mp_cd1400;
-struct tty *tp = mp->mp_tty;
-int s, msvr;
+ struct cd1400 *cd = mp->mp_cd1400;
+ struct tty *tp = mp->mp_tty;
+ int s, msvr;
s = spltty();
@@ -1227,46 +1294,54 @@ int s, msvr;
bits |= TIOCM_LE;
msvr = cd1400_read_reg(cd, CD1400_MSVR1);
- if( msvr & CD1400_MSVR1_RTS ) bits |= TIOCM_DTR;
+ if (msvr & CD1400_MSVR1_RTS)
+ bits |= TIOCM_DTR;
msvr = cd1400_read_reg(cd, CD1400_MSVR2);
- if( msvr & CD1400_MSVR2_DTR ) bits |= TIOCM_RTS;
- if( msvr & CD1400_MSVR2_CTS ) bits |= TIOCM_CTS;
- if( msvr & CD1400_MSVR2_RI ) bits |= TIOCM_RI;
- if( msvr & CD1400_MSVR2_DSR ) bits |= (cd->cd_parmode ? TIOCM_CD : TIOCM_DSR);
- if( msvr & CD1400_MSVR2_CD ) bits |= (cd->cd_parmode ? 0 : TIOCM_CD);
+ if (msvr & CD1400_MSVR2_DTR)
+ bits |= TIOCM_RTS;
+ if (msvr & CD1400_MSVR2_CTS)
+ bits |= TIOCM_CTS;
+ if (msvr & CD1400_MSVR2_RI)
+ bits |= TIOCM_RI;
+ if (msvr & CD1400_MSVR2_DSR)
+ bits |= (cd->cd_parmode ? TIOCM_CD : TIOCM_DSR);
+ if (msvr & CD1400_MSVR2_CD)
+ bits |= (cd->cd_parmode ? 0 : TIOCM_CD);
break;
case DMSET: /* reset bits */
- if( !ISSET(tp->t_cflag, CRTSCTS) )
- cd1400_write_reg(cd, CD1400_MSVR2, ((bits & TIOCM_RTS) ? CD1400_MSVR2_DTR : 0));
+ if (!ISSET(tp->t_cflag, CRTSCTS))
+ cd1400_write_reg(cd, CD1400_MSVR2,
+ ((bits & TIOCM_RTS) ? CD1400_MSVR2_DTR : 0));
- cd1400_write_reg(cd, CD1400_MSVR1, ((bits & TIOCM_DTR) ? CD1400_MSVR1_RTS : 0));
+ cd1400_write_reg(cd, CD1400_MSVR1,
+ ((bits & TIOCM_DTR) ? CD1400_MSVR1_RTS : 0));
break;
case DMBIS: /* set bits */
- if( (bits & TIOCM_RTS) && !ISSET(tp->t_cflag, CRTSCTS) )
+ if ((bits & TIOCM_RTS) && !ISSET(tp->t_cflag, CRTSCTS))
cd1400_write_reg(cd, CD1400_MSVR2, CD1400_MSVR2_DTR);
- if( bits & TIOCM_DTR )
+ if (bits & TIOCM_DTR)
cd1400_write_reg(cd, CD1400_MSVR1, CD1400_MSVR1_RTS);
break;
case DMBIC: /* clear bits */
- if( (bits & TIOCM_RTS) && !ISSET(tp->t_cflag, CRTSCTS) )
+ if ((bits & TIOCM_RTS) && !ISSET(tp->t_cflag, CRTSCTS))
cd1400_write_reg(cd, CD1400_MSVR2, 0);
- if( bits & TIOCM_DTR )
+ if (bits & TIOCM_DTR)
cd1400_write_reg(cd, CD1400_MSVR1, 0);
break;
}
splx(s);
- return(bits);
+ return (bits);
}
/*
@@ -1274,38 +1349,41 @@ int s, msvr;
*/
int
mtty_param(tp, t)
-struct tty *tp;
-struct termios *t;
+ struct tty *tp;
+ struct termios *t;
{
-struct mtty_softc *ms = mtty_cd.cd_devs[MAGMA_CARD(tp->t_dev)];
-struct mtty_port *mp = &ms->ms_port[MAGMA_PORT(tp->t_dev)];
-struct cd1400 *cd = mp->mp_cd1400;
-int rbpr, tbpr, rcor, tcor;
-u_char mcor1 = 0, mcor2 = 0;
-int s, opt;
+ struct mtty_softc *ms = mtty_cd.cd_devs[MAGMA_CARD(tp->t_dev)];
+ struct mtty_port *mp = &ms->ms_port[MAGMA_PORT(tp->t_dev)];
+ struct cd1400 *cd = mp->mp_cd1400;
+ int rbpr, tbpr, rcor, tcor;
+ u_char mcor1 = 0, mcor2 = 0;
+ int s, opt;
- if( t->c_ospeed && cd1400_compute_baud(t->c_ospeed, cd->cd_clock, &tcor, &tbpr) )
- return(EINVAL);
+ if (t->c_ospeed &&
+ cd1400_compute_baud(t->c_ospeed, cd->cd_clock, &tcor, &tbpr))
+ return (EINVAL);
- if( t->c_ispeed && cd1400_compute_baud(t->c_ispeed, cd->cd_clock, &rcor, &rbpr) )
- return(EINVAL);
+ if (t->c_ispeed &&
+ cd1400_compute_baud(t->c_ispeed, cd->cd_clock, &rcor, &rbpr))
+ return (EINVAL);
s = spltty();
/* hang up the line if ospeed is zero, else raise DTR */
- (void)mtty_modem_control(mp, TIOCM_DTR, (t->c_ospeed == 0 ? DMBIC : DMBIS));
+ (void)mtty_modem_control(mp, TIOCM_DTR,
+ (t->c_ospeed == 0 ? DMBIC : DMBIS));
/* select channel, done in mtty_modem_control() */
/* cd1400_write_reg(cd, CD1400_CAR, mp->mp_channel); */
/* set transmit speed */
- if( t->c_ospeed ) {
+ if (t->c_ospeed) {
cd1400_write_reg(cd, CD1400_TCOR, tcor);
cd1400_write_reg(cd, CD1400_TBPR, tbpr);
}
/* set receive speed */
- if( t->c_ispeed ) {
+ if (t->c_ispeed) {
cd1400_write_reg(cd, CD1400_RCOR, rcor);
cd1400_write_reg(cd, CD1400_RBPR, rbpr);
}
@@ -1316,16 +1394,17 @@ int s, opt;
/* set parity, data and stop bits */
opt = 0;
- if( ISSET(t->c_cflag, PARENB) )
- opt |= (ISSET(t->c_cflag, PARODD) ? CD1400_COR1_PARODD : CD1400_COR1_PARNORMAL);
+ if (ISSET(t->c_cflag, PARENB))
+ opt |= (ISSET(t->c_cflag, PARODD) ?
+ CD1400_COR1_PARODD : CD1400_COR1_PARNORMAL);
- if( !ISSET(t->c_iflag, INPCK) )
+ if (!ISSET(t->c_iflag, INPCK))
opt |= CD1400_COR1_NOINPCK; /* no parity checking */
- if( ISSET(t->c_cflag, CSTOPB) )
+ if (ISSET(t->c_cflag, CSTOPB))
opt |= CD1400_COR1_STOP2;
- switch( t->c_cflag & CSIZE ) {
+ switch (t->c_cflag & CSIZE) {
case CS5:
opt |= CD1400_COR1_CS5;
break;
@@ -1350,12 +1429,14 @@ int s, opt;
* use the CD1400 automatic CTS flow control if CRTSCTS is set
*/
opt = CD1400_COR2_ETC;
- if( ISSET(t->c_cflag, CRTSCTS) ) opt |= CD1400_COR2_CCTS_OFLOW;
+ if (ISSET(t->c_cflag, CRTSCTS))
+ opt |= CD1400_COR2_CCTS_OFLOW;
cd1400_write_reg(cd, CD1400_COR2, opt);
cd1400_write_reg(cd, CD1400_COR3, MTTY_RX_FIFO_THRESHOLD);
- cd1400_write_ccr(cd, CD1400_CCR_CMDCORCHG | CD1400_CCR_COR1 | CD1400_CCR_COR2 | CD1400_CCR_COR3);
+ cd1400_write_ccr(cd, CD1400_CCR_CMDCORCHG | CD1400_CCR_COR1 |
+ CD1400_CCR_COR2 | CD1400_CCR_COR3);
cd1400_write_reg(cd, CD1400_COR4, CD1400_COR4_PFO_EXCEPTION);
cd1400_write_reg(cd, CD1400_COR5, 0);
@@ -1364,11 +1445,11 @@ int s, opt;
* if automatic RTS handshaking enabled, set DTR threshold
* (RTS and DTR lines are switched, CD1400 thinks its DTR)
*/
- if( ISSET(t->c_cflag, CRTSCTS) )
+ if (ISSET(t->c_cflag, CRTSCTS))
mcor1 = MTTY_RX_DTR_THRESHOLD;
/* set up `carrier detect' interrupts */
- if( cd->cd_parmode ) {
+ if (cd->cd_parmode) {
SET(mcor1, CD1400_MCOR1_DSRzd);
SET(mcor2, CD1400_MCOR2_DSRod);
} else {
@@ -1383,7 +1464,7 @@ int s, opt;
cd1400_write_reg(cd, CD1400_RTPR, 2);
splx(s);
- return(0);
+ return (0);
}
/************************************************************************
@@ -1407,32 +1488,33 @@ int s, opt;
int
mbpp_match(parent, vcf, args)
-struct device *parent;
-void *vcf, *args;
+ struct device *parent;
+ void *vcf, *args;
{
-register struct magma_softc *sc = (struct magma_softc *)parent;
+ register struct magma_softc *sc = (struct magma_softc *)parent;
- return( args == mbpp_match && sc->ms_board->mb_npar && sc->ms_mbpp == NULL );
+ return (args == mbpp_match && sc->ms_board->mb_npar &&
+ sc->ms_mbpp == NULL);
}
void
mbpp_attach(parent, dev, args)
-struct device *parent;
-struct device *dev;
-void *args;
+ struct device *parent;
+ struct device *dev;
+ void *args;
{
-struct magma_softc *sc = (struct magma_softc *)parent;
-struct mbpp_softc *ms = (struct mbpp_softc *)dev;
-struct mbpp_port *mp;
-int port;
+ struct magma_softc *sc = (struct magma_softc *)parent;
+ struct mbpp_softc *ms = (struct mbpp_softc *)dev;
+ struct mbpp_port *mp;
+ int port;
sc->ms_mbpp = ms;
dprintf((" addr 0x%x", ms));
- for( port = 0 ; port < sc->ms_board->mb_npar ; port++ ) {
+ for (port = 0 ; port < sc->ms_board->mb_npar ; port++) {
mp = &ms->ms_port[port];
- if( sc->ms_ncd1190 )
+ if (sc->ms_ncd1190)
mp->mp_cd1190 = &sc->ms_cd1190[port];
else
mp->mp_cd1400 = &sc->ms_cd1400[0];
@@ -1450,26 +1532,27 @@ int port;
*/
int
mbppopen(dev, flags, mode, p)
-dev_t dev;
-int flags;
-int mode;
-struct proc *p;
+ dev_t dev;
+ int flags;
+ int mode;
+ struct proc *p;
{
-int card = MAGMA_CARD(dev);
-int port = MAGMA_PORT(dev);
-struct mbpp_softc *ms;
-struct mbpp_port *mp;
-int s;
+ int card = MAGMA_CARD(dev);
+ int port = MAGMA_PORT(dev);
+ struct mbpp_softc *ms;
+ struct mbpp_port *mp;
+ int s;
- if( card >= mbpp_cd.cd_ndevs || (ms = mbpp_cd.cd_devs[card]) == NULL || port >= ms->ms_nports )
- return(ENXIO);
+ if (card >= mbpp_cd.cd_ndevs || (ms = mbpp_cd.cd_devs[card]) == NULL ||
+ port >= ms->ms_nports)
+ return (ENXIO);
mp = &ms->ms_port[port];
s = spltty();
- if( ISSET(mp->mp_flags, MBPPF_OPEN) ) {
+ if (ISSET(mp->mp_flags, MBPPF_OPEN)) {
splx(s);
- return(EBUSY);
+ return (EBUSY);
}
SET(mp->mp_flags, MBPPF_OPEN);
splx(s);
@@ -1480,21 +1563,21 @@ int s;
mp->mp_delay = mbpp_mstohz(BPP_DELAY);
/* init chips */
- if( mp->mp_cd1400 ) { /* CD1400 */
- struct cd1400 *cd = mp->mp_cd1400;
+ if (mp->mp_cd1400) { /* CD1400 */
+ struct cd1400 *cd = mp->mp_cd1400;
/* set up CD1400 channel */
s = spltty();
cd1400_write_reg(cd, CD1400_CAR, 0);
cd1400_write_ccr(cd, CD1400_CCR_CMDRESET);
- cd1400_write_reg(cd, CD1400_LIVR, (1<<3));
+ cd1400_write_reg(cd, CD1400_LIVR, (1 << 3));
splx(s);
} else { /* CD1190 */
mp->mp_flags = 0;
- return(ENXIO);
+ return (ENXIO);
}
- return(0);
+ return (0);
}
/*
@@ -1502,16 +1585,16 @@ int s;
*/
int
mbppclose(dev, flag, mode, p)
-dev_t dev;
-int flag;
-int mode;
-struct proc *p;
+ dev_t dev;
+ int flag;
+ int mode;
+ struct proc *p;
{
-struct mbpp_softc *ms = mbpp_cd.cd_devs[MAGMA_CARD(dev)];
-struct mbpp_port *mp = &ms->ms_port[MAGMA_PORT(dev)];
+ struct mbpp_softc *ms = mbpp_cd.cd_devs[MAGMA_CARD(dev)];
+ struct mbpp_port *mp = &ms->ms_port[MAGMA_PORT(dev)];
mp->mp_flags = 0;
- return(0);
+ return (0);
}
/*
@@ -1519,11 +1602,11 @@ struct mbpp_port *mp = &ms->ms_port[MAGMA_PORT(dev)];
*/
int
mbppread(dev, uio, flags)
-dev_t dev;
-struct uio *uio;
-int flags;
+ dev_t dev;
+ struct uio *uio;
+ int flags;
{
- return( mbpp_rw(dev, uio) );
+ return (mbpp_rw(dev, uio));
}
/*
@@ -1531,11 +1614,11 @@ int flags;
*/
int
mbppwrite(dev, uio, flags)
-dev_t dev;
-struct uio *uio;
-int flags;
+ dev_t dev;
+ struct uio *uio;
+ int flags;
{
- return( mbpp_rw(dev, uio) );
+ return (mbpp_rw(dev, uio));
}
/*
@@ -1543,23 +1626,25 @@ int flags;
*/
int
mbppioctl(dev, cmd, data, flags, p)
-dev_t dev;
-u_long cmd;
-caddr_t data;
-int flags;
-struct proc *p;
+ dev_t dev;
+ u_long cmd;
+ caddr_t data;
+ int flags;
+ struct proc *p;
{
-struct mbpp_softc *ms = mbpp_cd.cd_devs[MAGMA_CARD(dev)];
-register struct mbpp_port *mp = &ms->ms_port[MAGMA_PORT(dev)];
-struct bpp_param *bp;
-int error = 0;
-int s;
+ struct mbpp_softc *ms = mbpp_cd.cd_devs[MAGMA_CARD(dev)];
+ register struct mbpp_port *mp = &ms->ms_port[MAGMA_PORT(dev)];
+ struct bpp_param *bp;
+ int error = 0;
+ int s;
switch(cmd) {
case BPPIOCSPARAM:
bp = (struct bpp_param *)data;
- if( bp->bp_burst < BPP_BURST_MIN || bp->bp_burst > BPP_BURST_MAX ||
- bp->bp_delay < BPP_DELAY_MIN || bp->bp_delay > BPP_DELAY_MIN ) {
+ if (bp->bp_burst < BPP_BURST_MIN ||
+ bp->bp_burst > BPP_BURST_MAX ||
+ bp->bp_delay < BPP_DELAY_MIN ||
+ bp->bp_delay > BPP_DELAY_MIN) {
error = EINVAL;
} else {
mp->mp_burst = bp->bp_burst;
@@ -1584,7 +1669,7 @@ int s;
error = ENOTTY;
}
- return(error);
+ return (error);
}
/*
@@ -1592,29 +1677,29 @@ int s;
*/
int
mbpppoll(dev, events, p)
-dev_t dev;
-int events;
-struct proc *p;
+ dev_t dev;
+ int events;
+ struct proc *p;
{
- return(seltrue(dev, events, p));
+ return (seltrue(dev, events, p));
}
int
mbpp_rw(dev, uio)
-dev_t dev;
-struct uio *uio;
+ dev_t dev;
+ struct uio *uio;
{
-int card = MAGMA_CARD(dev);
-int port = MAGMA_PORT(dev);
-struct mbpp_softc *ms = mbpp_cd.cd_devs[card];
-register struct mbpp_port *mp = &ms->ms_port[port];
-caddr_t buffer, ptr;
-int buflen, cnt, len;
-int s, error = 0;
-int gotdata = 0;
-
- if( uio->uio_resid == 0 )
- return(0);
+ int card = MAGMA_CARD(dev);
+ int port = MAGMA_PORT(dev);
+ struct mbpp_softc *ms = mbpp_cd.cd_devs[card];
+ register struct mbpp_port *mp = &ms->ms_port[port];
+ caddr_t buffer, ptr;
+ int buflen, cnt, len;
+ int s, error = 0;
+ int gotdata = 0;
+
+ if (uio->uio_resid == 0)
+ return (0);
buflen = min(uio->uio_resid, mp->mp_burst);
buffer = malloc(buflen, M_DEVBUF, M_WAITOK);
@@ -1624,64 +1709,68 @@ int gotdata = 0;
/*
* start timeout, if needed
*/
- if( mp->mp_timeout > 0 ) {
+ if (mp->mp_timeout > 0) {
SET(mp->mp_flags, MBPPF_TIMEOUT);
timeout_add(&mp->mp_timeout_tmo, mp->mp_timeout);
}
len = cnt = 0;
- while( uio->uio_resid > 0 ) {
+ while (uio->uio_resid > 0) {
len = min(buflen, uio->uio_resid);
ptr = buffer;
- if( uio->uio_rw == UIO_WRITE ) {
+ if (uio->uio_rw == UIO_WRITE) {
error = uiomove(ptr, len, uio);
- if( error ) break;
+ if (error)
+ break;
}
again: /* goto bad */
/* timed out? */
- if( !ISSET(mp->mp_flags, MBPPF_UIO) )
+ if (!ISSET(mp->mp_flags, MBPPF_UIO))
break;
/*
* perform the operation
*/
- if( uio->uio_rw == UIO_WRITE ) {
+ if (uio->uio_rw == UIO_WRITE) {
cnt = mbpp_send(mp, ptr, len);
} else {
cnt = mbpp_recv(mp, ptr, len);
}
- if( uio->uio_rw == UIO_READ ) {
- if( cnt ) {
+ if (uio->uio_rw == UIO_READ) {
+ if (cnt) {
error = uiomove(ptr, cnt, uio);
- if( error ) break;
+ if (error)
+ break;
gotdata++;
}
- else if( gotdata ) /* consider us done */
+ else if (gotdata) /* consider us done */
break;
}
/* timed out? */
- if( !ISSET(mp->mp_flags, MBPPF_UIO) )
+ if (!ISSET(mp->mp_flags, MBPPF_UIO))
break;
/*
* poll delay?
*/
- if( mp->mp_delay > 0 ) {
+ if (mp->mp_delay > 0) {
s = spltty(); /* XXX */
SET(mp->mp_flags, MBPPF_DELAY);
timeout_add(&mp->mp_start_tmo, mp->mp_delay);
error = tsleep(mp, PCATCH | PZERO, "mbppdelay", 0);
splx(s);
- if( error ) break;
+ if (error)
+ break;
}
/*
- * don't call uiomove again until we used all the data we grabbed
+ * Don't call uiomove again until we used all the data we
+ * grabbed.
*/
- if( uio->uio_rw == UIO_WRITE && cnt != len ) {
+ if (uio->uio_rw == UIO_WRITE && cnt != len) {
ptr += cnt;
len -= cnt;
cnt = 0;
@@ -1693,32 +1782,32 @@ again: /* goto bad */
* clear timeouts
*/
s = spltty(); /* XXX */
- if( ISSET(mp->mp_flags, MBPPF_TIMEOUT) ) {
+ if (ISSET(mp->mp_flags, MBPPF_TIMEOUT)) {
timeout_del(&mp->mp_timeout_tmo);
CLR(mp->mp_flags, MBPPF_TIMEOUT);
}
- if( ISSET(mp->mp_flags, MBPPF_DELAY) ) {
+ if (ISSET(mp->mp_flags, MBPPF_DELAY)) {
timeout_del(&mp->mp_start_tmo);
CLR(mp->mp_flags, MBPPF_DELAY);
}
splx(s);
/*
- * adjust for those chars that we uiomoved but never actually wrote
+ * Adjust for those chars that we uiomoved but never actually wrote.
*/
- if( uio->uio_rw == UIO_WRITE && cnt != len ) {
+ if (uio->uio_rw == UIO_WRITE && cnt != len) {
uio->uio_resid += (len - cnt);
}
free(buffer, M_DEVBUF);
- return(error);
+ return (error);
}
void
mbpp_timeout(arg)
-void *arg;
+ void *arg;
{
-struct mbpp_port *mp = arg;
+ struct mbpp_port *mp = arg;
CLR(mp->mp_flags, MBPPF_UIO | MBPPF_TIMEOUT);
wakeup(mp);
@@ -1726,9 +1815,9 @@ struct mbpp_port *mp = arg;
void
mbpp_start(arg)
-void *arg;
+ void *arg;
{
-struct mbpp_port *mp = arg;
+ struct mbpp_port *mp = arg;
CLR(mp->mp_flags, MBPPF_DELAY);
wakeup(mp);
@@ -1736,12 +1825,12 @@ struct mbpp_port *mp = arg;
int
mbpp_send(mp, ptr, len)
-struct mbpp_port *mp;
-caddr_t ptr;
-int len;
+ struct mbpp_port *mp;
+ caddr_t ptr;
+ int len;
{
-int s;
-struct cd1400 *cd = mp->mp_cd1400;
+ int s;
+ struct cd1400 *cd = mp->mp_cd1400;
/* set up io information */
mp->mp_ptr = ptr;
@@ -1749,7 +1838,7 @@ struct cd1400 *cd = mp->mp_cd1400;
/* start transmitting */
s = spltty();
- if( cd ) {
+ if (cd) {
cd1400_write_reg(cd, CD1400_CAR, 0);
/* output strobe width ~1microsecond */
@@ -1760,11 +1849,11 @@ struct cd1400 *cd = mp->mp_cd1400;
cd1400_write_reg(cd, CD1400_SRER, CD1400_SRER_TXRDY);
}
- /* ZZzzz... */
+ /* zzz... */
tsleep(mp, PCATCH | PZERO, "mbpp_send", 0);
/* stop transmitting */
- if( cd ) {
+ if (cd) {
cd1400_write_reg(cd, CD1400_CAR, 0);
/* disable transmitter */
@@ -1777,17 +1866,17 @@ struct cd1400 *cd = mp->mp_cd1400;
splx(s);
/* return number of chars sent */
- return(len - mp->mp_cnt);
+ return (len - mp->mp_cnt);
}
int
mbpp_recv(mp, ptr, len)
-struct mbpp_port *mp;
-caddr_t ptr;
-int len;
+ struct mbpp_port *mp;
+ caddr_t ptr;
+ int len;
{
-int s;
-struct cd1400 *cd = mp->mp_cd1400;
+ int s;
+ struct cd1400 *cd = mp->mp_cd1400;
/* set up io information */
mp->mp_ptr = ptr;
@@ -1795,8 +1884,8 @@ struct cd1400 *cd = mp->mp_cd1400;
/* start receiving */
s = spltty();
- if( cd ) {
- int rcor, rbpr;
+ if (cd) {
+ int rcor, rbpr;
cd1400_write_reg(cd, CD1400_CAR, 0);
@@ -1814,11 +1903,11 @@ struct cd1400 *cd = mp->mp_cd1400;
cd1400_write_reg(cd, CD1400_SRER, CD1400_SRER_RXDATA);
}
- /* ZZzzz... */
+ /* zzz... */
tsleep(mp, PCATCH | PZERO, "mbpp_recv", 0);
/* stop receiving */
- if( cd ) {
+ if (cd) {
cd1400_write_reg(cd, CD1400_CAR, 0);
/* disable receiving */
@@ -1828,32 +1917,30 @@ struct cd1400 *cd = mp->mp_cd1400;
splx(s);
/* return number of chars received */
- return(len - mp->mp_cnt);
+ return (len - mp->mp_cnt);
}
int
mbpp_hztoms(h)
-int h;
+ int h;
{
-int m = h;
+ int m = h;
- if( m > 0 )
+ if (m > 0)
m = m * 1000 / hz;
- return(m);
+ return (m);
}
int
mbpp_mstohz(m)
-int m;
+ int m;
{
-int h = m;
+ int h = m;
- if( h > 0 ) {
+ if (h > 0) {
h = h * hz / 1000;
- if( h == 0 )
+ if (h == 0)
h = 1000 / hz;
}
- return(h);
+ return (h);
}
-
-#endif /* NMAGMA */
diff --git a/sys/arch/sparc/dev/magmareg.h b/sys/arch/sparc/dev/magmareg.h
index 35d3b9cfdbe..34a9c5c242b 100644
--- a/sys/arch/sparc/dev/magmareg.h
+++ b/sys/arch/sparc/dev/magmareg.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: magmareg.h,v 1.8 2003/02/11 19:20:26 mickey Exp $ */
+/* $OpenBSD: magmareg.h,v 1.9 2004/11/02 21:16:10 miod Exp $ */
/* magmareg.h
*
@@ -32,12 +32,6 @@
*
*/
-#ifdef MAGMA_DEBUG
-#define dprintf(x) printf x
-#else
-#define dprintf(x)
-#endif
-
/* The mapping of minor device number -> card and port is done as
* follows by default:
*
@@ -117,7 +111,7 @@ struct magma_softc {
int ms_ncd1190;
struct cd1190 ms_cd1190[MAGMA_MAX_CD1190];
- struct magma_board_info *ms_board; /* what am I? */
+ const struct magma_board_info *ms_board; /* what am I? */
struct mtty_softc *ms_mtty;
struct mbpp_softc *ms_mbpp;