Module Name:    src
Committed By:   nisimura
Date:           Sun Jan 23 02:08:24 UTC 2011

Modified Files:
        src/sys/arch/sandpoint/stand/altboot: printf.c

Log Message:
fix a failure in the sign extension consideration.


To generate a diff of this commit:
cvs rdiff -u -r1.2 -r1.3 src/sys/arch/sandpoint/stand/altboot/printf.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/arch/sandpoint/stand/altboot/printf.c
diff -u src/sys/arch/sandpoint/stand/altboot/printf.c:1.2 src/sys/arch/sandpoint/stand/altboot/printf.c:1.3
--- src/sys/arch/sandpoint/stand/altboot/printf.c:1.2	Sun Jan 23 01:32:08 2011
+++ src/sys/arch/sandpoint/stand/altboot/printf.c	Sun Jan 23 02:08:24 2011
@@ -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;
 

Reply via email to