]> git.ipfire.org Git - thirdparty/grub.git/commitdiff
* kern/misc.c (grub_ltoa): New function.
authordavem <davem@localhost>
Sat, 11 Apr 2009 11:48:34 +0000 (11:48 +0000)
committerdavem <davem@localhost>
Sat, 11 Apr 2009 11:48:34 +0000 (11:48 +0000)
(grub_vsprintf): Use it to format 'long' integers.

ChangeLog
kern/misc.c

index 76b709dad06beb6e3b00d3d28fc35d11f501f98b..6dd046f893b5f45cd6f336161097868d290d11df 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -33,6 +33,9 @@
        * boot/sparc64/ieee1275/boot.S: Likewise.
        * boot/sparc64/ieee1275/diskboot.S: Likewise.
 
+       * kern/misc.c (grub_ltoa): New function.
+       (grub_vsprintf): Use it to format 'long' integers.
+
 2009-04-10  David S. Miller  <davem@davemloft.net>
 
        * disk/ieee1275/nand.c (grub_nand_open): All ieee1275 call arg
index 23eaa14e39b5ff2529c15c6dcf7d005362f15da3..85a5d9525ea273655b122b68add38e59bde0c430 100644 (file)
@@ -590,6 +590,31 @@ grub_itoa (char *str, int c, unsigned n)
   return p;
 }
 
+static char *
+grub_ltoa (char *str, int c, unsigned long n)
+{
+  unsigned long base = (c == 'x') ? 16 : 10;
+  char *p;
+
+  if ((long) n < 0 && c == 'd')
+    {
+      n = (unsigned) (-((long) n));
+      *str++ = '-';
+    }
+
+  p = str;
+  do
+    {
+      unsigned long d = n % base;
+      *p++ = (d > 9) ? d + 'a' - 10 : d + '0';
+    }
+  while (n /= base);
+  *p = 0;
+
+  grub_reverse (str);
+  return p;
+}
+
 /* Divide N by D, return the quotient, and store the remainder in *R.  */
 grub_uint64_t
 grub_divmod64 (grub_uint64_t n, grub_uint32_t d, grub_uint32_t *r)
@@ -790,12 +815,14 @@ grub_vsprintf (char *str, const char *fmt, va_list args)
                  ll = va_arg (args, long long);
                  grub_lltoa (tmp, c, ll);
                }
+             else if (longfmt)
+               {
+                 long l = va_arg (args, long);
+                 grub_ltoa (tmp, c, l);
+               }
              else
                {
-                 if (longfmt)
-                   n = va_arg (args, long);
-                 else
-                   n = va_arg (args, int);
+                 n = va_arg (args, int);
                  grub_itoa (tmp, c, n);
                }
              if (! rightfill && grub_strlen (tmp) < format1)