Author: marcel
Date: Sun Aug 16 21:27:35 2009
New Revision: 196278
URL: http://svn.freebsd.org/changeset/base/196278

Log:
  Emit a proper error message instead of dumping core when 1)
  GEOM_PART does not exist in the kernel, and 2) the GEOM in
  question does not exist.
  Additionally abort in case of programming errors that result
  in neither the class nor geom not being present in the gctl
  request.
  
  Submitted by: "Andrey V. Elsukov" <bu7c...@yandex.ru>
  Approved by:  re (kib)

Modified:
  head/sbin/geom/class/part/geom_part.c

Modified: head/sbin/geom/class/part/geom_part.c
==============================================================================
--- head/sbin/geom/class/part/geom_part.c       Sun Aug 16 20:33:16 2009        
(r196277)
+++ head/sbin/geom/class/part/geom_part.c       Sun Aug 16 21:27:35 2009        
(r196278)
@@ -274,8 +274,18 @@ gpart_autofill(struct gctl_req *req)
        error = geom_gettree(&mesh);
        if (error)
                return (error);
-       cp = find_class(&mesh, gctl_get_ascii(req, "class"));
-       gp = find_geom(cp, gctl_get_ascii(req, "geom"));
+       s = gctl_get_ascii(req, "class");
+       if (s == NULL)
+               abort();
+       cp = find_class(&mesh, s);
+       if (cp == NULL)
+               errx(EXIT_FAILURE, "Class %s not found.", s);
+       s = gctl_get_ascii(req, "geom");
+       if (s == NULL)
+               abort();
+       gp = find_geom(cp, s);
+       if (gp == NULL)
+               errx(EXIT_FAILURE, "No such geom: %s.", s);
        first = atoll(find_geomcfg(gp, "first"));
        last = atoll(find_geomcfg(gp, "last"));
        grade = ~0ULL;
@@ -536,6 +546,8 @@ gpart_write_partcode(struct gctl_req *re
                errx(EXIT_FAILURE, "Class %s not found.", s);
        }
        s = gctl_get_ascii(req, "geom");
+       if (s == NULL)
+               abort();
        gp = find_geom(classp, s);
        if (gp == NULL)
                errx(EXIT_FAILURE, "No such geom: %s.", s);
_______________________________________________
svn-src-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to