summaryrefslogtreecommitdiff
path: root/sys/arch/pica
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/pica')
-rw-r--r--sys/arch/pica/dev/dma.c45
-rw-r--r--sys/arch/pica/dev/dma.h5
-rw-r--r--sys/arch/pica/dev/fd.c36
-rw-r--r--sys/arch/pica/dev/if_sn.c88
-rw-r--r--sys/arch/pica/dev/if_sn.h6
-rw-r--r--sys/arch/pica/dev/lpt.c15
-rw-r--r--sys/arch/pica/dev/pccons.c302
7 files changed, 282 insertions, 215 deletions
diff --git a/sys/arch/pica/dev/dma.c b/sys/arch/pica/dev/dma.c
index 34c313d3d71..cb3dfb3d2f0 100644
--- a/sys/arch/pica/dev/dma.c
+++ b/sys/arch/pica/dev/dma.c
@@ -31,7 +31,7 @@
* SUCH DAMAGE.
*
* from: @(#)rz.c 8.1 (Berkeley) 7/29/93
- * $Id: dma.c,v 1.2 1995/10/28 15:47:06 deraadt Exp $
+ * $Id: dma.c,v 1.3 1996/05/01 16:59:32 pefo Exp $
*/
/*
@@ -54,6 +54,7 @@
#include <machine/cpu.h>
#include <machine/autoconf.h>
#include <machine/pte.h>
+#include <machine/pio.h>
#include <scsi/scsi_all.h>
#include <scsi/scsiconf.h>
@@ -207,7 +208,6 @@ picaDmaTLBMap(dma_softc_t *sc)
va += PICA_DMA_PAGE_SIZE;
nbytes -= PICA_DMA_PAGE_SIZE;
}
- out32(PICA_SYS_TL_IVALID, 0); /* Flush dma map cache */
}
/*
@@ -235,6 +235,7 @@ picaDmaStart(sc, addr, size, datain)
/* Map up the request viritual dma space */
picaDmaTLBMap(sc);
+ out32(PICA_SYS_TL_IVALID, 0); /* Flush dma map cache */
/* Load new transfer parameters */
regs->dma_addr = sc->next_va;
@@ -275,6 +276,19 @@ picaDmaMap(sc, addr, size, offset)
}
/*
+ * Prepare for new dma by flushing
+ */
+void
+picaDmaFlush(sc, addr, size, datain)
+ struct dma_softc *sc;
+ char *addr;
+ size_t size;
+ int datain;
+{
+ out32(PICA_SYS_TL_IVALID, 0); /* Flush dma map cache */
+}
+
+/*
* Stop/Reset a DMA channel
*/
void
@@ -289,6 +303,25 @@ picaDmaReset(dma_softc_t *sc)
}
/*
+ * End dma operation, return byte count left.
+ */
+int
+picaDmaEnd(dma_softc_t *sc)
+{
+ pDmaReg regs = sc->dma_reg;
+ int res;
+
+ res = regs->dma_count = sc->next_size;
+
+ /* Halt DMA */
+ regs->dma_enab = 0;
+ regs->dma_mode = 0;
+ sc->sc_active = 0;
+
+ return res;
+}
+
+/*
* Null call rathole!
*/
void
@@ -312,10 +345,11 @@ asc_dma_init(dma_softc_t *sc)
sc->map = picaDmaMap;
sc->isintr = picaDmaNull;
sc->intr = picaDmaNull;
+ sc->end = picaDmaEnd;
sc->dma_reg = (pDmaReg)PICA_SYS_DMA0_REGS;
sc->pte_size = 32;
- sc->mode = PICA_DMA_MODE_80NS | PICA_DMA_MODE_16;
+ sc->mode = PICA_DMA_MODE_160NS | PICA_DMA_MODE_16;
picaDmaTLBAlloc(sc);
}
/*
@@ -328,8 +362,10 @@ fdc_dma_init(dma_softc_t *sc)
sc->reset = picaDmaReset;
sc->enintr = picaDmaNull;
sc->start = picaDmaStart;
+ sc->map = picaDmaMap;
sc->isintr = picaDmaNull;
sc->intr = picaDmaNull;
+ sc->end = picaDmaEnd;
sc->dma_reg = (pDmaReg)PICA_SYS_DMA1_REGS;
sc->pte_size = 32;
@@ -345,10 +381,11 @@ sn_dma_init(dma_softc_t *sc, int pages)
{
sc->reset = picaDmaNull;
sc->enintr = picaDmaNull;
+ sc->start = picaDmaFlush;
sc->map = picaDmaMap;
- sc->start = picaDmaNull;
sc->isintr = picaDmaNull;
sc->intr = picaDmaNull;
+ sc->end = picaDmaNull;
sc->dma_reg = (pDmaReg)NULL;
sc->pte_size = pages;
diff --git a/sys/arch/pica/dev/dma.h b/sys/arch/pica/dev/dma.h
index 991d3ec8bcb..92f6a9436c9 100644
--- a/sys/arch/pica/dev/dma.h
+++ b/sys/arch/pica/dev/dma.h
@@ -31,7 +31,7 @@
* SUCH DAMAGE.
*
* from: @(#)dma.h 8.1 (Berkeley) 6/10/93
- * $Id: dma.h,v 1.2 1995/10/28 15:47:07 deraadt Exp $
+ * $Id: dma.h,v 1.3 1996/05/01 16:59:35 pefo Exp $
*/
/*
@@ -133,6 +133,7 @@ typedef struct dma_softc {
/* Start routine pointer */
int (*isintr)(struct dma_softc *); /* Int check routine pointer */
int (*intr)(struct dma_softc *); /* Interrupt routine pointer */
+ int (*end)(struct dma_softc *); /* Interrupt routine pointer */
} dma_softc_t;
#define DMA_TO_DEV 0
@@ -146,4 +147,4 @@ typedef struct dma_softc {
#define DMA_MAP(a, b, c, d) ((a->map)(a, b, c, d))
#define DMA_INTR(r) ((r->intr)(r))
#define DMA_DRAIN(r)
-#define DMA_END(r) ((r->reset)(r))
+#define DMA_END(r) ((r->end)(r))
diff --git a/sys/arch/pica/dev/fd.c b/sys/arch/pica/dev/fd.c
index caa9769a7ea..df19f546b8c 100644
--- a/sys/arch/pica/dev/fd.c
+++ b/sys/arch/pica/dev/fd.c
@@ -106,8 +106,11 @@ struct fdc_softc {
int fdcprobe __P((struct device *, void *, void *));
void fdcattach __P((struct device *, struct device *, void *));
-struct cfdriver fdccd = {
- NULL, "fdc", fdcprobe, fdcattach, DV_DULL, sizeof(struct fdc_softc)
+struct cfattach fdc_ca = {
+ sizeof(struct fdc_softc), fdcprobe, fdcattach
+};
+struct cfdriver fdc_cd = {
+ NULL, "fdc", DV_DULL, NULL, 0
};
/*
@@ -144,7 +147,7 @@ struct fd_type fd_types[] = {
/* software state, per disk (with up to 4 disks per ctlr) */
struct fd_softc {
struct device sc_dev;
- struct dkdevice sc_dk;
+ struct disk sc_dk;
struct fd_type *sc_deftype; /* default type descriptor */
struct fd_type *sc_type; /* current type descriptor */
@@ -162,6 +165,8 @@ struct fd_softc {
#define FD_MOTOR_WAIT 0x04 /* motor coming up */
int sc_cylin; /* where we think the head is */
+ void *sc_sdhook; /* saved shutdown hook for drive. */
+
TAILQ_ENTRY(fd_softc) sc_drivechain;
int sc_ops; /* I/O ops since last switch */
struct buf sc_q; /* head of buf chain */
@@ -171,8 +176,11 @@ struct fd_softc {
int fdprobe __P((struct device *, void *, void *));
void fdattach __P((struct device *, struct device *, void *));
-struct cfdriver fdcd = {
- NULL, "fd", fdprobe, fdattach, DV_DISK, sizeof(struct fd_softc)
+struct cfattach fd_ca = {
+ sizeof(struct fd_softc), fdprobe, fdattach
+};
+struct cfdriver fd_cd = {
+ NULL, "fd", DV_DISK, NULL, 0
};
void fdgetdisklabel __P((struct fd_softc *));
@@ -354,9 +362,13 @@ fdattach(parent, self, aux)
fd->sc_drive = drive;
fd->sc_deftype = type;
fdc->sc_fd[drive] = fd;
+ fd->sc_dk.dk_name = fd->sc_dev.dv_xname;
fd->sc_dk.dk_driver = &fddkdriver;
/* XXX Need to do some more fiddling with sc_dk. */
dk_establish(&fd->sc_dk, &fd->sc_dev);
+
+ /* Needed to power off if the motor is on when we halt. */
+ fd->sc_sdhook = shutdownhook_establish(fd_motor_off, fd);
}
/*
@@ -418,8 +430,8 @@ fdstrategy(bp)
int s;
/* Valid unit, controller, and request? */
- if (unit >= fdcd.cd_ndevs ||
- (fd = fdcd.cd_devs[unit]) == 0 ||
+ if (unit >= fd_cd.cd_ndevs ||
+ (fd = fd_cd.cd_devs[unit]) == 0 ||
bp->b_blkno < 0 ||
(bp->b_bcount % FDC_BSIZE) != 0) {
bp->b_error = EINVAL;
@@ -637,7 +649,7 @@ out_fdc(iobase, x)
}
int
-Fdopen(dev, flags)
+fdopen(dev, flags)
dev_t dev;
int flags;
{
@@ -646,9 +658,9 @@ Fdopen(dev, flags)
struct fd_type *type;
unit = FDUNIT(dev);
- if (unit >= fdcd.cd_ndevs)
+ if (unit >= fd_cd.cd_ndevs)
return ENXIO;
- fd = fdcd.cd_devs[unit];
+ fd = fd_cd.cd_devs[unit];
if (fd == 0)
return ENXIO;
type = fd_dev_to_type(fd, dev);
@@ -671,7 +683,7 @@ fdclose(dev, flags)
dev_t dev;
int flags;
{
- struct fd_softc *fd = fdcd.cd_devs[FDUNIT(dev)];
+ struct fd_softc *fd = fd_cd.cd_devs[FDUNIT(dev)];
fd->sc_flags &= ~FD_OPEN;
return 0;
@@ -1081,7 +1093,7 @@ fdioctl(dev, cmd, addr, flag)
caddr_t addr;
int flag;
{
- struct fd_softc *fd = fdcd.cd_devs[FDUNIT(dev)];
+ struct fd_softc *fd = fd_cd.cd_devs[FDUNIT(dev)];
struct disklabel buffer;
int error;
diff --git a/sys/arch/pica/dev/if_sn.c b/sys/arch/pica/dev/if_sn.c
index dc48444a0b7..12f815a7d63 100644
--- a/sys/arch/pica/dev/if_sn.c
+++ b/sys/arch/pica/dev/if_sn.c
@@ -116,8 +116,11 @@ struct sn_softc {
int snmatch __P((struct device *, void *, void *));
void snattach __P((struct device *, struct device *, void *));
-struct cfdriver sncd = {
- NULL, "sn", snmatch, snattach, DV_IFNET, sizeof(struct sn_softc)
+struct cfattach sn_ca = {
+ sizeof(struct sn_softc), snmatch, snattach
+};
+struct cfdriver sn_cd = {
+ NULL, "sn", DV_IFNET, NULL, 0
};
#include <assert.h>
@@ -189,15 +192,6 @@ void snreset __P((struct sn_softc *sc));
#define UPPER(x) ((unsigned)(x) >> 16)
#define LOWER(x) ((unsigned)(x) & 0xffff)
-/*
- * buffer sizes in 32 bit mode
- * 1 TXpkt is 4 hdr words + (3 * FRAGMAX) + 1 link word
- * FRAGMAX == 16 => 54 words == 216 bytes
- *
- * 1 RxPkt is 7 words == 28 bytes
- * 1 Rda is 4 words == 16 bytes
- */
-
#define NRRA 32 /* # receive resource descriptors */
#define RRAMASK 0x1f /* why it must be poer of two */
@@ -314,27 +308,27 @@ snattach(parent, self, aux)
p = SONICBUF;
pp = SONICBUF - (FRAGMAX * NTDA * PICA_DMA_PAGE_SIZE);
+ if ((p ^ (p + TDASIZE)) & 0x10000)
+ p = (p + 0x10000) & ~0xffff;
+ p_tda = (struct TXpkt *) p;
+ v_tda = (struct TXpkt *)(p - pp + sc->dma->dma_va);
+ p += TDASIZE;
+
if ((p ^ (p + RRASIZE + CDASIZE)) & 0x10000)
p = (p + 0x10000) & ~0xffff;
p_rra = (struct RXrsrc *) p;
v_rra = (struct RXrsrc *)(p - pp + sc->dma->dma_va);
p += RRASIZE;
- p_cda = (struct CDA *) p;
- v_cda = (struct CDA *)(p - pp + sc->dma->dma_va);
- p += CDASIZE;
-
if ((p ^ (p + RDASIZE)) & 0x10000)
p = (p + 0x10000) & ~0xffff;
p_rda = (struct RXpkt *) p;
v_rda = (struct RXpkt *)(p - pp + sc->dma->dma_va);
p += RDASIZE;
- if ((p ^ (p + TDASIZE)) & 0x10000)
- p = (p + 0x10000) & ~0xffff;
- p_tda = (struct TXpkt *) p;
- v_tda = (struct TXpkt *)(p - pp + sc->dma->dma_va);
- p += TDASIZE;
+ p_cda = (struct CDA *) p;
+ v_cda = (struct CDA *)(p - pp + sc->dma->dma_va);
+ p += CDASIZE;
p += PICA_DMA_PAGE_SIZE - (p & (PICA_DMA_PAGE_SIZE -1));
p_rba = (char *)p;
@@ -379,7 +373,7 @@ snioctl(ifp, cmd, data)
caddr_t data;
{
struct ifaddr *ifa;
- struct sn_softc *sc = sncd.cd_devs[ifp->if_unit];
+ struct sn_softc *sc = sn_cd.cd_devs[ifp->if_unit];
int s = splnet(), err = 0;
int temp;
@@ -475,7 +469,7 @@ void
snstart(ifp)
struct ifnet *ifp;
{
- struct sn_softc *sc = sncd.cd_devs[ifp->if_unit];
+ struct sn_softc *sc = sn_cd.cd_devs[ifp->if_unit];
struct mbuf *m;
int len;
@@ -490,7 +484,9 @@ snstart(ifp)
* the Tx ring, then send the packet directly. Otherwise append
* it to the o/p queue.
*/
- len = sonicput(sc, m);
+ if (!sonicput(sc, m)) { /* not enough space */
+ IF_PREPEND(&sc->sc_if.if_snd, m);
+ }
#if NBPFILTER > 0
/*
* If bpf is listening on this interface, let it
@@ -532,7 +528,7 @@ int
sninit(unit)
int unit;
{
- struct sn_softc *sc = sncd.cd_devs[unit];
+ struct sn_softc *sc = sn_cd.cd_devs[unit];
struct sonic_reg *csr = sc->sc_csr;
int s, error;
@@ -601,7 +597,7 @@ int
snstop(unit)
int unit;
{
- struct sn_softc *sc = sncd.cd_devs[unit];
+ struct sn_softc *sc = sn_cd.cd_devs[unit];
struct mtd *mtd;
int s = splnet();
@@ -637,7 +633,7 @@ void
snwatchdog(unit)
int unit;
{
- struct sn_softc *sc = sncd.cd_devs[unit];
+ struct sn_softc *sc = sn_cd.cd_devs[unit];
int temp;
if (mtdhead && mtdhead->mtd_mbuf) {
@@ -690,9 +686,11 @@ sonicput(sc, m0)
unsigned va = (unsigned) mtod(m, caddr_t);
int resid = m->m_len;
- MachHitFlushDCache(va, resid);
+ if(resid != 0) {
+ MachHitFlushDCache(va, resid);
+ DMA_MAP(sc->dma, (caddr_t)va, resid, fragoffset);
+ }
len += resid;
- DMA_MAP(sc->dma, (caddr_t)va, resid, fragoffset);
while (resid) {
unsigned pa;
@@ -714,6 +712,25 @@ sonicput(sc, m0)
fragoffset += PICA_DMA_PAGE_SIZE;
}
}
+ /*
+ * pad out last fragment for minimum size
+ */
+ if (len < ETHERMIN + sizeof(struct ether_header) && fr < FRAGMAX) {
+ int pad = ETHERMIN + sizeof(struct ether_header) - len;
+ static char zeros[64];
+ unsigned pa;
+
+ DMA_MAP(sc->dma, (caddr_t)zeros, pad, fragoffset);
+ pa = sc->dma->dma_va + ((unsigned)zeros & PGOFSET) + fragoffset;
+ SWR(txp->u[fr].frag_ptrlo, LOWER(pa));
+ SWR(txp->u[fr].frag_ptrhi, UPPER(pa));
+ SWR(txp->u[fr].frag_size, pad);
+ fr++;
+ len = ETHERMIN + sizeof(struct ether_header);
+ }
+
+ DMA_START(sc->dma, (caddr_t)0, 0, 0); /* Flush dma tlb */
+
if (fr > FRAGMAX) {
mtd_free(mtdnew);
m_freem(m0);
@@ -723,18 +740,6 @@ sonicput(sc, m0)
return (len);
}
- /*
- * pad out last fragment for minimum size
- *
- * XXX is this incorrectly done? does it cause random bytes of
- * mem to be sent? if so, it should instead point to a zero'd
- * zone of mem.
- */
- if (len < ETHERMIN + sizeof(struct ether_header)) {
- int pad = ETHERMIN + sizeof(struct ether_header) - len;
- SWR(txp->u[fr - 1].frag_size, pad + SRD(txp->u[fr - 1].frag_size));
- len = ETHERMIN + sizeof(struct ether_header);
- }
SWR(txp->frag_count, fr);
SWR(txp->pkt_size, len);
@@ -982,6 +987,7 @@ initialise_rra(sc)
csr->s_rsa = LOWER(v_rra);
csr->s_rea = LOWER(&v_rra[NRRA]);
csr->s_rrp = LOWER(v_rra);
+ csr->s_rsc = 0;
/* fill up SOME of the rra with buffers */
for (i = 0; i < NRBA; i++) {
@@ -1153,6 +1159,8 @@ sonicrxint(sc)
assert(SRD(rxp->pkt_ptrhi) == SRD(p_rra[orra].buff_ptrhi));
assert(SRD(rxp->pkt_ptrlo) == SRD(p_rra[orra].buff_ptrlo));
+if(SRD(rxp->pkt_ptrlo) != SRD(p_rra[orra].buff_ptrlo))
+printf("%x,%x\n",SRD(rxp->pkt_ptrlo),SRD(p_rra[orra].buff_ptrlo));
assert(SRD(p_rra[orra].buff_wclo));
/*
diff --git a/sys/arch/pica/dev/if_sn.h b/sys/arch/pica/dev/if_sn.h
index 9b2789ea244..a5cd835cfcf 100644
--- a/sys/arch/pica/dev/if_sn.h
+++ b/sys/arch/pica/dev/if_sn.h
@@ -43,6 +43,7 @@ struct RXpkt {
u_long seq_no; /* + RBA sequence numbers */
u_long rlink; /* link to next receive descriptor */
u_long in_use; /* + packet available to SONIC */
+ u_long pad; /* pad to multiple of 16 bytes */
};
#endif
#define RBASEQ(x) (((x)>>8)&0xff)
@@ -52,7 +53,7 @@ struct RXpkt {
* Transmit Descriptor
* This structure holds information about packets to be transmitted.
*/
-#define FRAGMAX 32 /* maximum number of fragments in a packet */
+#define FRAGMAX 31 /* maximum number of fragments in a packet */
#if SONICDW == 32
struct TXpkt {
u_long status; /* + transmitted packet status */
@@ -68,8 +69,7 @@ struct TXpkt {
struct {
u_long _tlink; /* link to next transmit descriptor */
} u_link;
- } u[FRAGMAX];
- u_long :32; /* This makes tcp->u[FRAGMAX].u_link.link valid! */
+ } u[FRAGMAX+1]; /* +1 makes tcp->u[FRAGMAX].u_link.link valid! */
};
#endif
diff --git a/sys/arch/pica/dev/lpt.c b/sys/arch/pica/dev/lpt.c
index 75c220bc09e..22809699cab 100644
--- a/sys/arch/pica/dev/lpt.c
+++ b/sys/arch/pica/dev/lpt.c
@@ -107,8 +107,11 @@ int lptprobe __P((struct device *, void *, void *));
void lptattach __P((struct device *, struct device *, void *));
int lptintr __P((void *));
-struct cfdriver lptcd = {
- NULL, "lpt", lptprobe, lptattach, DV_TTY, sizeof(struct lpt_softc)
+struct cfattach lpt_ca = {
+ sizeof(struct lpt_softc), lptprobe, lptattach
+};
+struct cfdriver lpt_cd = {
+ NULL, "lpt", DV_TTY, NULL, 0
};
#define LPTUNIT(s) (minor(s) & 0x1f)
@@ -251,9 +254,9 @@ lptopen(dev, flag)
int error;
int spin;
- if (unit >= lptcd.cd_ndevs)
+ if (unit >= lpt_cd.cd_ndevs)
return ENXIO;
- sc = lptcd.cd_devs[unit];
+ sc = lpt_cd.cd_devs[unit];
if (!sc)
return ENXIO;
@@ -354,7 +357,7 @@ lptclose(dev, flag)
int flag;
{
int unit = LPTUNIT(dev);
- struct lpt_softc *sc = lptcd.cd_devs[unit];
+ struct lpt_softc *sc = lpt_cd.cd_devs[unit];
int iobase = sc->sc_iobase;
if (sc->sc_count)
@@ -404,7 +407,7 @@ lptwrite(dev, uio)
dev_t dev;
struct uio *uio;
{
- struct lpt_softc *sc = lptcd.cd_devs[LPTUNIT(dev)];
+ struct lpt_softc *sc = lpt_cd.cd_devs[LPTUNIT(dev)];
size_t n;
int error = 0;
diff --git a/sys/arch/pica/dev/pccons.c b/sys/arch/pica/dev/pccons.c
index 9b5e0ace965..f7ee0774e62 100644
--- a/sys/arch/pica/dev/pccons.c
+++ b/sys/arch/pica/dev/pccons.c
@@ -66,6 +66,7 @@
#include <dev/cons.h>
#include <machine/cpu.h>
+#include <machine/pio.h>
#include <machine/autoconf.h>
#include <machine/display.h>
#include <machine/pccons.h>
@@ -140,16 +141,22 @@ int pcmatch __P((struct device *, void *, void *));
void pcattach __P((struct device *, struct device *, void *));
int pcintr __P((void *));
-struct cfdriver pccd = {
- NULL, "pc", pcmatch, pcattach, DV_TTY, sizeof(struct pc_softc)
+struct cfattach pc_ca = {
+ sizeof(struct pc_softc), pcmatch, pcattach
+};
+struct cfdriver pc_cd = {
+ NULL, "pc", DV_TTY, NULL, 0
};
int pmsprobe __P((struct device *, void *, void *));
void pmsattach __P((struct device *, struct device *, void *));
int pmsintr __P((void *));
-struct cfdriver pmscd = {
- NULL, "pms", pmsprobe, pmsattach, DV_TTY, sizeof(struct pms_softc)
+struct cfattach pms_ca = {
+ sizeof(struct pms_softc), pmsprobe, pmsattach
+};
+struct cfdriver pms_cd = {
+ NULL, "pms", DV_TTY, NULL, 0
};
#define PMSUNIT(dev) (minor(dev))
@@ -513,9 +520,9 @@ pcopen(dev, flag, mode, p)
int unit = PCUNIT(dev);
struct tty *tp;
- if (unit >= pccd.cd_ndevs)
+ if (unit >= pc_cd.cd_ndevs)
return ENXIO;
- sc = pccd.cd_devs[unit];
+ sc = pc_cd.cd_devs[unit];
if (sc == 0)
return ENXIO;
@@ -552,7 +559,7 @@ pcclose(dev, flag, mode, p)
int flag, mode;
struct proc *p;
{
- struct pc_softc *sc = pccd.cd_devs[PCUNIT(dev)];
+ struct pc_softc *sc = pc_cd.cd_devs[PCUNIT(dev)];
struct tty *tp = sc->sc_tty;
(*linesw[tp->t_line].l_close)(tp, flag);
@@ -569,7 +576,7 @@ pcread(dev, uio, flag)
struct uio *uio;
int flag;
{
- struct pc_softc *sc = pccd.cd_devs[PCUNIT(dev)];
+ struct pc_softc *sc = pc_cd.cd_devs[PCUNIT(dev)];
struct tty *tp = sc->sc_tty;
return ((*linesw[tp->t_line].l_read)(tp, uio, flag));
@@ -581,7 +588,7 @@ pcwrite(dev, uio, flag)
struct uio *uio;
int flag;
{
- struct pc_softc *sc = pccd.cd_devs[PCUNIT(dev)];
+ struct pc_softc *sc = pc_cd.cd_devs[PCUNIT(dev)];
struct tty *tp = sc->sc_tty;
return ((*linesw[tp->t_line].l_write)(tp, uio, flag));
@@ -591,7 +598,7 @@ struct tty *
pctty(dev)
dev_t dev;
{
- struct pc_softc *sc = pccd.cd_devs[PCUNIT(dev)];
+ struct pc_softc *sc = pc_cd.cd_devs[PCUNIT(dev)];
struct tty *tp = sc->sc_tty;
return (tp);
@@ -634,7 +641,7 @@ pcioctl(dev, cmd, data, flag, p)
int flag;
struct proc *p;
{
- struct pc_softc *sc = pccd.cd_devs[PCUNIT(dev)];
+ struct pc_softc *sc = pc_cd.cd_devs[PCUNIT(dev)];
struct tty *tp = sc->sc_tty;
int error;
@@ -817,8 +824,8 @@ pccnpollc(dev, on)
* interrupts.
*/
unit = PCUNIT(dev);
- if (pccd.cd_ndevs > unit) {
- sc = pccd.cd_devs[unit];
+ if (pc_cd.cd_ndevs > unit) {
+ sc = pc_cd.cd_devs[unit];
if (sc != 0) {
s = spltty();
pcintr(sc);
@@ -1456,135 +1463,134 @@ static Scan_def us_scan_codes[] = {
};
static Scan_def sw_scan_codes[] = {
- NONE, "", "", "", "", /* 0 unused */
- ASCII, "\033", "\033", "\033", "\033", /* 1 ESCape */
- ASCII, "1", "!", "", "0xa1", /* 2 1 */
- ASCII, "2", "\"", "\000", "@", /* 3 2 */
- ASCII, "3", "#", "", "0xa3", /* 4 3 */
- ASCII, "4", "$", "", "$", /* 5 4 */
- ASCII, "5", "%", "\034", "\\", /* 6 5 */
- ASCII, "6", "&", "\034", "|", /* 7 6 */
- ASCII, "7", "/", "\033", "{", /* 8 7 */
- ASCII, "9", ")", "\035", "]", /* 10 9 */
- ASCII, "0", "=", "\035", "}", /* 11 0 */
- ASCII, "+", "?", "\037", "0xbf", /* 12 - */
- ASCII, "\\", "`", "\034", "'", /* 13 = */
- ASCII, "\177", "\177", "\010", "\177", /* 14 backspace */
- ASCII, "\t", "\177\t", "\t", "\t", /* 15 tab */
- ASCII, "q", "Q", "\021", "q", /* 16 q */
- ASCII, "w", "W", "\027", "w", /* 17 w */
- ASCII, "e", "E", "\005", "0xeb", /* 18 e */
- ASCII, "r", "R", "\022", "r", /* 19 r */
- ASCII, "t", "T", "\024", "t", /* 20 t */
- ASCII, "y", "Y", "\031", "y", /* 21 y */
- ASCII, "u", "U", "\025", "0xfc", /* 22 u */
- ASCII, "i", "I", "\011", "i", /* 23 i */
- ASCII, "o", "O", "\017", "0xf6", /* 24 o */
- ASCII, "p", "P", "\020", "p", /* 25 p */
- ASCII, "0xe5", "0xc5", "0xdc", "0xfc", /* 26 [ */
- ASCII, "~", "^", "\036", "", /* 27 ] */
- ASCII, "\r", "\r", "\n", "\r", /* 28 return */
- CTL, "", "", "", "", /* 29 control */
- ASCII, "a", "A", "\001", "0xe4", /* 30 a */
- ASCII, "s", "S", "\023", "0xdf", /* 31 s */
- ASCII, "d", "D", "\004", "d", /* 32 d */
- ASCII, "f", "F", "\006", "f", /* 33 f */
- ASCII, "g", "G", "\007", "g", /* 34 g */
- ASCII, "h", "H", "\010", "h", /* 35 h */
- ASCII, "j", "J", "\n", "j", /* 36 j */
- ASCII, "k", "K", "\013", "k", /* 37 k */
- ASCII, "l", "L", "\014", "l", /* 38 l */
- ASCII, "0xf6", "0xd6", "0xd6", "0xf6", /* 39 ; */
- ASCII, "0xe4", "0xc4", "0xc4", "0xe4", /* 40 ' */
- ASCII, "|", "@", "\034", "0xa7", /* 41 ` */
- SHIFT, "", "", "", "", /* 42 shift */
- ASCII, "'", "*", "'", "'", /* 43 \ */
- ASCII, "z", "Z", "\032", "z", /* 44 z */
- ASCII, "x", "X", "\030", "x", /* 45 x */
- ASCII, "c", "C", "\003", "c", /* 46 c */
- ASCII, "v", "V", "\026", "v", /* 47 v */
- ASCII, "b", "B", "\002", "b", /* 48 b */
- ASCII, "n", "N", "\016", "n", /* 49 n */
- ASCII, "m", "M", "\015", "m", /* 50 m */
- ASCII, ",", ";", ",", ",", /* 51 , */
- ASCII, ".", ":", ".", ".", /* 52 . */
- ASCII, "-", "_", "\037", "-", /* 53 / */
- SHIFT, "", "", "", "", /* 54 shift */
- KP, "*", "*", "*", "*", /* 55 kp * */
- ALT, "", "", "", "", /* 56 alt */
- ASCII, " ", " ", "\000", " ", /* 57 space */
- CAPS, "", "", "", "", /* 58 caps */
- FUNC, "\033[M", "\033[Y", "\033[k", "", /* 59 f1 */
- FUNC, "\033[N", "\033[Z", "\033[l", "", /* 60 f2 */
- FUNC, "\033[O", "\033[a", "\033[m", "", /* 61 f3 */
- FUNC, "\033[P", "\033[b", "\033[n", "", /* 62 f4 */
- FUNC, "\033[Q", "\033[c", "\033[o", "", /* 63 f5 */
- FUNC, "\033[R", "\033[d", "\033[p", "", /* 64 f6 */
- FUNC, "\033[S", "\033[e", "\033[q", "", /* 65 f7 */
- FUNC, "\033[T", "\033[f", "\033[r", "", /* 66 f8 */
- FUNC, "\033[U", "\033[g", "\033[s", "", /* 67 f9 */
- FUNC, "\033[V", "\033[h", "\033[t", "", /* 68 f10 */
- NUM, "", "", "", "", /* 69 num lo
-
- SCROLL, "", "", "", "", /* 70 scroll
-
- KP, "7", "\033[H", "7", "", /* 71 kp 7 */
- KP, "8", "\033[A", "8", "", /* 72 kp 8 */
- KP, "9", "\033[I", "9", "", /* 73 kp 9 */
- KP, "-", "-", "-", "", /* 74 kp - */
- KP, "4", "\033[D", "4", "", /* 75 kp 4 */
- KP, "5", "\033[E", "5", "", /* 76 kp 5 */
- KP, "6", "\033[C", "6", "", /* 77 kp 6 */
- KP, "+", "+", "+", "", /* 78 kp + */
- KP, "1", "\033[F", "1", "", /* 79 kp 1 */
- KP, "2", "\033[B", "2", "", /* 80 kp 2 */
- KP, "3", "\033[G", "3", "", /* 81 kp 3 */
- KP, "0", "\033[L", "0", "", /* 82 kp 0 */
- KP, ".", "\177", ".", "", /* 83 kp . */
- NONE, "", "", "", "", /* 84 0 */
- NONE, "100", "", "", "", /* 85 0 */
- ASCII, "<", ">", "0xbb", "0xab", /* 86 < > */
- FUNC, "\033[W", "\033[i", "\033[u","", /* 87 f11 */
- FUNC, "\033[X", "\033[j", "\033[v","", /* 88 f12 */
- NONE, "102", "", "", "", /* 89 0 */
- NONE, "103", "", "", "", /* 90 0 */
- NONE, "", "", "", "", /* 91 0 */
- NONE, "", "", "", "", /* 92 0 */
- NONE, "", "", "", "", /* 93 0 */
- NONE, "", "", "", "", /* 94 0 */
- NONE, "", "", "", "", /* 95 0 */
- NONE, "", "", "", "", /* 96 0 */
- NONE, "", "", "", "", /* 97 0 */
- NONE, "", "", "", "", /* 98 0 */
- NONE, "", "", "", "", /* 99 0 */
- NONE, "", "", "", "", /* 100 */
- NONE, "", "", "", "", /* 101 */
- NONE, "", "", "", "", /* 102 */
- NONE, "", "", "", "", /* 103 */
- NONE, "", "", "", "", /* 104 */
- NONE, "", "", "", "", /* 105 */
- NONE, "", "", "", "", /* 106 */
- NONE, "", "", "", "", /* 107 */
- NONE, "", "", "", "", /* 108 */
- NONE, "", "", "", "", /* 109 */
- NONE, "", "", "", "", /* 110 */
- NONE, "", "", "", "", /* 111 */
- NONE, "", "", "", "", /* 112 */
- NONE, "", "", "", "", /* 113 */
- NONE, "", "", "", "", /* 114 */
- NONE, "", "", "", "", /* 115 */
- NONE, "", "", "", "", /* 116 */
- NONE, "", "", "", "", /* 117 */
- NONE, "", "", "", "", /* 118 */
- NONE, "", "", "", "", /* 119 */
- NONE, "", "", "", "", /* 120 */
- NONE, "", "", "", "", /* 121 */
- NONE, "", "", "", "", /* 122 */
- NONE, "", "", "", "", /* 123 */
- NONE, "", "", "", "", /* 124 */
- NONE, "", "", "", "", /* 125 */
- NONE, "", "", "", "", /* 126 */
- NONE, "", "", "", "", /* 127 */
+ NONE, "", "", "", "", /* 0 unused */
+ ASCII, "\033", "\033", "\033", "\033", /* 1 ESCape */
+ ASCII, "1", "!", "", "\241", /* 2 1 */
+ ASCII, "2", "\"", "\000", "@", /* 3 2 */
+ ASCII, "3", "#", "", "\243", /* 4 3 */
+ ASCII, "4", "$", "", "$", /* 5 4 */
+ ASCII, "5", "%", "\034", "\\", /* 6 5 */
+ ASCII, "6", "&", "\034", "|", /* 7 6 */
+ ASCII, "7", "/", "\033", "{", /* 8 7 */
+ ASCII, "8", "(", "\036", "[", /* 9 8 */
+ ASCII, "9", ")", "\035", "]", /* 10 9 */
+ ASCII, "0", "=", "\035", "}", /* 11 0 */
+ ASCII, "+", "?", "\037", "\\", /* 12 - */
+ ASCII, "'", "`", "\034", "'", /* 13 = */
+ ASCII, "\177", "\177", "\010", "\177", /* 14 backspace */
+ ASCII, "\t", "\177\t", "\t", "\t", /* 15 tab */
+ ASCII, "q", "Q", "\021", "q", /* 16 q */
+ ASCII, "w", "W", "\027", "w", /* 17 w */
+ ASCII, "e", "E", "\005", "\353", /* 18 e */
+ ASCII, "r", "R", "\022", "r", /* 19 r */
+ ASCII, "t", "T", "\024", "t", /* 20 t */
+ ASCII, "y", "Y", "\031", "y", /* 21 y */
+ ASCII, "u", "U", "\025", "\374", /* 22 u */
+ ASCII, "i", "I", "\011", "i", /* 23 i */
+ ASCII, "o", "O", "\017", "\364", /* 24 o */
+ ASCII, "p", "P", "\020", "p", /* 25 p */
+ ASCII, "\345", "\305", "\334", "\374", /* 26 [ */
+ ASCII, "~", "^", "\036", "", /* 27 ] */
+ ASCII, "\r", "\r", "\n", "\r", /* 28 return */
+ CTL, "", "", "", "", /* 29 control */
+ ASCII, "a", "A", "\001", "\344", /* 30 a */
+ ASCII, "s", "S", "\023", "\337", /* 31 s */
+ ASCII, "d", "D", "\004", "d", /* 32 d */
+ ASCII, "f", "F", "\006", "f", /* 33 f */
+ ASCII, "g", "G", "\007", "g", /* 34 g */
+ ASCII, "h", "H", "\010", "h", /* 35 h */
+ ASCII, "j", "J", "\n", "j", /* 36 j */
+ ASCII, "k", "K", "\013", "k", /* 37 k */
+ ASCII, "l", "L", "\014", "l", /* 38 l */
+ ASCII, "\366", "\326", "\326", "\366", /* 39 ; */
+ ASCII, "\344", "\304", "\304", "\344", /* 40 ' */
+ ASCII, "|", "@", "\034", "\247", /* 41 ` */
+ SHIFT, "", "", "", "", /* 42 shift */
+ ASCII, "'", "*", "'", "'", /* 43 \ */
+ ASCII, "z", "Z", "\032", "z", /* 44 z */
+ ASCII, "x", "X", "\030", "x", /* 45 x */
+ ASCII, "c", "C", "\003", "c", /* 46 c */
+ ASCII, "v", "V", "\026", "v", /* 47 v */
+ ASCII, "b", "B", "\002", "b", /* 48 b */
+ ASCII, "n", "N", "\016", "n", /* 49 n */
+ ASCII, "m", "M", "\015", "m", /* 50 m */
+ ASCII, ",", ";", ",", ",", /* 51 , */
+ ASCII, ".", ":", ".", ".", /* 52 . */
+ ASCII, "-", "_", "\037", "-", /* 53 / */
+ SHIFT, "", "", "", "", /* 54 shift */
+ KP, "*", "*", "*", "*", /* 55 kp * */
+ ALT, "", "", "", "", /* 56 alt */
+ ASCII, " ", " ", "\000", " ", /* 57 space */
+ CAPS, "", "", "", "", /* 58 caps */
+ FUNC, "\033[M", "\033[Y", "\033[k", "", /* 59 f1 */
+ FUNC, "\033[N", "\033[Z", "\033[l", "", /* 60 f2 */
+ FUNC, "\033[O", "\033[a", "\033[m", "", /* 61 f3 */
+ FUNC, "\033[P", "\033[b", "\033[n", "", /* 62 f4 */
+ FUNC, "\033[Q", "\033[c", "\033[o", "", /* 63 f5 */
+ FUNC, "\033[R", "\033[d", "\033[p", "", /* 64 f6 */
+ FUNC, "\033[S", "\033[e", "\033[q", "", /* 65 f7 */
+ FUNC, "\033[T", "\033[f", "\033[r", "", /* 66 f8 */
+ FUNC, "\033[U", "\033[g", "\033[s", "", /* 67 f9 */
+ FUNC, "\033[V", "\033[h", "\033[t", "", /* 68 f10 */
+ NUM, "", "", "", "", /* 69 num lo */
+ SCROLL, "", "", "", "", /* 70 scroll */
+ KP, "7", "\033[H", "7", "", /* 71 kp 7 */
+ KP, "8", "\033[A", "8", "", /* 72 kp 8 */
+ KP, "9", "\033[I", "9", "", /* 73 kp 9 */
+ KP, "-", "-", "-", "", /* 74 kp - */
+ KP, "4", "\033[D", "4", "", /* 75 kp 4 */
+ KP, "5", "\033[E", "5", "", /* 76 kp 5 */
+ KP, "6", "\033[C", "6", "", /* 77 kp 6 */
+ KP, "+", "+", "+", "", /* 78 kp + */
+ KP, "1", "\033[F", "1", "", /* 79 kp 1 */
+ KP, "2", "\033[B", "2", "", /* 80 kp 2 */
+ KP, "3", "\033[G", "3", "", /* 81 kp 3 */
+ KP, "0", "\033[L", "0", "", /* 82 kp 0 */
+ KP, ".", "\177", ".", "", /* 83 kp . */
+ NONE, "", "", "", "", /* 84 0 */
+ NONE, "100", "", "", "", /* 85 0 */
+ ASCII, "<", ">", "\273", "|", /* 86 < > */
+ FUNC, "\033[W", "\033[i", "\033[u", "", /* 87 f11 */
+ FUNC, "\033[X", "\033[j", "\033[v", "", /* 88 f12 */
+ NONE, "102", "", "", "", /* 89 0 */
+ NONE, "103", "", "", "", /* 90 0 */
+ NONE, "", "", "", "", /* 91 0 */
+ NONE, "", "", "", "", /* 92 0 */
+ NONE, "", "", "", "", /* 93 0 */
+ NONE, "", "", "", "", /* 94 0 */
+ NONE, "", "", "", "", /* 95 0 */
+ NONE, "", "", "", "", /* 96 0 */
+ NONE, "", "", "", "", /* 97 0 */
+ NONE, "", "", "", "", /* 98 0 */
+ NONE, "", "", "", "", /* 99 0 */
+ NONE, "", "", "", "", /* 100 */
+ NONE, "", "", "", "", /* 101 */
+ NONE, "", "", "", "", /* 102 */
+ NONE, "", "", "", "", /* 103 */
+ NONE, "", "", "", "", /* 104 */
+ NONE, "", "", "", "", /* 105 */
+ NONE, "", "", "", "", /* 106 */
+ NONE, "", "", "", "", /* 107 */
+ NONE, "", "", "", "", /* 108 */
+ NONE, "", "", "", "", /* 109 */
+ NONE, "", "", "", "", /* 110 */
+ NONE, "", "", "", "", /* 111 */
+ NONE, "", "", "", "", /* 112 */
+ NONE, "", "", "", "", /* 113 */
+ NONE, "", "", "", "", /* 114 */
+ NONE, "", "", "", "", /* 115 */
+ NONE, "", "", "", "", /* 116 */
+ NONE, "", "", "", "", /* 117 */
+ NONE, "", "", "", "", /* 118 */
+ NONE, "", "", "", "", /* 119 */
+ NONE, "", "", "", "", /* 120 */
+ NONE, "", "", "", "", /* 121 */
+ NONE, "", "", "", "", /* 122 */
+ NONE, "", "", "", "", /* 123 */
+ NONE, "", "", "", "", /* 124 */
+ NONE, "", "", "", "", /* 125 */
+ NONE, "", "", "", "", /* 126 */
+ NONE, "", "", "", "", /* 127 */
};
@@ -1966,9 +1972,9 @@ pmsopen(dev, flag)
int unit = PMSUNIT(dev);
struct pms_softc *sc;
- if (unit >= pmscd.cd_ndevs)
+ if (unit >= pms_cd.cd_ndevs)
return ENXIO;
- sc = pmscd.cd_devs[unit];
+ sc = pms_cd.cd_devs[unit];
if (!sc)
return ENXIO;
@@ -2003,7 +2009,7 @@ pmsclose(dev, flag)
dev_t dev;
int flag;
{
- struct pms_softc *sc = pmscd.cd_devs[PMSUNIT(dev)];
+ struct pms_softc *sc = pms_cd.cd_devs[PMSUNIT(dev)];
/* Disable interrupts. */
pms_dev_cmd(PMS_DEV_DISABLE);
@@ -2023,7 +2029,7 @@ pmsread(dev, uio, flag)
struct uio *uio;
int flag;
{
- struct pms_softc *sc = pmscd.cd_devs[PMSUNIT(dev)];
+ struct pms_softc *sc = pms_cd.cd_devs[PMSUNIT(dev)];
int s;
int error;
size_t length;
@@ -2071,7 +2077,7 @@ pmsioctl(dev, cmd, addr, flag)
caddr_t addr;
int flag;
{
- struct pms_softc *sc = pmscd.cd_devs[PMSUNIT(dev)];
+ struct pms_softc *sc = pms_cd.cd_devs[PMSUNIT(dev)];
struct mouseinfo info;
int s;
int error;
@@ -2200,7 +2206,7 @@ pmsselect(dev, rw, p)
int rw;
struct proc *p;
{
- struct pms_softc *sc = pmscd.cd_devs[PMSUNIT(dev)];
+ struct pms_softc *sc = pms_cd.cd_devs[PMSUNIT(dev)];
int s;
int ret;