mirror of https://gitee.com/openkylin/linux.git
efi/printf: Factor out integer argument retrieval
Factor out the code to get the correct type of numeric argument into a helper function. Signed-off-by: Arvind Sankar <nivedita@alum.mit.edu> Link: https://lore.kernel.org/r/20200518190716.751506-13-nivedita@alum.mit.edu Signed-off-by: Ard Biesheuvel <ardb@kernel.org>
This commit is contained in:
parent
3fbcf75bb4
commit
dec6119952
drivers/firmware/efi/libstub
|
@ -244,6 +244,38 @@ int get_int(const char **fmt, va_list *ap)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static
|
||||||
|
unsigned long long get_number(int sign, int qualifier, va_list *ap)
|
||||||
|
{
|
||||||
|
if (sign) {
|
||||||
|
switch (qualifier) {
|
||||||
|
case 'L':
|
||||||
|
return va_arg(*ap, long long);
|
||||||
|
case 'l':
|
||||||
|
return va_arg(*ap, long);
|
||||||
|
case 'h':
|
||||||
|
return (short)va_arg(*ap, int);
|
||||||
|
case 'H':
|
||||||
|
return (signed char)va_arg(*ap, int);
|
||||||
|
default:
|
||||||
|
return va_arg(*ap, int);
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
switch (qualifier) {
|
||||||
|
case 'L':
|
||||||
|
return va_arg(*ap, unsigned long long);
|
||||||
|
case 'l':
|
||||||
|
return va_arg(*ap, unsigned long);
|
||||||
|
case 'h':
|
||||||
|
return (unsigned short)va_arg(*ap, int);
|
||||||
|
case 'H':
|
||||||
|
return (unsigned char)va_arg(*ap, int);
|
||||||
|
default:
|
||||||
|
return va_arg(*ap, unsigned int);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
int vsprintf(char *buf, const char *fmt, va_list ap)
|
int vsprintf(char *buf, const char *fmt, va_list ap)
|
||||||
{
|
{
|
||||||
int len;
|
int len;
|
||||||
|
@ -370,40 +402,8 @@ int vsprintf(char *buf, const char *fmt, va_list ap)
|
||||||
}
|
}
|
||||||
if (*fmt == 'p') {
|
if (*fmt == 'p') {
|
||||||
num = (unsigned long)va_arg(args, void *);
|
num = (unsigned long)va_arg(args, void *);
|
||||||
} else if (flags & SIGN) {
|
|
||||||
switch (qualifier) {
|
|
||||||
case 'L':
|
|
||||||
num = va_arg(args, long long);
|
|
||||||
break;
|
|
||||||
case 'l':
|
|
||||||
num = va_arg(args, long);
|
|
||||||
break;
|
|
||||||
case 'h':
|
|
||||||
num = (short)va_arg(args, int);
|
|
||||||
break;
|
|
||||||
case 'H':
|
|
||||||
num = (signed char)va_arg(args, int);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
num = va_arg(args, int);
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
switch (qualifier) {
|
num = get_number(flags & SIGN, qualifier, &args);
|
||||||
case 'L':
|
|
||||||
num = va_arg(args, unsigned long long);
|
|
||||||
break;
|
|
||||||
case 'l':
|
|
||||||
num = va_arg(args, unsigned long);
|
|
||||||
break;
|
|
||||||
case 'h':
|
|
||||||
num = (unsigned short)va_arg(args, int);
|
|
||||||
break;
|
|
||||||
case 'H':
|
|
||||||
num = (unsigned char)va_arg(args, int);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
num = va_arg(args, unsigned int);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
str = number(str, num, base, field_width, precision, flags);
|
str = number(str, num, base, field_width, precision, flags);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue