Katalog CVE

CVE-2026-56015

Nieznane
Opublikowano: Zaktualizowano: Przetłumaczono: NVD NIST

Streszczenie

W bibliotece Net::IP::LPM dla Perla w wersjach do 1.10 występuje podatność na odczyt poza dozwolonym obszarem sterty (heap out-of-bounds read) spowodowana brakiem walidacji długości prefiksu w funkcji add(). Atakujący może przekazać nieprawidłową długość prefiksu (np. 255 dla IPv4 lub IPv6), co prowadzi do odczytu danych poza buforem adresu. Problem jest wykrywalny przez narzędzia takie jak AddressSanitizer i może spowodować przerwanie procesu.

Ocena ryzyka

Ryzyko dla organizacji polega na potencjalnym przerwaniu działania aplikacji korzystających z tej biblioteki (odmowa usługi) w przypadku przetwarzania złośliwych danych wejściowych. Podatność nie ujawnia danych poza API modułu, ale może prowadzić do awarii procesu.

Rekomendacja

Zaleca się natychmiastową aktualizację biblioteki Net::IP::LPM do wersji nowszej niż 1.10, jeśli taka jest dostępna, lub zastosowanie tymczasowego rozwiązania polegającego na walidacji długości prefiksu przed wywołaniem funkcji add().

Oryginalny opis (angielski, źródło NVD)

Net::IP::LPM versions through 1.10 for Perl allow a heap out-of-bounds read via an unbounded prefix length. add() passes the prefix string to the trie builder addPrefixToTrie() without checking it against the address width. addPrefixToTrie() then walks the prefix buffer by prefix_length bits, reading prefix[byte] for byte up to prefix_len/8, where prefix is the 4-byte (IPv4) or 16-byte (IPv6) packed address. A prefix length greater than 32 for IPv4 or 128 for IPv6, for example add("1.2.3.4/255", $v) or add("2001:db8::/255", $v), reads past the end of the packed address. The out-of-bounds read happens during trie construction and is bounded: the prefix length is stored as an unsigned char, so the bit walk reads at most 32 bytes from the start of the packed address, a short distance past the end of the 4-byte or 16-byte buffer. It is detectable under AddressSanitizer, valgrind, or a hardened allocator, where it can abort the process. Lookups and dump() format only the valid address width, so the out-of-bounds bytes are not exposed through the module's API.

Dane podatności pochodzą z NVD (NIST) · CISA KEV · EPSS