Skip to content

Improper Input Frame Validation in ieee802154 Processing

High
d3zd3z published GHSA-3gvq-h42f-v3c7 Apr 26, 2021

Package

zephyr (west)

Affected versions

v1.14.2, v2.2.0

Patched versions

v2.3.0

Description

Issue Description

Packet buf size is underflown for small ieee802154 packets in
zephyr/subsys/net/l2/ieee802154/ieee802154.c#ieee802154_recv.
Manual computation of size is performed in ieee802154_recv after the
minimal size has not been properly validated in
ieee802154_validate_frame. The size check for minimal packet size of
IEEE802154_MIN_LENGTH (==3) does not include potential additional sizes
introduced by PAN id and/or (extended) src/dest addresses.

During frame validation, the PAN ID / address fields can be of extended
lengths in
zephyr/subsys/net/l2/ieee802154/ieee802154_frame.c#ieee802154_validate_frame
(2+8, 8 additional bytes) for packet type type == IEEE802154_FRAME_TYPE_DATA
in
zephyr/subsys/net/l2/ieee802154/ieee802154_frame.c#validate_payload_and_mfr.

A sample manifestation resides in an out-of-bounds access in
uncompress_IPHC_header function (subsys/net/ip/6lo.c)

Vulnerable Code

static enum net_verdict ieee802154_recv(struct net_if *iface, struct
net_pkt *pkt)
{
    // Tobias Scharnowski: Missing length validation in
ieee802154_validate_frame and subfunctions
    if (!ieee802154_validate_frame(net_pkt_data(pkt),
net_pkt_get_len(pkt), &mpdu)) {
        return NET_DROP;
    }
    ...
    // Tobias Scharnowski: Missing underflow check here
    hdr_len = (u8_t *)mpdu.payload - net_pkt_data(pkt); -> hdr_len is
larger than the netbuf size
    net_buf_pull(pkt->buffer, hdr_len);
    ...
}
// -> ieee802154_validate_frame does not properly check that hdr_len
will not be larger than available space in pkt
// -> modifications performed by PAN id and src/dest address decoding,
leading to integer underflow in pkt size and thus larger fake size of netbuf

Source Code References

Exploitability and Impact

  • For exploitability to occur, an attacker controlled packet with a
    small size needs to reach the ieee802154 stack.
  • In case of a trigger, DoS is achieved at minimum
  • Based on timing (context switch during memmov operation) and board RAM
    (>64kB of RAM), corruption is likely to be exploitable to RCE as well

Patches

This has been fixed in:

For more information

If you have any questions or comments about this advisory:

embargo: 2020-06-29
zepsec: ZEPSEC-65
thanks: Steffen Schultz

Severity

High

CVSS overall score

This score calculates overall vulnerability severity from 0 to 10 and is based on the Common Vulnerability Scoring System (CVSS).
/ 10

CVSS v3 base metrics

Attack vector
Network
Attack complexity
Low
Privileges required
None
User interaction
None
Scope
Changed
Confidentiality
Low
Integrity
Low
Availability
Low

CVSS v3 base metrics

Attack vector: More severe the more the remote (logically and physically) an attacker can be in order to exploit the vulnerability.
Attack complexity: More severe for the least complex attacks.
Privileges required: More severe if no privileges are required.
User interaction: More severe when no user interaction is required.
Scope: More severe when a scope change occurs, e.g. one vulnerable component impacts resources in components beyond its security scope.
Confidentiality: More severe when loss of data confidentiality is highest, measuring the level of data access available to an unauthorized user.
Integrity: More severe when loss of data integrity is the highest, measuring the consequence of data modification possible by an unauthorized user.
Availability: More severe when the loss of impacted component availability is highest.
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:L/I:L/A:L

CVE ID

CVE-2020-10064