Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sbin/gpt print the current map type.
details:   https://anonhg.NetBSD.org/src/rev/52fdfeb12cb8
branches:  trunk
changeset: 812058:52fdfeb12cb8
user:      christos <christos%NetBSD.org@localhost>
date:      Sun Nov 29 00:34:39 2015 +0000
description:
print the current map type.
diffstat:
 sbin/gpt/map.c |  39 ++++++++++++++++++++++++++++-----------
 1 files changed, 28 insertions(+), 11 deletions(-)
diffs (64 lines):
diff -r 2883c8f398e7 -r 52fdfeb12cb8 sbin/gpt/map.c
--- a/sbin/gpt/map.c    Sun Nov 29 00:15:12 2015 +0000
+++ b/sbin/gpt/map.c    Sun Nov 29 00:34:39 2015 +0000
@@ -33,7 +33,7 @@
 __FBSDID("$FreeBSD: src/sbin/gpt/map.c,v 1.6 2005/08/31 01:47:19 marcel Exp $");
 #endif
 #ifdef __RCSID
-__RCSID("$NetBSD: map.c,v 1.8 2015/11/29 00:15:12 christos Exp $");
+__RCSID("$NetBSD: map.c,v 1.9 2015/11/29 00:34:39 christos Exp $");
 #endif
 
 #include <sys/types.h>
@@ -65,6 +65,26 @@
        return (m);
 }
 
+static const char *maptypes[]  = {
+       "unused",
+       "mbr",
+       "mbr partition",
+       "primary gpt header",
+       "secondary gpt header",
+       "primary gpt table",
+       "secondary gpt table",
+       "gpt partition",
+       "protective mbr",
+};
+
+static const char *
+map_type(int t)
+{
+       if ((size_t)t >= __arraycount(maptypes))
+               return "*unknown*";
+       return maptypes[t];
+}
+
 map_t *
 map_add(off_t start, off_t size, int type, void *data)
 {
@@ -99,17 +119,14 @@
                return (n);
        }
 
-       
-       switch (n->map_type) {
-       case MAP_TYPE_MBR_PART:
-       case MAP_TYPE_GPT_PART:
+       if (n->map_type != MAP_TYPE_UNUSED) {
+               if (n->map_type != MAP_TYPE_MBR_PART ||
+                   type != MAP_TYPE_GPT_PART) {
+                       warnx("bogus map current=%s new=%s",
+                           map_type(n->map_type), map_type(type));
+                       return (NULL);
+               }
                n->map_type = MAP_TYPE_UNUSED;
-               break;
-       case MAP_TYPE_UNUSED:
-               break;
-       default:
-               warnx("bogus map %#x", n->map_type);
-               return (NULL);
        }
 
        m = mkmap(start, size, type);
Home |
Main Index |
Thread Index |
Old Index