From 773d991fb0d90b5b8d25d378d7043919becab01e Mon Sep 17 00:00:00 2001 From: Kenneth R Westerback Date: Thu, 4 Jun 2009 05:57:28 +0000 Subject: Add DIOCRLDINFO to those drivers previously deprived. Noticed by & ok deraadt@ --- sys/arch/hp300/dev/hd.c | 10 +++++++++- sys/dev/ccd.c | 15 ++++++++++++++- sys/dev/vnd.c | 12 +++++++++++- 3 files changed, 34 insertions(+), 3 deletions(-) diff --git a/sys/arch/hp300/dev/hd.c b/sys/arch/hp300/dev/hd.c index 378270a69b9..3c0ee2dd9c8 100644 --- a/sys/arch/hp300/dev/hd.c +++ b/sys/arch/hp300/dev/hd.c @@ -1,4 +1,4 @@ -/* $OpenBSD: hd.c,v 1.55 2009/01/25 14:29:29 miod Exp $ */ +/* $OpenBSD: hd.c,v 1.56 2009/06/04 05:57:27 krw Exp $ */ /* $NetBSD: rd.c,v 1.33 1997/07/10 18:14:08 kleink Exp $ */ /* @@ -1137,6 +1137,7 @@ hdioctl(dev, cmd, data, flag, p) struct proc *p; { int unit = DISKUNIT(dev); + struct disklabel *lp; struct hd_softc *sc; int error = 0; @@ -1145,6 +1146,13 @@ hdioctl(dev, cmd, data, flag, p) return (ENXIO); switch (cmd) { + case DIOCRLDINFO: + lp = malloc(sizeof(*lp), M_TEMP, M_WAITOK); + hdgetdisklabel(dev, sc, lp, 0); + *(sc->sc_dkdev.dk_label) = *lp; + free(lp, M_TEMP); + return 0; + case DIOCGPDINFO: hdgetdisklabel(dev, sc, (struct disklabel *)data, 1); goto exit; diff --git a/sys/dev/ccd.c b/sys/dev/ccd.c index 42609c64f8f..18169e5efd2 100644 --- a/sys/dev/ccd.c +++ b/sys/dev/ccd.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ccd.c,v 1.85 2008/07/01 04:15:59 ray Exp $ */ +/* $OpenBSD: ccd.c,v 1.86 2009/06/04 05:57:27 krw Exp $ */ /* $NetBSD: ccd.c,v 1.33 1996/05/05 04:21:14 thorpej Exp $ */ /*- @@ -1012,6 +1012,7 @@ ccdioctl(dev_t dev, u_long cmd, caddr_t data, int flag, struct proc *p) int unit = DISKUNIT(dev); int i, j, lookedup = 0, error = 0; int part, pmask, s; + struct disklabel *lp; struct ccd_softc *cs; struct ccd_ioctl *ccio = (struct ccd_ioctl *)data; struct ccddevice ccd; @@ -1191,6 +1192,18 @@ ccdioctl(dev_t dev, u_long cmd, caddr_t data, int flag, struct proc *p) splx(s); break; + case DIOCRLDINFO: + if ((error = ccdlock(cs)) != 0) + return (error); + + lp = malloc(sizeof(*lp), M_TEMP, M_WAITOK); + ccdgetdisklabel(dev, cs, lp, 0); + *(cs->sc_dkdev.dk_label) = *lp; + free(lp, M_TEMP); + + ccdunlock(cs); + break; + case DIOCGPDINFO: if ((error = ccdlock(cs)) != 0) return (error); diff --git a/sys/dev/vnd.c b/sys/dev/vnd.c index 1ac734d5233..8cbda77ef91 100644 --- a/sys/dev/vnd.c +++ b/sys/dev/vnd.c @@ -1,4 +1,4 @@ -/* $OpenBSD: vnd.c,v 1.91 2009/06/03 22:09:30 thib Exp $ */ +/* $OpenBSD: vnd.c,v 1.92 2009/06/04 05:57:27 krw Exp $ */ /* $NetBSD: vnd.c,v 1.26 1996/03/30 23:06:11 christos Exp $ */ /* @@ -749,6 +749,7 @@ int vndioctl(dev_t dev, u_long cmd, caddr_t addr, int flag, struct proc *p) { int unit = vndunit(dev); + struct disklabel *lp; struct vnd_softc *vnd; struct vnd_ioctl *vio; struct vnd_user *vnu; @@ -945,6 +946,15 @@ vndioctl(dev_t dev, u_long cmd, caddr_t addr, int flag, struct proc *p) break; + case DIOCRLDINFO: + if ((vnd->sc_flags & VNF_HAVELABEL) == 0) + return (ENOTTY); + lp = malloc(sizeof(*lp), M_TEMP, M_WAITOK); + vndgetdisklabel(dev, vnd, lp, 0); + *(vnd->sc_dk.dk_label) = *lp; + free(lp, M_TEMP); + return (0); + case DIOCGPDINFO: if ((vnd->sc_flags & VNF_HAVELABEL) == 0) return (ENOTTY); -- cgit v1.2.3