Divide By Zero Affecting kernel-uek-container package, versions <0:5.4.17-2136.337.5.el7uek


Severity

Recommended
high

Based on Oracle Linux security rating.

Threat Intelligence

EPSS
0.04% (6th percentile)

Do your applications use this vulnerable package?

In a few clicks we can analyze your entire application and see what components are vulnerable in your application, and suggest you quick fixes.

Test your applications
  • Snyk IDSNYK-ORACLE7-KERNELUEKCONTAINER-8370986
  • published14 Nov 2024
  • disclosed13 Sept 2024

Introduced: 13 Sep 2024

CVE-2024-46676  (opens in a new tab)
CWE-369  (opens in a new tab)

How to fix?

Upgrade Oracle:7 kernel-uek-container to version 0:5.4.17-2136.337.5.el7uek or higher.
This issue was patched in ELSA-2024-12813.

NVD Description

Note: Versions mentioned in the description apply only to the upstream kernel-uek-container package and not the kernel-uek-container package as distributed by Oracle. See How to fix? for Oracle:7 relevant fixed versions and status.

In the Linux kernel, the following vulnerability has been resolved:

nfc: pn533: Add poll mod list filling check

In case of im_protocols value is 1 and tm_protocols value is 0 this combination successfully passes the check 'if (!im_protocols && !tm_protocols)' in the nfc_start_poll(). But then after pn533_poll_create_mod_list() call in pn533_start_poll() poll mod list will remain empty and dev->poll_mod_count will remain 0 which lead to division by zero.

Normally no im protocol has value 1 in the mask, so this combination is not expected by driver. But these protocol values actually come from userspace via Netlink interface (NFC_CMD_START_POLL operation). So a broken or malicious program may pass a message containing a "bad" combination of protocol parameter values so that dev->poll_mod_count is not incremented inside pn533_poll_create_mod_list(), thus leading to division by zero. Call trace looks like: nfc_genl_start_poll() nfc_start_poll() ->start_poll() pn533_start_poll()

Add poll mod list filling check.

Found by Linux Verification Center (linuxtesting.org) with SVACE.

CVSS Scores

version 3.1