generic.c: In function ‘print_mtrr_state’: generic.c:210:11: error: ‘%0*lx’ directive output between 1 and 1073741823 bytes may cause result to exceed ‘INT_MAX’ [-Werror=format-overflow=] 210 | printk("%s %u base %0*"PRIx64"000 mask %0*"PRIx64"000 %s\n", | ^~~~~~~~~~~~~~~~~ generic.c:210:44: note: format string is defined here 210 | printk("%s %u base %0*"PRIx64"000 mask %0*"PRIx64"000 %s\n", generic.c:210:11: note: directive argument in the range [0, 4503599627370495] 210 | printk("%s %u base %0*"PRIx64"000 mask %0*"PRIx64"000 %s\n", | ^~~~~~~~~~~~~~~~~ generic.c:210:11: note: assuming directive output of 1 byte
Restrict the width of the variable "width" controlling the number of address digits output. Reported-by: Charles Arnold <carn...@suse.com> Signed-off-by: Jan Beulich <jbeul...@suse.com> --- a/xen/arch/x86/cpu/mtrr/generic.c +++ b/xen/arch/x86/cpu/mtrr/generic.c @@ -182,7 +182,7 @@ static void __init print_fixed(unsigned static void __init print_mtrr_state(const char *level) { unsigned int i; - int width; + unsigned char width; /* gcc9 doesn't like plain "int" here */ printk("%sMTRR default type: %s\n", level, mtrr_attrib_to_str(mtrr_state.def_type)); _______________________________________________ Xen-devel mailing list Xen-devel@lists.xenproject.org https://lists.xenproject.org/mailman/listinfo/xen-devel