Headline
CVE-2023-24833: Re-sync with internal repository (#908) · facebook/hermes@a6dcafe
A use-after-free in BigIntPrimitive addition in Hermes prior to commit a6dcafe6ded8e61658b40f5699878cd19a481f80 could have been used by an attacker to leak raw data from Hermes VM’s heap. Note that this is only exploitable in cases where Hermes is used to execute untrusted JavaScript. Hence, most React Native applications are not affected.
Expand Up
@@ -1093,10 +1093,6 @@ class StandardSortModel : public SortModel {
JSObject::getComputedPrimitiveDescriptor(
obj_, runtime_, aHandle_, aDescObjHandle_, aTmpNameStorage_, aDesc);
ComputedPropertyDescriptor bDesc;
JSObject::getComputedPrimitiveDescriptor(
obj_, runtime_, bHandle_, bDescObjHandle_, bTmpNameStorage_, bDesc);
if (aDescObjHandle_) {
if (LLVM_LIKELY(!aDesc.flags.proxyObject)) {
auto res = JSObject::getComputedPropertyValue_RJS(
Expand Down Expand Up
@@ -1135,6 +1131,11 @@ class StandardSortModel : public SortModel {
}
}
}
ComputedPropertyDescriptor bDesc;
JSObject::getComputedPrimitiveDescriptor(
obj_, runtime_, bHandle_, bDescObjHandle_, bTmpNameStorage_, bDesc);
if (bDescObjHandle_) {
if (LLVM_LIKELY(!bDesc.flags.proxyObject)) {
auto res = JSObject::getComputedPropertyValue_RJS(
Expand Down