Soumettre #520182: Open Source libgsf <=1.14.53 Integer Overflow -> Heap Overflow (gsf_prop_settings_collect_va)information

TitreOpen Source libgsf <=1.14.53 Integer Overflow -> Heap Overflow (gsf_prop_settings_collect_va)
DescriptionThe vulnerability arises from unchecked arithmetic during the dynamic expansion of the parameters array—adding 16 to n_alloced_params near SIZE_MAX can overflow, leading to underallocation and potential out-of-bounds writes to heap memory. void gsf_prop_settings_collect_valist (GType object_type, GsfParam **p_params, size_t *p_n_params, const gchar *first_property_name, va_list var_args) { ... size_t n_params = *p_n_params; size_t n_alloced_params = n_params; ... while (name) { ... if (n_params >= n_alloced_params) { // If n_alloced_params is near SIZE_MAX, adding 16 may overflow. n_alloced_params += 16; params = g_renew (GsfParam, params, n_alloced_params); // underallocation as a result fof the arithmetic } ... params[n_params].name = name; //the 'write' logic, could attempt to derference an offset that isn't mapped, or write to arbitrary addresses on the heap ... n_params++; // another incrementation vector that could lead to an overflow in theory ... } ... }
Utilisateur ninpwn (UID 82253)
Soumission13/03/2025 21:21 (il y a 1 Année)
Modérer24/03/2025 13:46 (11 days later)
StatutAccepté
Entrée VulDB300742 [GNOME libgsf jusqu’à 1.14.53 gsf_prop_settings_collect_va n_alloced_params buffer overflow]
Points17

Interested in the pricing of exploits?

See the underground prices here!