Sun Jan 23 02:08:24 2011 UTC ()
fix a failure in the sign extension consideration.


(nisimura)
diff -r1.2 -r1.3 src/sys/arch/sandpoint/stand/altboot/printf.c

cvs diff -r1.2 -r1.3 src/sys/arch/sandpoint/stand/altboot/Attic/printf.c (expand / switch to context diff)
--- src/sys/arch/sandpoint/stand/altboot/Attic/printf.c 2011/01/23 01:32:08 1.2
+++ src/sys/arch/sandpoint/stand/altboot/Attic/printf.c 2011/01/23 02:08:24 1.3
@@ -1,4 +1,4 @@
-/* $NetBSD: printf.c,v 1.2 2011/01/23 01:32:08 nisimura Exp $ */
+/* $NetBSD: printf.c,v 1.3 2011/01/23 02:08:24 nisimura Exp $ */
 
 /*-
  * Copyright (c) 2007 The NetBSD Foundation, Inc.
@@ -96,7 +96,8 @@
 	int length, fmax, fmin, leading;
 	int leftjust, llflag;
 	char fill, sign;
-	long long v;
+	long long d;
+	unsigned long long v;
 
 	outcnt = 0;
 	while ((i = *fmt++) != '\0') {
@@ -160,39 +161,39 @@
 
 		case 'd':
 			if (llflag)
-				v = va_arg(ap, long long);
+				d = va_arg(ap, long long);
 			else
-				v = va_arg(ap, int);
-			if (v < 0) {
-				sign = '-' ; v = -v;
+				d = va_arg(ap, int);
+			if (d < 0) {
+				sign = '-' ; d = -d;
 			}
-			mkdigit((unsigned long long)v, 10, str);
+			mkdigit((unsigned long long)d, 10, str);
 			break;
 
 		case 'u':
 			if (llflag)
-				v = va_arg(ap, long long);
+				v = va_arg(ap, unsigned long long);
 			else
-				v = va_arg(ap, int);
-			mkdigit((unsigned long long)v, 10, str);
+				v = va_arg(ap, unsigned int);
+			mkdigit(v, 10, str);
 			break;
 
 		case 'o':
 			if (llflag)
-				v = va_arg(ap, long long);
+				v = va_arg(ap, unsigned long long);
 			else
-				v = va_arg(ap, int);
-			mkdigit((unsigned long long)v, 8, str);
+				v = va_arg(ap, unsigned int);
+			mkdigit(v, 8, str);
 			fmax = 0;
 			break;
 
 		case 'X':
 		case 'x':
 			if (llflag)
-				v = va_arg(ap, long long);
+				v = va_arg(ap, unsigned long long);
 			else
-				v = va_arg(ap, int);
-			mkdigit((unsigned long long)v, 16, str);
+				v = va_arg(ap, unsigned int);
+			mkdigit(v, 16, str);
 			fmax = 0;
 			break;