summaryrefslogtreecommitdiff
path: root/sys/dev
diff options
context:
space:
mode:
authorDavid Gwynne <dlg@cvs.openbsd.org>2006-08-14 15:22:28 +0000
committerDavid Gwynne <dlg@cvs.openbsd.org>2006-08-14 15:22:28 +0000
commitdbf6c19015bc8cb84596b21250bebdfdbdced5ae (patch)
tree5a2829c12b9f9349eaceeb9810828e36d371fb75 /sys/dev
parent8377bcb6bb7e4365da274fc70255b527f5706efe (diff)
start and stop bgrb during attach and detach respectively. as a bonus
flush the hbas cache on detach as well. writes on my raid5 seem to run fast now.
Diffstat (limited to 'sys/dev')
-rw-r--r--sys/dev/pci/arc.c37
1 files changed, 32 insertions, 5 deletions
diff --git a/sys/dev/pci/arc.c b/sys/dev/pci/arc.c
index b19a447852a..3688206166a 100644
--- a/sys/dev/pci/arc.c
+++ b/sys/dev/pci/arc.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: arc.c,v 1.17 2006/08/14 14:43:36 dlg Exp $ */
+/* $OpenBSD: arc.c,v 1.18 2006/08/14 15:22:27 dlg Exp $ */
/*
* Copyright (c) 2006 David Gwynne <dlg@openbsd.org>
@@ -245,6 +245,7 @@ int arc_wait_eq(struct arc_softc *, bus_size_t,
u_int32_t, u_int32_t);
int arc_wait_ne(struct arc_softc *, bus_size_t,
u_int32_t, u_int32_t);
+int arc_msg0(struct arc_softc *, u_int32_t);
#define arc_push(_s, _r) arc_write((_s), ARC_REG_POST_QUEUE, (_r))
#define arc_pop(_s) arc_read((_s), ARC_REG_REPLY_QUEUE)
@@ -340,6 +341,14 @@ arc_attach(struct device *parent, struct device *self, void *aux)
int
arc_detach(struct device *self, int flags)
{
+ struct arc_softc *sc = (struct arc_softc *)self;
+
+ if (arc_msg0(sc, ARC_REG_INB_MSG0_STOP_BGRB) != 0)
+ printf("%s: timeout waiting to stop bg rebuild\n");
+
+ if (arc_msg0(sc, ARC_REG_INB_MSG0_FLUSH_CACHE) != 0)
+ printf("%s: timeout waiting to flush cache\n");
+
return (0);
}
@@ -618,13 +627,10 @@ arc_query_firmware(struct arc_softc *sc)
return (1);
}
- arc_write(sc, ARC_REG_INB_MSG0, ARC_REG_INB_MSG0_GET_CONFIG);
- if (arc_wait_eq(sc, ARC_REG_INTRSTAT, ARC_REG_INTRSTAT_MSG0,
- ARC_REG_INTRSTAT_MSG0) != 0) {
+ if (arc_msg0(sc, ARC_REG_INB_MSG0_GET_CONFIG) != 0) {
printf("%s: timeout waiting for get config\n");
return (1);
}
- arc_write(sc, ARC_REG_INTRSTAT, ARC_REG_INTRSTAT_MSG0);
arc_read_region(sc, ARC_REG_MSGBUF, &fwinfo, sizeof(fwinfo));
@@ -665,6 +671,11 @@ arc_query_firmware(struct arc_softc *sc)
sc->sc_req_count = letoh32(fwinfo.queue_len);
+ if (arc_msg0(sc, ARC_REG_INB_MSG0_START_BGRB) != 0) {
+ printf("%s: timeout waiting to start bg rebuild\n");
+ return (1);
+ }
+
printf("%s: %d SATA Ports, %dMB SDRAM, FW Version: %s\n",
DEVNAME(sc), letoh32(fwinfo.sata_ports),
letoh32(fwinfo.sdram_size), string);
@@ -748,6 +759,22 @@ arc_wait_ne(struct arc_softc *sc, bus_size_t r, u_int32_t mask,
return (1);
}
+int
+arc_msg0(struct arc_softc *sc, u_int32_t m)
+{
+ /* post message */
+ arc_write(sc, ARC_REG_INB_MSG0, m);
+ /* wait for the fw to do it */
+ if (arc_wait_eq(sc, ARC_REG_INTRSTAT, ARC_REG_INTRSTAT_MSG0,
+ ARC_REG_INTRSTAT_MSG0) != 0)
+ return (1);
+
+ /* ack it */
+ arc_write(sc, ARC_REG_INTRSTAT, ARC_REG_INTRSTAT_MSG0);
+
+ return (0);
+}
+
struct arc_dmamem *
arc_dmamem_alloc(struct arc_softc *sc, size_t size)
{