summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Gwynne <dlg@cvs.openbsd.org>2006-08-20 02:20:05 +0000
committerDavid Gwynne <dlg@cvs.openbsd.org>2006-08-20 02:20:05 +0000
commit9f98c891e2dcb6744496680c8de5014666f0f3be (patch)
tree9ae18e4f139290627f87136bc4a29a691b17affe
parent42ff4d1f7204ac54e143b70f6da08399aebd5f14 (diff)
get rid of the old arc_msgbuf.
-rw-r--r--sys/dev/pci/arc.c117
1 files changed, 8 insertions, 109 deletions
diff --git a/sys/dev/pci/arc.c b/sys/dev/pci/arc.c
index 1fa90a167f0..e9fde707ee7 100644
--- a/sys/dev/pci/arc.c
+++ b/sys/dev/pci/arc.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: arc.c,v 1.30 2006/08/20 02:13:49 dlg Exp $ */
+/* $OpenBSD: arc.c,v 1.31 2006/08/20 02:20:04 dlg Exp $ */
/*
* Copyright (c) 2006 David Gwynne <dlg@openbsd.org>
@@ -392,14 +392,10 @@ int arc_query_firmware(struct arc_softc *);
void arc_lock(struct arc_softc *);
void arc_unlock(struct arc_softc *);
void arc_wait(struct arc_softc *);
-u_int8_t arc_msg_cksum(void *, size_t);
+u_int8_t arc_msg_cksum(void *, u_int16_t);
int arc_msgbuf(struct arc_softc *, void *, size_t,
void *, size_t);
-u_int8_t arc_msg_cksum2(void *cmd, u_int16_t len);
-int arc_msgbuf2(struct arc_softc *sc, void *wptr, size_t wbuflen, void *rptr,
- size_t rbuflen);
-
/* bioctl */
#if NBIO > 0
int arc_bioctl(struct device *, u_long, caddr_t);
@@ -899,7 +895,7 @@ arc_bio_alarm(struct arc_softc *sc, struct bioc_alarm *ba)
}
arc_lock(sc);
- error = arc_msgbuf2(sc, request, len, reply, sizeof(reply));
+ error = arc_msgbuf(sc, request, len, reply, sizeof(reply));
arc_unlock(sc);
if (error != 0)
@@ -925,7 +921,7 @@ arc_bio_alarm_state(struct arc_softc *sc, struct bioc_alarm *ba)
request = ARC_FW_SYSINFO;
arc_lock(sc);
- error = arc_msgbuf2(sc, &request, sizeof(request),
+ error = arc_msgbuf(sc, &request, sizeof(request),
sysinfo, sizeof(struct arc_fw_sysinfo));
arc_unlock(sc);
@@ -941,104 +937,7 @@ out:
#endif /* NBIO > 0 */
u_int8_t
-arc_msg_cksum(void *cmd, size_t len)
-{
- u_int8_t *buf = cmd;
- u_int8_t cksum = 0;
- int i;
-
- /* starts after the header, ends before the cksum */
- for (i = sizeof(struct arc_fw_hdr); i < (len - 1); i++)
- cksum += buf[i];
-
- return (cksum);
-}
-
-int
-arc_msgbuf(struct arc_softc *sc, void *wptr, size_t wlen, void *rptr,
- size_t rlen)
-{
- u_int8_t rwbuf[ARC_REG_IOC_RWBUF_MAXLEN];
- u_int8_t *wbuf = wptr, *rbuf = rptr;
- int wdone = 0, rdone = 0;
- u_int32_t reg, rwlen;
-#ifdef ARC_DEBUG
- int i;
-#endif
-
- DNPRINTF(ARC_D_DB, "%s: arc_msgbuf wlen: %d rlen: %d\n", DEVNAME(sc),
- wlen, rlen);
-
- if (arc_read(sc, ARC_REG_OUTB_DOORBELL) != 0)
- return (EBUSY);
-
- reg = ARC_REG_OUTB_DOORBELL_READ_OK;
-
- do {
- if ((reg & ARC_REG_OUTB_DOORBELL_READ_OK) && wdone < wlen) {
- bzero(rwbuf, sizeof(rwbuf));
- rwlen = (wlen - wdone) % sizeof(rwbuf);
- bcopy(&wbuf[wdone], rwbuf, rwlen);
- wdone += rwlen;
-
-#ifdef ARC_DEBUG
- if (arcdebug & ARC_D_DB) {
- printf("%s: write:", DEVNAME(sc));
- for (i = 0; i < rwlen; i++)
- printf(" 0x%02x", rwbuf[i]);
- printf("\n");
- }
-#endif
-
- /* copy the chunk to the hw */
- arc_write(sc, ARC_REG_IOC_WBUF_LEN, rwlen);
- arc_write_region(sc, ARC_REG_IOC_WBUF, rwbuf,
- sizeof(rwbuf));
-
- /* say we have a buffer for the hw */
- arc_write(sc, ARC_REG_INB_DOORBELL,
- ARC_REG_INB_DOORBELL_WRITE_OK);
- }
-
- while ((reg = arc_read(sc, ARC_REG_OUTB_DOORBELL)) == 0)
- arc_wait(sc);
- arc_write(sc, ARC_REG_OUTB_DOORBELL, reg);
-
- DNPRINTF(ARC_D_DB, "%s: reg: 0x%08x\n", DEVNAME(sc), reg);
-
- if ((reg & ARC_REG_OUTB_DOORBELL_WRITE_OK) && rdone < rlen) {
- rwlen = arc_read(sc, ARC_REG_IOC_RBUF_LEN);
- arc_read_region(sc, ARC_REG_IOC_RBUF, rwbuf,
- sizeof(rwbuf));
-
- arc_write(sc, ARC_REG_INB_DOORBELL,
- ARC_REG_INB_DOORBELL_READ_OK);
-
-#ifdef ARC_DEBUG
- printf("%s: len: %d+%d=%d/%d\n", DEVNAME(sc),
- rwlen, rdone, rwlen + rdone, rlen);
- if (arcdebug & ARC_D_DB) {
- printf("%s: read:", DEVNAME(sc));
- for (i = 0; i < rwlen; i++)
- printf(" 0x%02x", rwbuf[i]);
- printf("\n");
- }
-#endif
-
- if ((rdone + rwlen) > rlen)
- return (EIO);
-
- bcopy(rwbuf, &rbuf[rdone], rwlen);
- rdone += rwlen;
- }
-
- } while (rdone != rlen);
-
- return (0);
-}
-
-u_int8_t
-arc_msg_cksum2(void *cmd, u_int16_t len)
+arc_msg_cksum(void *cmd, u_int16_t len)
{
u_int8_t *buf = cmd;
u_int8_t cksum;
@@ -1053,7 +952,7 @@ arc_msg_cksum2(void *cmd, u_int16_t len)
int
-arc_msgbuf2(struct arc_softc *sc, void *wptr, size_t wbuflen, void *rptr,
+arc_msgbuf(struct arc_softc *sc, void *wptr, size_t wbuflen, void *rptr,
size_t rbuflen)
{
u_int8_t rwbuf[ARC_REG_IOC_RWBUF_MAXLEN];
@@ -1091,7 +990,7 @@ arc_msgbuf2(struct arc_softc *sc, void *wptr, size_t wbuflen, void *rptr,
bufhdr->hdr = arc_fw_hdr;
bufhdr->len = htole16(wbuflen);
bcopy(wptr, wbuf + sizeof(struct arc_fw_bufhdr), wbuflen);
- wbuf[wlen - 1] = arc_msg_cksum2(wptr, wbuflen);
+ wbuf[wlen - 1] = arc_msg_cksum(wptr, wbuflen);
reg = ARC_REG_OUTB_DOORBELL_READ_OK;
@@ -1176,7 +1075,7 @@ arc_msgbuf2(struct arc_softc *sc, void *wptr, size_t wbuflen, void *rptr,
bcopy(rbuf + sizeof(struct arc_fw_bufhdr), rptr, rbuflen);
- if (rbuf[rlen - 1] != arc_msg_cksum2(rptr, rbuflen)) {
+ if (rbuf[rlen - 1] != arc_msg_cksum(rptr, rbuflen)) {
DNPRINTF(ARC_D_DB, "%s: invalid cksum\n", DEVNAME(sc));
error = EIO;
goto out;