Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev Provide a more complete modules hook, cgd_modcmd(), ...
details: https://anonhg.NetBSD.org/src/rev/eb568a3d165a
branches: trunk
changeset: 750749:eb568a3d165a
user: dyoung <dyoung%NetBSD.org@localhost>
date: Tue Jan 12 23:49:34 2010 +0000
description:
Provide a more complete modules hook, cgd_modcmd(), derived from
vnd_modcmd().
diffstat:
sys/dev/cgd.c | 31 ++++++++++++++++++++++++++-----
1 files changed, 26 insertions(+), 5 deletions(-)
diffs (64 lines):
diff -r 8a962704a600 -r eb568a3d165a sys/dev/cgd.c
--- a/sys/dev/cgd.c Tue Jan 12 22:26:30 2010 +0000
+++ b/sys/dev/cgd.c Tue Jan 12 23:49:34 2010 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cgd.c,v 1.65 2010/01/12 21:08:08 dyoung Exp $ */
+/* $NetBSD: cgd.c,v 1.66 2010/01/12 23:49:34 dyoung Exp $ */
/*-
* Copyright (c) 2002 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: cgd.c,v 1.65 2010/01/12 21:08:08 dyoung Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cgd.c,v 1.66 2010/01/12 23:49:34 dyoung Exp $");
#include <sys/types.h>
#include <sys/param.h>
@@ -928,6 +928,7 @@
#include <sys/module.h>
MODULE(MODULE_CLASS_DRIVER, cgd, NULL);
+CFDRIVER_DECL(cgd, DV_DISK, NULL);
static int
cgd_modcmd(modcmd_t cmd, void *arg)
@@ -936,14 +937,34 @@
switch (cmd) {
case MODULE_CMD_INIT:
- cgdattach(4);
+ error = config_cfdriver_attach(&cgd_cd);
+ if (error)
+ break;
+
+ error = config_cfattach_attach(cgd_cd.cd_name, &cgd_ca);
+ if (error) {
+ config_cfdriver_detach(&cgd_cd);
+ aprint_error("%s: unable to register cfattach\n",
+ cgd_cd.cd_name);
+ break;
+ }
- return devsw_attach("cgd", &cgd_bdevsw, &bmajor,
+ error = devsw_attach("cgd", &cgd_bdevsw, &bmajor,
&cgd_cdevsw, &cmajor);
+ if (error) {
+ config_cfattach_detach(cgd_cd.cd_name, &cgd_ca);
+ config_cfdriver_detach(&cgd_cd);
+ break;
+ }
+
break;
case MODULE_CMD_FINI:
- return devsw_detach(&cgd_bdevsw, &cgd_cdevsw);
+ error = config_cfattach_detach(cgd_cd.cd_name, &cgd_ca);
+ if (error)
+ break;
+ config_cfdriver_detach(&cgd_cd);
+ devsw_detach(&cgd_bdevsw, &cgd_cdevsw);
break;
case MODULE_CMD_STAT:
Home |
Main Index |
Thread Index |
Old Index