From 40c2e97ea38c4275e8d8476eeddd1bb38d8ed90d Mon Sep 17 00:00:00 2001 From: Neil Dhar Date: Mon, 9 Dec 2024 13:01:13 -0800 Subject: [PATCH] Remove unnecessary CAPTURE_IP for property accesses Summary: These operations do not throw or allocate, so they do not need a `CAPTURE_IP`. Reviewed By: tmikov Differential Revision: D66923469 fbshipit-source-id: afe86c44235a941240b5db9658b7616834d8c2c9 --- lib/VM/Interpreter.cpp | 43 ++++++++++++++++++------------------------ 1 file changed, 18 insertions(+), 25 deletions(-) diff --git a/lib/VM/Interpreter.cpp b/lib/VM/Interpreter.cpp index 74342424ab6..4e3c8196743 100644 --- a/lib/VM/Interpreter.cpp +++ b/lib/VM/Interpreter.cpp @@ -2229,18 +2229,16 @@ CallResult Interpreter::interpretFunction( // return the property. if (LLVM_LIKELY(cacheEntry->clazz == clazzPtr)) { ++NumGetByIdCacheHits; - CAPTURE_IP( - O1REG(GetById) = JSObject::getNamedSlotValueUnsafe( - obj, runtime, cacheEntry->slot) - .unboxToHV(runtime)); + O1REG(GetById) = + JSObject::getNamedSlotValueUnsafe(obj, runtime, cacheEntry->slot) + .unboxToHV(runtime); ip = nextIP; DISPATCH; } auto id = ID(idVal); NamedPropertyDescriptor desc; - CAPTURE_IP_ASSIGN( - OptValue fastPathResult, - JSObject::tryGetOwnNamedDescriptorFast(obj, runtime, id, desc)); + OptValue fastPathResult = + JSObject::tryGetOwnNamedDescriptorFast(obj, runtime, id, desc); if (LLVM_LIKELY( fastPathResult.hasValue() && fastPathResult.getValue()) && !desc.flags.accessor) { @@ -2266,10 +2264,8 @@ CallResult Interpreter::interpretFunction( assert( !obj->isProxyObject() && "tryGetOwnNamedDescriptorFast returned true on Proxy"); - CAPTURE_IP( - O1REG(GetById) = - JSObject::getNamedSlotValueUnsafe(obj, runtime, desc) - .unboxToHV(runtime)); + O1REG(GetById) = JSObject::getNamedSlotValueUnsafe(obj, runtime, desc) + .unboxToHV(runtime); ip = nextIP; DISPATCH; } @@ -2279,7 +2275,7 @@ CallResult Interpreter::interpretFunction( // not-found. if (fastPathResult.hasValue() && !fastPathResult.getValue() && LLVM_LIKELY(!obj->isProxyObject())) { - CAPTURE_IP_ASSIGN(JSObject * parent, obj->getParent(runtime)); + JSObject *parent = obj->getParent(runtime); // TODO: This isLazy check is because a lazy object is reported as // having no properties and therefore cannot contain the property. // This check does not belong here, it should be merged into @@ -2288,10 +2284,9 @@ CallResult Interpreter::interpretFunction( LLVM_LIKELY(!obj->isLazy())) { ++NumGetByIdProtoHits; // We've already checked that this isn't a Proxy. - CAPTURE_IP( - O1REG(GetById) = JSObject::getNamedSlotValueUnsafe( - parent, runtime, cacheEntry->slot) - .unboxToHV(runtime)); + O1REG(GetById) = JSObject::getNamedSlotValueUnsafe( + parent, runtime, cacheEntry->slot) + .unboxToHV(runtime); ip = nextIP; DISPATCH; } @@ -2430,16 +2425,15 @@ CallResult Interpreter::interpretFunction( // return the property. if (LLVM_LIKELY(cacheEntry->clazz == clazzPtr)) { ++NumPutByIdCacheHits; - CAPTURE_IP(JSObject::setNamedSlotValueUnsafe( - obj, runtime, cacheEntry->slot, shv)); + JSObject::setNamedSlotValueUnsafe( + obj, runtime, cacheEntry->slot, shv); ip = nextIP; DISPATCH; } auto id = ID(idVal); NamedPropertyDescriptor desc; - CAPTURE_IP_ASSIGN( - OptValue hasOwnProp, - JSObject::tryGetOwnNamedDescriptorFast(obj, runtime, id, desc)); + OptValue hasOwnProp = + JSObject::tryGetOwnNamedDescriptorFast(obj, runtime, id, desc); if (LLVM_LIKELY(hasOwnProp.hasValue() && hasOwnProp.getValue()) && !desc.flags.accessor && desc.flags.writable && !desc.flags.internalSetter) { @@ -2463,8 +2457,7 @@ CallResult Interpreter::interpretFunction( } // This must be valid because an own property was already found. - CAPTURE_IP( - JSObject::setNamedSlotValueUnsafe(obj, runtime, desc.slot, shv)); + JSObject::setNamedSlotValueUnsafe(obj, runtime, desc.slot, shv); ip = nextIP; DISPATCH; } @@ -3380,8 +3373,8 @@ CallResult Interpreter::interpretFunction( CAPTURE_IP_ASSIGN( SmallHermesValue shv, SmallHermesValue::encodeHermesValue(O2REG(PutOwnBySlotIdx), runtime)); - CAPTURE_IP(JSObject::setNamedSlotValueUnsafe( - vmcast(O1REG(PutOwnBySlotIdx)), runtime, idVal, shv)); + JSObject::setNamedSlotValueUnsafe( + vmcast(O1REG(PutOwnBySlotIdx)), runtime, idVal, shv); gcScope.flushToSmallCount(KEEP_HANDLES); ip = nextIP; DISPATCH;