mirror of
https://src.fedoraproject.org/rpms/grub2.git
synced 2024-11-24 22:35:28 +00:00
ec4acbbd98
- Try to fix things for new compiler madness. I really don't know why gcc decided __attribute__((packed)) on a "typedef struct" should imply __attribute__((align (1))) and that it should have a warning that it does so. The obvious behavior would be to keep the alignment of the first element unless it's used in another object or type that /also/ hask the packed attribute. Why should it change the default alignment at all? - Merge in the BLS patches Javier and I wrote. - Attempt to fix pmtimer initialization failures to not be super duper slow. Signed-off-by: Peter Jones <pjones@redhat.com>
58 lines
1.6 KiB
Diff
58 lines
1.6 KiB
Diff
From d3e9800ae2fe7c0ed2d7795eae2be17a66e625ff Mon Sep 17 00:00:00 2001
|
|
From: Paulo Flabiano Smorigo <pfsmorigo@br.ibm.com>
|
|
Date: Tue, 27 Nov 2012 16:58:39 -0200
|
|
Subject: [PATCH 087/206] Add %X option to printf functions.
|
|
|
|
---
|
|
grub-core/kern/misc.c | 7 +++++--
|
|
1 file changed, 5 insertions(+), 2 deletions(-)
|
|
|
|
diff --git a/grub-core/kern/misc.c b/grub-core/kern/misc.c
|
|
index 952411d5dc6..8344526be7f 100644
|
|
--- a/grub-core/kern/misc.c
|
|
+++ b/grub-core/kern/misc.c
|
|
@@ -588,7 +588,7 @@ grub_divmod64 (grub_uint64_t n, grub_uint64_t d, grub_uint64_t *r)
|
|
static inline char *
|
|
grub_lltoa (char *str, int c, unsigned long long n)
|
|
{
|
|
- unsigned base = (c == 'x') ? 16 : 10;
|
|
+ unsigned base = ((c == 'x') || (c == 'X')) ? 16 : 10;
|
|
char *p;
|
|
|
|
if ((long long) n < 0 && c == 'd')
|
|
@@ -603,7 +603,7 @@ grub_lltoa (char *str, int c, unsigned long long n)
|
|
do
|
|
{
|
|
unsigned d = (unsigned) (n & 0xf);
|
|
- *p++ = (d > 9) ? d + 'a' - 10 : d + '0';
|
|
+ *p++ = (d > 9) ? d + ((c == 'x') ? 'a' : 'A') - 10 : d + '0';
|
|
}
|
|
while (n >>= 4);
|
|
else
|
|
@@ -676,6 +676,7 @@ parse_printf_args (const char *fmt0, struct printf_args *args,
|
|
{
|
|
case 'p':
|
|
case 'x':
|
|
+ case 'X':
|
|
case 'u':
|
|
case 'd':
|
|
case 'c':
|
|
@@ -762,6 +763,7 @@ parse_printf_args (const char *fmt0, struct printf_args *args,
|
|
switch (c)
|
|
{
|
|
case 'x':
|
|
+ case 'X':
|
|
case 'u':
|
|
args->ptr[curn].type = UNSIGNED_INT + longfmt;
|
|
break;
|
|
@@ -900,6 +902,7 @@ grub_vsnprintf_real (char *str, grub_size_t max_len, const char *fmt0,
|
|
c = 'x';
|
|
/* Fall through. */
|
|
case 'x':
|
|
+ case 'X':
|
|
case 'u':
|
|
case 'd':
|
|
{
|
|
--
|
|
2.15.0
|
|
|