Module Name:    src
Committed By:   dyoung
Date:           Tue Jan 19 21:24:36 UTC 2010

Modified Files:
        src/sys/kern: subr_autoconf.c

Log Message:
Refactor: as suggested by rmind@, extract duplicate code into
subroutines config_alldevs_enter() and config_alldevs_exit().  This
change amounts to textual substitution.  No functional change intended.

We do not collect garbage in device_lookup(), so there is no use dumping
it: get rid of the garbage list.  Do not call config_dump_garbage().

In device_lookup_private(), call device_lookup() instead of duplicating
the code from device_lookup().


To generate a diff of this commit:
cvs rdiff -u -r1.197 -r1.198 src/sys/kern/subr_autoconf.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/kern/subr_autoconf.c
diff -u src/sys/kern/subr_autoconf.c:1.197 src/sys/kern/subr_autoconf.c:1.198
--- src/sys/kern/subr_autoconf.c:1.197	Tue Jan 12 22:11:13 2010
+++ src/sys/kern/subr_autoconf.c	Tue Jan 19 21:24:36 2010
@@ -1,4 +1,4 @@
-/* $NetBSD: subr_autoconf.c,v 1.197 2010/01/12 22:11:13 rmind Exp $ */
+/* $NetBSD: subr_autoconf.c,v 1.198 2010/01/19 21:24:36 dyoung Exp $ */
 
 /*
  * Copyright (c) 1996, 2000 Christopher G. Demetriou
@@ -77,7 +77,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: subr_autoconf.c,v 1.197 2010/01/12 22:11:13 rmind Exp $");
+__KERNEL_RCSID(0, "$NetBSD: subr_autoconf.c,v 1.198 2010/01/19 21:24:36 dyoung Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_ddb.h"
@@ -162,6 +162,11 @@
 	int	pri;
 };
 
+struct alldevs_foray {
+	int			af_s;
+	struct devicelist	af_garbage;
+};
+
 static char *number(char *, int);
 static void mapply(struct matchinfo *, cfdata_t);
 static device_t config_devalloc(const device_t, const cfdata_t, const int *);
@@ -171,6 +176,8 @@
 static void config_devlink(device_t);
 static void config_alldevs_unlock(int);
 static int config_alldevs_lock(void);
+static void config_alldevs_enter(struct alldevs_foray *);
+static void config_alldevs_exit(struct alldevs_foray *);
 
 static void config_collect_garbage(struct devicelist *);
 static void config_dump_garbage(struct devicelist *);
@@ -370,11 +377,10 @@
 int
 config_cfdriver_detach(struct cfdriver *cd)
 {
-	struct devicelist garbage = TAILQ_HEAD_INITIALIZER(garbage);
-	int i, rc = 0, s;
+	struct alldevs_foray af;
+	int i, rc = 0;
 
-	s = config_alldevs_lock();
-	config_collect_garbage(&garbage);
+	config_alldevs_enter(&af);
 	/* Make sure there are no active instances. */
 	for (i = 0; i < cd->cd_ndevs; i++) {
 		if (cd->cd_devs[i] != NULL) {
@@ -382,8 +388,7 @@
 			break;
 		}
 	}
-	config_alldevs_unlock(s);
-	config_dump_garbage(&garbage);
+	config_alldevs_exit(&af);
 
 	if (rc != 0)
 		return rc;
@@ -445,17 +450,16 @@
 int
 config_cfattach_detach(const char *driver, struct cfattach *ca)
 {
-	struct devicelist garbage = TAILQ_HEAD_INITIALIZER(garbage);
+	struct alldevs_foray af;
 	struct cfdriver *cd;
 	device_t dev;
-	int i, rc = 0, s;
+	int i, rc = 0;
 
 	cd = config_cfdriver_lookup(driver);
 	if (cd == NULL)
 		return ESRCH;
 
-	s = config_alldevs_lock();
-	config_collect_garbage(&garbage);
+	config_alldevs_enter(&af);
 	/* Make sure there are no active instances. */
 	for (i = 0; i < cd->cd_ndevs; i++) {
 		if ((dev = cd->cd_devs[i]) == NULL)
@@ -465,8 +469,7 @@
 			break;
 		}
 	}
