37 lines
1.4 KiB
Diff
37 lines
1.4 KiB
Diff
|
From 2c8a7f14fac3628b6a06cc76cdfda54a7ac20386 Mon Sep 17 00:00:00 2001
|
||
|
From: Florian Weimer <fweimer@redhat.com>
|
||
|
Date: Tue, 17 Dec 2024 18:12:03 +0100
|
||
|
Subject: [PATCH] x86: Avoid integer truncation with large cache sizes (bug
|
||
|
32470)
|
||
|
|
||
|
Some hypervisors report 1 TiB L3 cache size. This results
|
||
|
in some variables incorrectly getting zeroed, causing crashes
|
||
|
in memcpy/memmove because invariants are violated.
|
||
|
|
||
|
(cherry picked from commit 61c3450db96dce96ad2b24b4f0b548e6a46d68e5)
|
||
|
---
|
||
|
sysdeps/x86/dl-cacheinfo.h | 4 ++--
|
||
|
1 file changed, 2 insertions(+), 2 deletions(-)
|
||
|
|
||
|
diff --git a/sysdeps/x86/dl-cacheinfo.h b/sysdeps/x86/dl-cacheinfo.h
|
||
|
index 5a98f70364..1f68968a9a 100644
|
||
|
--- a/sysdeps/x86/dl-cacheinfo.h
|
||
|
+++ b/sysdeps/x86/dl-cacheinfo.h
|
||
|
@@ -959,11 +959,11 @@ dl_init_cacheinfo (struct cpu_features *cpu_features)
|
||
|
non_temporal_threshold = maximum_non_temporal_threshold;
|
||
|
|
||
|
/* NB: The REP MOVSB threshold must be greater than VEC_SIZE * 8. */
|
||
|
- unsigned int minimum_rep_movsb_threshold;
|
||
|
+ unsigned long int minimum_rep_movsb_threshold;
|
||
|
/* NB: The default REP MOVSB threshold is 4096 * (VEC_SIZE / 16) for
|
||
|
VEC_SIZE == 64 or 32. For VEC_SIZE == 16, the default REP MOVSB
|
||
|
threshold is 2048 * (VEC_SIZE / 16). */
|
||
|
- unsigned int rep_movsb_threshold;
|
||
|
+ unsigned long int rep_movsb_threshold;
|
||
|
if (CPU_FEATURE_USABLE_P (cpu_features, AVX512F)
|
||
|
&& !CPU_FEATURE_PREFERRED_P (cpu_features, Prefer_No_AVX512))
|
||
|
{
|
||
|
--
|
||
|
2.46.2
|
||
|
|