Module Name: src
Committed By: apb
Date: Mon Aug 18 14:18:59 UTC 2014
Modified Files:
src/sys/dev/dkwedge: dkwedge_bsdlabel.c
Log Message:
Use FSTYPE_DEFN from <sys/disklabel.h> to generate case branches for
conversions from all known disklabel fstypes to strings. This replaces
the hand-coded list of conversions for only a few of the known types.
To generate a diff of this commit:
cvs rdiff -u -r1.20 -r1.21 src/sys/dev/dkwedge/dkwedge_bsdlabel.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/dev/dkwedge/dkwedge_bsdlabel.c
diff -u src/sys/dev/dkwedge/dkwedge_bsdlabel.c:1.20 src/sys/dev/dkwedge/dkwedge_bsdlabel.c:1.21
--- src/sys/dev/dkwedge/dkwedge_bsdlabel.c:1.20 Mon Aug 18 13:46:07 2014
+++ src/sys/dev/dkwedge/dkwedge_bsdlabel.c Mon Aug 18 14:18:59 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: dkwedge_bsdlabel.c,v 1.20 2014/08/18 13:46:07 apb Exp $ */
+/* $NetBSD: dkwedge_bsdlabel.c,v 1.21 2014/08/18 14:18:59 apb Exp $ */
/*-
* Copyright (c) 2004 The NetBSD Foundation, Inc.
@@ -79,7 +79,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: dkwedge_bsdlabel.c,v 1.20 2014/08/18 13:46:07 apb Exp $");
+__KERNEL_RCSID(0, "$NetBSD: dkwedge_bsdlabel.c,v 1.21 2014/08/18 14:18:59 apb Exp $");
#include <sys/param.h>
#ifdef _KERNEL
@@ -144,21 +144,15 @@ bsdlabel_fstype_to_str(uint8_t fstype)
{
const char *str;
+ /*
+ * For each type known to FSTYPE_DEFN (from <sys/disklabel.h>),
+ * a suitable case branch will convert the type number to a string.
+ */
switch (fstype) {
- case FS_UNUSED: str = DKW_PTYPE_UNUSED; break;
- case FS_SWAP: str = DKW_PTYPE_SWAP; break;
- case FS_BSDFFS: str = DKW_PTYPE_FFS; break;
- case FS_MSDOS: str = DKW_PTYPE_FAT; break;
- case FS_BSDLFS: str = DKW_PTYPE_LFS; break;
- case FS_ISO9660: str = DKW_PTYPE_ISO9660; break;
- case FS_ADOS: str = DKW_PTYPE_AMIGADOS; break;
- case FS_HFS: str = DKW_PTYPE_APPLEHFS; break;
- case FS_FILECORE: str = DKW_PTYPE_FILECORE; break;
- case FS_EX2FS: str = DKW_PTYPE_EXT2FS; break;
- case FS_NTFS: str = DKW_PTYPE_NTFS; break;
- case FS_RAID: str = DKW_PTYPE_RAIDFRAME; break;
- case FS_CCD: str = DKW_PTYPE_CCD; break;
- case FS_APPLEUFS: str = DKW_PTYPE_APPLEUFS; break;
+#define FSTYPE_TO_STR_CASE(tag, number, name, fsck, mount) \
+ case __CONCAT(FS_,tag): str = name; break;
+ FSTYPE_DEFN(FSTYPE_TO_STR_CASE)
+#undef FSTYPE_TO_STR_CASE
default: str = NULL; break;
}