-	config_alldevs_unlock(s);
-	config_dump_garbage(&garbage);
+	config_alldevs_exit(&af);
 
 	if (rc != 0)
 		return rc;
@@ -1116,12 +1119,11 @@
 static int
 config_unit_alloc(device_t dev, cfdriver_t cd, cfdata_t cf)
 {
-	struct devicelist garbage = TAILQ_HEAD_INITIALIZER(garbage);
-	int s, unit;
+	struct alldevs_foray af;
+	int unit;
 
-	s = config_alldevs_lock();
+	config_alldevs_enter(&af);
 	for (;;) {
-		config_collect_garbage(&garbage);
 		unit = config_unit_nextfree(cd, cf);
 		if (unit == -1)
 			break;
@@ -1132,8 +1134,7 @@
 		}
 		config_makeroom(unit, cd);
 	}
-	config_alldevs_unlock(s);
-	config_dump_garbage(&garbage);
+	config_alldevs_exit(&af);
 
 	return unit;
 }
@@ -1141,7 +1142,6 @@
 static device_t
 config_devalloc(const device_t parent, const cfdata_t cf, const int *locs)
 {
-	struct devicelist garbage = TAILQ_HEAD_INITIALIZER(garbage);
 	cfdriver_t cd;
 	cfattach_t ca;
 	size_t lname, lunit;
@@ -1420,7 +1420,7 @@
 int
 config_detach(device_t dev, int flags)
 {
-	struct devicelist garbage = TAILQ_HEAD_INITIALIZER(garbage);
+	struct alldevs_foray af;
 	struct cftable *ct;
 	cfdata_t cf;
 	const struct cfattach *ca;
@@ -1528,16 +1528,12 @@
 		aprint_normal_dev(dev, "detached\n");
 
 out:
-	s = config_alldevs_lock();
+	config_alldevs_enter(&af);
 	KASSERT(alldevs_nwrite != 0);
 	--alldevs_nwrite;
-	if (rv == 0 && dev->dv_del_gen == 0) {
-		dev->dv_del_gen = alldevs_gen;
-		alldevs_garbage = true;
-	}
-	config_collect_garbage(&garbage);
-	config_alldevs_unlock(s);
-	config_dump_garbage(&garbage);
+	if (rv == 0 && dev->dv_del_gen == 0)
+		config_devunlink(dev, &af.af_garbage);
+	config_alldevs_exit(&af);
 
 	return rv;
 }
@@ -1886,6 +1882,21 @@
 }
 
 static void
+config_alldevs_enter(struct alldevs_foray *af)
+{
+	TAILQ_INIT(&af->af_garbage);
+	af->af_s = config_alldevs_lock();
+	config_collect_garbage(&af->af_garbage);
+} 
+
+static void
+config_alldevs_exit(struct alldevs_foray *af)
+{
+	config_alldevs_unlock(af->af_s);
+	config_dump_garbage(&af->af_garbage);
+}
+
+static void
 config_alldevs_unlock(int s)
 {
 	mutex_exit(&alldevs_mtx);
@@ -1900,7 +1911,6 @@
 device_t
 device_lookup(cfdriver_t cd, int unit)
 {
-	struct devicelist garbage = TAILQ_HEAD_INITIALIZER(garbage);
 	device_t dv;
 	int s;
 
@@ -1911,7 +1921,6 @@
 	else if ((dv = cd->cd_devs[unit]) != NULL && dv->dv_del_gen != 0)
 		dv = NULL;
 	config_alldevs_unlock(s);
-	config_dump_garbage(&garbage);
 
 	return dv;
 }
@@ -1924,12 +1933,8 @@
 void *
 device_lookup_private(cfdriver_t cd, int unit)
 {
-	device_t dv;
-
-	if ((dv = device_lookup(cd, unit)) == NULL)
-		return NULL;
 
-	return dv->dv_private;
+	return device_private(device_lookup(cd, unit));
 }
 
 /*

Reply via email to