patch: clean up msdosfs conversion routine

Nate Lawson nate at root.org
Sat Mar 5 23:42:21 PST 2005


The attached patch optimizes the unix2win conversion routine.  It uses 
16 bit accesses instead of 8 bit and jumps to "out" once it hits the 
trailing NUL rather than drop through each loop.  I'd like to make sure 
my use of the endian routines is correct, if someone can check this.

Thanks,
-- 
Nate
-------------- next part --------------
Index: msdosfs_conv.c
===================================================================
RCS file: /home/ncvs/src/sys/fs/msdosfs/msdosfs_conv.c,v
retrieving revision 1.39
diff -u -r1.39 msdosfs_conv.c
--- msdosfs_conv.c	8 Feb 2005 07:51:14 -0000	1.39
+++ msdosfs_conv.c	2 Mar 2005 17:48:52 -0000
@@ -52,6 +52,7 @@
  * System include files.
  */
 #include <sys/param.h>
+#include <sys/endian.h>
 #include <sys/time.h>
 #include <sys/kernel.h>		/* defines tz */
 #include <sys/systm.h>
@@ -708,9 +711,8 @@
 	int chksum;
 	struct msdosfsmount *pmp;
 {
-	u_int8_t *wcp;
-	int i, end;
-	u_int16_t code;
+	u_int16_t *wcp;
+	int end, i;
 
 	/*
 	 * Drop trailing blanks and dots
@@ -726,7 +728,7 @@
 	/*
 	 * Initialize winentry to some useful default
 	 */
-	for (wcp = (u_int8_t *)wep, i = sizeof(*wep); --i >= 0; *wcp++ = 0xff);
+	memset(wep, 0xff, sizeof(*wep));
 	wep->weCnt = cnt;
 	wep->weAttributes = ATTR_WIN95;
 	wep->weReserved1 = 0;
@@ -737,29 +739,34 @@
 	 * Now convert the filename parts
 	 */
 	end = 0;
-	for (wcp = wep->wePart1, i = sizeof(wep->wePart1)/2; --i >= 0 && !end;) {
-		code = unix2winchr(&un, &unlen, 0, pmp);
-		*wcp++ = code;
-		*wcp++ = code >> 8;
-		if (!code)
+	wcp = (uint16_t *)wep->wePart1;
+	for (i = sizeof(wep->wePart1)/2; --i >= 0;) {
+		*wcp = htole16(unix2winchr(&un, &unlen, 0, pmp));
+		if (*wcp++ == 0) {
 			end = WIN_LAST;
+			goto out;
+		}
 	}
-	for (wcp = wep->wePart2, i = sizeof(wep->wePart2)/2; --i >= 0 && !end;) {
-		code = unix2winchr(&un, &unlen, 0, pmp);
-		*wcp++ = code;
-		*wcp++ = code >> 8;
-		if (!code)
+	wcp = (uint16_t *)wep->wePart2;
+	for (i = sizeof(wep->wePart2)/2; --i >= 0;) {
+		*wcp = htole16(unix2winchr(&un, &unlen, 0, pmp));
+		if (*wcp++ == 0) {
 			end = WIN_LAST;
+			goto out;
+		}
 	}
-	for (wcp = wep->wePart3, i = sizeof(wep->wePart3)/2; --i >= 0 && !end;) {
-		code = unix2winchr(&un, &unlen, 0, pmp);
-		*wcp++ = code;
-		*wcp++ = code >> 8;
-		if (!code)
+	wcp = (uint16_t *)wep->wePart3;
+	for (i = sizeof(wep->wePart3)/2; --i >= 0;) {
+		*wcp = htole16(unix2winchr(&un, &unlen, 0, pmp));
+		if (*wcp++ == 0) {
 			end = WIN_LAST;
+			goto out;
+		}
 	}
 	if (*un == '\0')
 		end = WIN_LAST;
+
+out:
 	wep->weCnt |= end;
 	return !end;
 }


More information about the freebsd-arch mailing list