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;