Bug 561361 (CVE-2009-4248)
| Summary: | CVE-2009-4248 HelixPlayer / RealPlayer: RTSP SET_PARAMETER buffer overflow | ||
|---|---|---|---|
| Product: | [Other] Security Response | Reporter: | Tomas Hoger <thoger> | 
| Component: | vulnerability | Assignee: | Red Hat Product Security <security-response-team> | 
| Status: | CLOSED ERRATA | QA Contact: | |
| Severity: | urgent | Docs Contact: | |
| Priority: | urgent | ||
| Version: | unspecified | CC: | cmontgom, gauret, yoyzhang | 
| Target Milestone: | --- | Keywords: | Security | 
| Target Release: | --- | ||
| Hardware: | All | ||
| OS: | Linux | ||
| URL: | http://web.nvd.nist.gov/view/vuln/detail?vulnId=CVE-2009-4248 | ||
| Whiteboard: | |||
| Fixed In Version: | Doc Type: | Bug Fix | |
| Doc Text: | Story Points: | --- | |
| Clone Of: | Environment: | ||
| Last Closed: | 2010-02-09 11:06:56 UTC | Type: | --- | 
| Regression: | --- | Mount Type: | --- | 
| Documentation: | --- | CRM: | |
| Verified Versions: | Category: | --- | |
| oVirt Team: | --- | RHEL 7.3 requirements from Atomic Host: | |
| Cloudforms Team: | --- | Target Upstream Version: | |
| Embargoed: | |||
| Bug Depends On: | |||
| Bug Blocks: | 559995 | ||
| 
        
          Description
        
        
          Tomas Hoger
        
        
        
        
        
          2010-02-03 14:35:14 UTC
        
       According to upstream, relevant upstream fixes are: HEAD: http://lists.helixcommunity.org/pipermail/client-cvs/2008-January/003759.html https://helixcommunity.org/viewcvs/client/core/rtspprotocol.cpp?view=log#rev1.86 1.x branch: http://lists.helixcommunity.org/pipermail/client-cvs/2008-January/003756.html https://helixcommunity.org/viewcvs/client/core/rtspprotocol.cpp?view=log#rev1.55.2.19 Additional reference: http://lists.helixcommunity.org/pipermail/client-dev/2008-January/004591.html Reading the patch pointed out by upstream, I fail to see the buffer overflow mentioned in the upstream advisory. It adds couple of checks to avoid NULL pointer dereferences and check if strlen return value does not wrap to negative when assigned to 32bit signed integer variable. Even negative contentLen shouldn't have any bad impact, as CHXBuffer::SetSize treats length as unsigned and BinFrom64() would not decode anything and rather return 0, resulting in the truncation of the buffer to size 0. Looks like the only place where overflow can happen is some time later, if processing of the buffer set by m_pDataRevert->ControlBufferReady() has some problems with 0-sized buffers. There is a possibility how overflow can happen in RTSPProtocol::HandleSetParameterRequest. CHXBuffer class uses 2 types of storage for buffer - it has a short (15 character) static buffer that is used when short amount of memory is needed, or allocates needed buffer dynamically if more memory is needed. When instance of this class is created as an empty buffer, it uses static buffer by default (e.g. when direct pointer to a storage area is requested using GetBuffer method). SetSize(contentLen) may fail to allocate memory, but its return value is not checked. Hence if an attacker can trigger a memory allocation failure, BinFrom64() will try to base64 decode input into the short CHXBuffer-internal buffer. This issue has been addressed in following products: Red Hat Enterprise Linux 4 Via RHSA-2010:0094 https://rhn.redhat.com/errata/RHSA-2010-0094.html |