summaryrefslogtreecommitdiff
path: root/sys/arch/mvme88k/dev/vx.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/mvme88k/dev/vx.c')
-rw-r--r--sys/arch/mvme88k/dev/vx.c65
1 files changed, 21 insertions, 44 deletions
diff --git a/sys/arch/mvme88k/dev/vx.c b/sys/arch/mvme88k/dev/vx.c
index b0ed05470b9..fdb2366c631 100644
--- a/sys/arch/mvme88k/dev/vx.c
+++ b/sys/arch/mvme88k/dev/vx.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: vx.c,v 1.4 2001/01/25 03:50:48 todd Exp $ */
+/* $OpenBSD: vx.c,v 1.5 2001/03/07 23:45:52 miod Exp $ */
/*
* Copyright (c) 1999 Steve Murphree, Jr.
* All rights reserved.
@@ -108,7 +108,7 @@ void read_wakeup __P((struct vxsoftc *sc, int port));
int bpp_send __P((struct vxsoftc *sc, void *pkt, int wait_flag));
int create_channels __P((struct vxsoftc *sc));
-void *memcpy2 __P((void *dest, const void *src, size_t size));
+void memcpy2 __P((void *dest, const void *src, size_t size));
void *get_free_envelope __P((struct vxsoftc *sc));
void put_free_envelope __P((struct vxsoftc *sc, void *envp));
void *get_free_packet __P((struct vxsoftc *sc));
@@ -121,7 +121,7 @@ void vx_unblock __P((struct tty *tp));
int vx_ccparam __P((struct vxsoftc *sc, struct termios *par, int port));
int vx_param __P((struct tty *tp, struct termios *t));
-int vx_intr __P((struct vxsoftc *sc));
+int vx_intr __P((void * arg));
int vx_sintr __P((struct vxsoftc *sc));
int vx_poll __P((struct vxsoftc *sc, struct packet *wpktp));
void vx_overflow __P((struct vxsoftc *sc, int port, long *ptime, u_char *msg));
@@ -141,7 +141,6 @@ void vxstart __P((struct tty *tp));
int vxstop __P((struct tty *tp, int flag));
static void vxputc __P((struct vxsoftc *sc, int port, u_char c));
-static u_char vxgetc __P((struct vxsoftc *sc, int *port));
struct cfattach vx_ca = {
sizeof(struct vxsoftc), vxmatch, vxattach
@@ -179,9 +178,8 @@ void *self;
void *aux;
{
struct vxreg *vx_reg;
- struct vxsoftc *sc = self;
struct confargs *ca = aux;
- int ret;
+
if (cputyp != CPU_187)
return 0;
#ifdef OLD_MAPPINGS
@@ -211,7 +209,6 @@ void *aux;
{
struct vxsoftc *sc = (struct vxsoftc *)self;
struct confargs *ca = aux;
- int i;
/* set up dual port memory and registers and init*/
sc->vx_reg = (struct vxreg *)ca->ca_vaddr;
@@ -238,8 +235,8 @@ void *aux;
/* enable interrupts */
sc->sc_ih_c.ih_fn = vx_intr;
sc->sc_ih_c.ih_arg = sc;
- sc->sc_ih_c.ih_ipl = ca->ca_ipl;
sc->sc_ih_c.ih_wantframe = 0;
+ sc->sc_ih_c.ih_ipl = ca->ca_ipl;
vmeintr_establish(ca->ca_vec, &sc->sc_ih_c);
evcnt_attach(&sc->sc_dev, "intr", &sc->sc_intrcnt);
@@ -247,6 +244,7 @@ void *aux;
int vxtdefaultrate = TTYDEF_SPEED;
+short
dtr_ctl(sc, port, on)
struct vxsoftc *sc;
int port;
@@ -268,6 +266,7 @@ dtr_ctl(sc, port, on)
return (pkt.error_l);
}
+short
rts_ctl(sc, port, on)
struct vxsoftc *sc;
int port;
@@ -289,6 +288,7 @@ rts_ctl(sc, port, on)
return (pkt.error_l);
}
+short
flush_ctl(sc, port, which)
struct vxsoftc *sc;
int port;
@@ -312,7 +312,6 @@ int bits;
int how;
{
int s, unit, port;
- int vxbits;
struct vxsoftc *sc;
struct vx_info *vxt;
u_char msvr;
@@ -515,7 +514,6 @@ struct termios *t;
{
int unit, port;
struct vxsoftc *sc;
- int s;
dev_t dev;
dev = tp->t_dev;
@@ -587,7 +585,6 @@ read_wakeup(sc, port)
struct vxsoftc *sc;
int port;
{
- struct rring *rp;
struct read_wakeup_packet rwp;
volatile struct vx_info *vxt;
vxt = &sc->sc_info[port];
@@ -655,7 +652,6 @@ int flag;
struct wring *wp;
struct write_wakeup_packet wwp;
u_short get, put;
- int i, cnt, s;
unit = VX_UNIT(dev);
if (unit >= vx_cd.cd_ndevs ||
@@ -793,14 +789,6 @@ int flag;
return 0;
}
-static u_char
-vxgetc(sc, port)
-struct vxsoftc *sc;
-int *port;
-{
- return 0;
-}
-
static void
vxputc(sc, port, c)
struct vxsoftc *sc;
@@ -879,9 +867,8 @@ struct vxsoftc *sc;
struct termios *par;
int port;
{
- struct termio tio;
- int imask=0, ints, s;
- int cflag, iflag, oflag, lflag;
+ int imask=0, s;
+ int cflag /*, iflag, oflag, lflag*/;
struct ioctl_a_packet pkt;
bzero(&pkt, sizeof(struct packet));
@@ -974,13 +961,11 @@ vxstart(tp)
struct tty *tp;
{
dev_t dev;
- u_char cbuf;
struct vxsoftc *sc;
struct wring *wp;
int cc, port, unit, s, cnt, i;
u_short get, put;
char buffer[WRING_BUF_SIZE];
- char *wrdp;
dev = tp->t_dev;
port = VX_PORT(dev);
@@ -1029,10 +1014,9 @@ int port;
*/
struct vx_info *vxt;
struct rring *rp;
- struct read_wakeup_packet rwp;
struct tty *tp;
u_short get, put;
- int frame_count, i, pc = 0, open;
+ int frame_count, i, open;
char c;
vxt = &sc->sc_info[port];
@@ -1070,6 +1054,7 @@ int port;
return;
}
+void
ccode(sc, port, c)
struct vxsoftc *sc;
int port;
@@ -1084,13 +1069,14 @@ char c;
}
int
-vx_intr(sc)
-struct vxsoftc *sc;
+vx_intr(arg)
+ void *arg;
{
+ struct vxsoftc *sc = arg;
+
struct envelope *envp, *next_envp;
- struct envelope env;
struct packet *pktp, pkt;
- int valid, i;
+ int valid;
short cmd;
u_char port;
#if defined(MVME187) || defined(MVME197)
@@ -1267,7 +1253,7 @@ int port;
/* Not needed now that I figured out VME bus */
/* mappings and address modifiers, but I don't */
/* want to change them :) */
-void *
+void
memcpy2(void *dest, const void *src, size_t size)
{
int i;
@@ -1299,9 +1285,7 @@ struct vxsoftc *sc;
{
int i;
struct envelope *envp;
- struct envelope env;
struct packet *pktp;
- struct packet pkt;
envp = (struct envelope *)ENVELOPE_AREA;
sc->elist_head = envp;
@@ -1392,11 +1376,8 @@ create_channels(sc)
struct vxsoftc *sc;
{
struct envelope *envp;
- struct envelope env;
- struct packet *pktp;
- u_char valid;
u_short status;
- u_short tas, csr;
+ u_short tas;
struct vxreg *ipc_csr;
ipc_csr = sc->vx_reg;
@@ -1486,9 +1467,8 @@ void
print_dump(sc)
struct vxsoftc *sc;
{
- char *dump_area, *end_dump, *dumpp;
+ char *dump_area;
char dump[209];
- char dump2[209];
bzero(&dump, 209);
dump_area = (char *)0xff780030;
@@ -1546,7 +1526,6 @@ get_packet(sc, thisenv)
struct vxsoftc *sc;
struct envelope *thisenv;
{
- struct envelope env;
unsigned long baseaddr;
if (thisenv == NULL) return NULL;
@@ -1568,10 +1547,8 @@ int
bpp_send(struct vxsoftc *sc, void *pkt, int wait_flag)
{
struct envelope *envp;
- struct init_packet init, *initp;
- struct packet *wpktp, *pktp, *testpktp;
+ struct packet *pktp;
unsigned long newenv;
- int i, s;
/* load up packet in dual port mem */