Vulnerability Description
Linux kernel: Exploitable memory corruption due to UFO to non-UFO path switch. When building a UFO packet with MSG_MORE __ip_append_data() calls ip_ufo_append_data() to append. However in between two send() calls, the append path can be switched from UFO to non-UFO one, which leads to a memory corruption. In case UFO packet lengths exceeds MTU, copy = maxfraglen - skb->len becomes negative on the non-UFO path and the branch to allocate new skb is taken. This triggers fragmentation and computation of fraggap = skb_prev->len - maxfraglen. Fraggap can exceed MTU, causing copy = datalen - transhdrlen - fraggap to become negative. Subsequently skb_copy_and_csum_bits() writes out-of-bounds. A similar issue is present in IPv6 code. The bug was introduced in e89e9cf539a2 ("[IPv4/IPv6]: UFO Scatter-gather approach") on Oct 18 2005.
CVSS Score
HIGH
Affected Products
| Vendor | Product | Versions |
|---|---|---|
| Linux | Linux Kernel | >= 2.6.15, < 3.10.108 |
Related Weaknesses (CWE)
References
- http://seclists.org/oss-sec/2017/q3/277Mailing ListPatchThird Party Advisory
- http://www.debian.org/security/2017/dsa-3981Third Party Advisory
- http://www.securityfocus.com/bid/100262Third Party AdvisoryVDB Entry
- http://www.securitytracker.com/id/1039162Third Party AdvisoryVDB Entry
- https://access.redhat.com/errata/RHSA-2017:2918Third Party Advisory
- https://access.redhat.com/errata/RHSA-2017:2930Third Party Advisory
- https://access.redhat.com/errata/RHSA-2017:2931Third Party Advisory
- https://access.redhat.com/errata/RHSA-2017:3200Third Party Advisory
- https://access.redhat.com/errata/RHSA-2019:1931Third Party Advisory
- https://access.redhat.com/errata/RHSA-2019:1932Third Party Advisory
- https://access.redhat.com/errata/RHSA-2019:4159Third Party Advisory
- https://github.com/xairy/kernel-exploits/tree/master/CVE-2017-1000112Third Party Advisory
- https://www.exploit-db.com/exploits/45147/Third Party AdvisoryVDB Entry
- http://seclists.org/oss-sec/2017/q3/277Mailing ListPatchThird Party Advisory
- http://www.debian.org/security/2017/dsa-3981Third Party Advisory
FAQ
What is CVE-2017-1000112?
CVE-2017-1000112 is a vulnerability with a CVSS score of 7.0 (HIGH). Linux kernel: Exploitable memory corruption due to UFO to non-UFO path switch. When building a UFO packet with MSG_MORE __ip_append_data() calls ip_ufo_append_data() to append. However in between two ...
How severe is CVE-2017-1000112?
CVE-2017-1000112 has been rated HIGH with a CVSS base score of 7.0/10. Review the CVSS metrics above for detailed severity breakdown.
Is there a patch for CVE-2017-1000112?
Check the references section above for vendor advisories and patch information. Affected products include: Linux Linux Kernel.