summaryrefslogtreecommitdiff
path: root/sys/dev
diff options
context:
space:
mode:
authorMarco Peereboom <marco@cvs.openbsd.org>2008-11-03 01:42:16 +0000
committerMarco Peereboom <marco@cvs.openbsd.org>2008-11-03 01:42:16 +0000
commit9e240a5d48a1ca3a810790ecfa4b716b6e43a16e (patch)
treef957d5cb81a0e172f3c3a46c2ee12ee57d8a9021 /sys/dev
parent7680100ffb9bf7692b3fca20b6e4284b1d8a5302 (diff)
Don't attach bio unless we do RAID.
Diffstat (limited to 'sys/dev')
-rw-r--r--sys/dev/ic/mpi.c52
1 files changed, 28 insertions, 24 deletions
diff --git a/sys/dev/ic/mpi.c b/sys/dev/ic/mpi.c
index 57dc48e5581..f885e2ab104 100644
--- a/sys/dev/ic/mpi.c
+++ b/sys/dev/ic/mpi.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: mpi.c,v 1.103 2008/11/01 23:09:29 marco Exp $ */
+/* $OpenBSD: mpi.c,v 1.104 2008/11/03 01:42:15 marco Exp $ */
/*
* Copyright (c) 2005, 2006 David Gwynne <dlg@openbsd.org>
@@ -290,30 +290,32 @@ mpi_attach(struct mpi_softc *sc)
#ifdef notyet
#if NBIO > 0
- if (bio_register(&sc->sc_dev, mpi_ioctl) != 0)
- panic("%s: controller registration failed", DEVNAME(sc));
- else {
- if (mpi_cfg_header(sc, MPI_CONFIG_REQ_PAGE_TYPE_IOC, 2, 0,
- &sc->sc_cfg_hdr) != 0) {
- printf("%s: can't get IOC page 2 hdr, bio disabled\n",
+ if (sc->sc_flags & MPI_F_RAID) {
+ if (bio_register(&sc->sc_dev, mpi_ioctl) != 0)
+ panic("%s: controller registration failed",
DEVNAME(sc));
- goto done;
- }
- sc->sc_vol_page = malloc(sc->sc_cfg_hdr.page_length * 4, M_TEMP,
- M_WAITOK | M_CANFAIL);
- if (sc->sc_vol_page == NULL) {
- printf("%s: can't get memory for IOC page 2, "
- "bio disabled\n", DEVNAME(sc));
- goto done;
- }
- sc->sc_vol_list = (struct mpi_cfg_raid_vol *)
- (sc->sc_vol_page + 1);
+ else {
+ if (mpi_cfg_header(sc, MPI_CONFIG_REQ_PAGE_TYPE_IOC,
+ 2, 0, &sc->sc_cfg_hdr) != 0) {
+ printf("%s: can't get IOC page 2 hdr, bio "
+ "disabled\n", DEVNAME(sc));
+ goto done;
+ }
+ sc->sc_vol_page = malloc(sc->sc_cfg_hdr.page_length * 4,
+ M_TEMP, M_WAITOK | M_CANFAIL);
+ if (sc->sc_vol_page == NULL) {
+ printf("%s: can't get memory for IOC page 2, "
+ "bio disabled\n", DEVNAME(sc));
+ goto done;
+ }
+ sc->sc_vol_list = (struct mpi_cfg_raid_vol *)
+ (sc->sc_vol_page + 1);
- sc->sc_ioctl = mpi_ioctl;
+ sc->sc_ioctl = mpi_ioctl;
+ }
}
#ifndef SMALL_KERNEL
- if (mpi_create_sensors(sc) != 0)
- printf("%s: unable to create sensors\n", DEVNAME(sc));
+ mpi_create_sensors(sc);
#endif /* SMALL_KERNEL */
done:
#endif /* NBIO > 0 */
@@ -2645,9 +2647,6 @@ mpi_ioctl(struct device *dev, u_long cmd, caddr_t addr)
DNPRINTF(MPI_D_IOCTL, "%s: mpi_ioctl ", DEVNAME(sc));
- if (!(sc->sc_flags & MPI_F_RAID))
- return (EINVAL);
-
/* make sure we have bio enabled */
if (sc->sc_ioctl != mpi_ioctl)
return (EINVAL);
@@ -2696,6 +2695,11 @@ mpi_ioctl(struct device *dev, u_long cmd, caddr_t addr)
int
mpi_ioctl_inq(struct mpi_softc *sc, struct bioc_inq *bi)
{
+ if (!(sc->sc_flags & MPI_F_RAID)) {
+ bi->bi_novol = 0;
+ bi->bi_nodisk = 0;
+ }
+
if (mpi_cfg_page(sc, 0, &sc->sc_cfg_hdr, 1, sc->sc_vol_page,
sc->sc_cfg_hdr.page_length * 4) != 0) {
DNPRINTF(MPI_D_IOCTL, "%s: mpi_get_raid unable to fetch IOC "