Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/usr.bin/config Split plain/interface/devclass attribute init...



details:   https://anonhg.NetBSD.org/src/rev/d96f0e2bd48d
branches:  trunk
changeset: 802949:d96f0e2bd48d
user:      uebayasi <uebayasi%NetBSD.org@localhost>
date:      Fri Oct 10 06:13:30 2014 +0000

description:
Split plain/interface/devclass attribute initializers.

diffstat:

 usr.bin/config/gram.y |    6 +-
 usr.bin/config/sem.c  |  113 ++++++++++++++++++++++++++++++++-----------------
 usr.bin/config/sem.h  |    5 +-
 3 files changed, 80 insertions(+), 44 deletions(-)

diffs (199 lines):

diff -r 9161f67eed59 -r d96f0e2bd48d usr.bin/config/gram.y
--- a/usr.bin/config/gram.y     Fri Oct 10 05:27:28 2014 +0000
+++ b/usr.bin/config/gram.y     Fri Oct 10 06:13:30 2014 +0000
@@ -1,5 +1,5 @@
 %{
-/*     $NetBSD: gram.y,v 1.41 2014/10/09 09:39:24 uebayasi Exp $       */
+/*     $NetBSD: gram.y,v 1.42 2014/10/10 06:13:30 uebayasi Exp $       */
 
 /*
  * Copyright (c) 1992, 1993
@@ -356,7 +356,7 @@
 ;
 
 define_devclass:
-       DEVCLASS WORD                   { (void)defattr($2, NULL, NULL, 1); }
+       DEVCLASS WORD                   { (void)defdevclass($2, NULL, NULL, 1); }
 ;
 
 define_filesystems:
@@ -365,7 +365,7 @@
 
 define_attribute:
        DEFINE WORD interface_opt depend_list
-                                       { (void)defattr($2, $3, $4, 0); }
+                                       { (void)defattr0($2, $3, $4, 0); }
 ;
 
 define_option:
diff -r 9161f67eed59 -r d96f0e2bd48d usr.bin/config/sem.c
--- a/usr.bin/config/sem.c      Fri Oct 10 05:27:28 2014 +0000
+++ b/usr.bin/config/sem.c      Fri Oct 10 06:13:30 2014 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: sem.c,v 1.48 2014/10/10 05:27:28 uebayasi Exp $        */
+/*     $NetBSD: sem.c,v 1.49 2014/10/10 06:13:30 uebayasi Exp $        */
 
 /*
  * Copyright (c) 1992, 1993
@@ -204,19 +204,24 @@
  * all locator lists include a dummy head node, which we discard here.
  */
 int
+defattr0(const char *name, struct loclist *locs, struct attrlist *deps,
+    int devclass)
+{
+
+       if (locs != NULL)
+               return defiattr(name, locs, deps, devclass);
+       else if (devclass)
+               return defdevclass(name, locs, deps, devclass);
+       else
+               return defattr(name, locs, deps, devclass);
+}
+
+int
 defattr(const char *name, struct loclist *locs, struct attrlist *deps,
     int devclass)
 {
        struct attr *a, *dep;
        struct attrlist *al;
-       struct loclist *ll;
-       int len;
-
-       if (locs != NULL && devclass)
-               panic("defattr(%s): locators and devclass", name);
-
-       if (deps != NULL && devclass)
-               panic("defattr(%s): dependencies and devclass", name);
 
        /*
         * If this attribute depends on any others, make sure none of
@@ -243,41 +248,69 @@
        a->a_deps = deps;
        a->a_expanding = 0;
        TAILQ_INIT(&a->a_files);
+       expandattr(a, NULL);
 
-       /* "interface attribute" initialization */
-       if (locs != NULL) {
-               a->a_iattr = 1;
-               /* unwrap */
-               a->a_locs = locs->ll_next;
-               locs->ll_next = NULL;
-               loclist_destroy(locs);
-               len = 0;
-               for (ll = a->a_locs; ll != NULL; ll = ll->ll_next)
-                       len++;
-               a->a_loclen = len;
-       }
+       return (0);
+}
+
+/* "interface attribute" initialization */
+int
+defiattr(const char *name, struct loclist *locs, struct attrlist *deps,
+    int devclass)
+{
+       struct attr *a;
+       int len;
+       struct loclist *ll;
+
+       if (devclass)
+               panic("defattr(%s): locators and devclass", name);
+
+       if (defattr(name, locs, deps, devclass) != 0)
+               return (1);
 
-       /* "device class" initialization */
-       if (devclass) {
-               char classenum[256], *cp;
-               int errored = 0;
+       a = getattr(name);
+       a->a_iattr = 1;
+       /* unwrap */
+       a->a_locs = locs->ll_next;
+       locs->ll_next = NULL;
+       loclist_destroy(locs);
+       len = 0;
+       for (ll = a->a_locs; ll != NULL; ll = ll->ll_next)
+               len++;
+       a->a_loclen = len;
+       if (deps)
+               CFGDBG(2, "attr `%s' iface with deps", a->a_name);
+       return (0);
+}
 
-               (void)snprintf(classenum, sizeof(classenum), "DV_%s", name);
-               for (cp = classenum + 3; *cp; cp++) {
-                       if (!errored &&
-                           (!isalnum((unsigned char)*cp) ||
-                             (isalpha((unsigned char)*cp) && !islower((unsigned char)*cp)))) {
-                               cfgerror("device class names must be "
-                                   "lower-case alphanumeric characters");
-                               errored = 1;
-                       }
-                       *cp = toupper((unsigned char)*cp);
+/* "device class" initialization */
+int
+defdevclass(const char *name, struct loclist *locs, struct attrlist *deps,
+    int devclass)
+{
+       struct attr *a;
+       char classenum[256], *cp;
+       int errored = 0;
+
+       if (deps)
+               panic("defattr(%s): dependencies and devclass", name);
+
+       if (defattr(name, locs, deps, devclass) != 0)
+               return (1);
+
+       a = getattr(name);
+       (void)snprintf(classenum, sizeof(classenum), "DV_%s", name);
+       for (cp = classenum + 3; *cp; cp++) {
+               if (!errored &&
+                   (!isalnum((unsigned char)*cp) ||
+                     (isalpha((unsigned char)*cp) && !islower((unsigned char)*cp)))) {
+                       cfgerror("device class names must be "
+                           "lower-case alphanumeric characters");
+                       errored = 1;
                }
-               a->a_devclass = intern(classenum);
+               *cp = toupper((unsigned char)*cp);
        }
-
-       /* Expand the attribute to check for cycles in the graph. */
-       expandattr(a, NULL);
+       a->a_devclass = intern(classenum);
 
        return (0);
 }
@@ -360,7 +393,7 @@
        if (loclist != NULL) {
                ll = loclist;
                loclist = NULL; /* defattr disposes of them for us */
-               if (defattr(dev->d_name, ll, NULL, 0))
+               if (defiattr(dev->d_name, ll, NULL, 0))
                        goto bad;
                attrs = attrlist_cons(attrs, getattr(dev->d_name));
                /* This used to be stored but was never used */
diff -r 9161f67eed59 -r d96f0e2bd48d usr.bin/config/sem.h
--- a/usr.bin/config/sem.h      Fri Oct 10 05:27:28 2014 +0000
+++ b/usr.bin/config/sem.h      Fri Oct 10 06:13:30 2014 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: sem.h,v 1.10 2012/03/11 21:16:08 dholland Exp $        */
+/*     $NetBSD: sem.h,v 1.11 2014/10/10 06:13:30 uebayasi Exp $        */
 
 /*
  * Copyright (c) 1992, 1993
@@ -46,7 +46,10 @@
 void           setdefmaxusers(int, int, int);
 void           setmaxusers(int);
 void           setident(const char *);
+int            defattr0(const char *, struct loclist *, struct attrlist *, int);
 int            defattr(const char *, struct loclist *, struct attrlist *, int);
+int            defiattr(const char *, struct loclist *, struct attrlist *, int);
+int            defdevclass(const char *, struct loclist *, struct attrlist *, int);
 void           defdev(struct devbase *, struct loclist *, struct attrlist *, int);
 void           defdevattach(struct deva *, struct devbase *, struct nvlist *,
                             struct attrlist *);



Home | Main Index | Thread Index | Old Index