summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDmitry Stogov <dmitry@zend.com>2018-11-15 18:47:23 +0300
committerDmitry Stogov <dmitry@zend.com>2018-11-15 18:47:23 +0300
commit71d6899e535d960d9b43d75ed2b7073288c13b59 (patch)
tree63405cdb3c01c24bc0eb2c20e95649bbfd74aa29
parent5ae1524dc3fb72d96e50660336541d1f1b0ba9f6 (diff)
downloadphp-git-71d6899e535d960d9b43d75ed2b7073288c13b59.tar.gz
micro-optimization
-rw-r--r--Zend/zend_objects_API.c9
1 files changed, 4 insertions, 5 deletions
diff --git a/Zend/zend_objects_API.c b/Zend/zend_objects_API.c
index afa9359289..ed2c99af68 100644
--- a/Zend/zend_objects_API.c
+++ b/Zend/zend_objects_API.c
@@ -162,8 +162,6 @@ ZEND_API void ZEND_FASTCALL zend_objects_store_del(zend_object *object) /* {{{ *
otherwise, when the destructor ends the storage might be freed
when the refcount reaches 0 a second time
*/
- ZEND_ASSERT(EG(objects_store).object_buckets != NULL);
- ZEND_ASSERT(IS_OBJ_VALID(EG(objects_store).object_buckets[object->handle]));
ZEND_ASSERT(GC_REFCOUNT(object) == 0);
if (!(OBJ_FLAGS(object) & IS_OBJ_DESTRUCTOR_CALLED)) {
@@ -171,7 +169,7 @@ ZEND_API void ZEND_FASTCALL zend_objects_store_del(zend_object *object) /* {{{ *
if (object->handlers->dtor_obj != zend_objects_destroy_object
|| object->ce->destructor) {
- GC_ADDREF(object);
+ GC_SET_REFCOUNT(object, 1);
object->handlers->dtor_obj(object);
GC_DELREF(object);
}
@@ -181,12 +179,13 @@ ZEND_API void ZEND_FASTCALL zend_objects_store_del(zend_object *object) /* {{{ *
uint32_t handle = object->handle;
void *ptr;
+ ZEND_ASSERT(EG(objects_store).object_buckets != NULL);
+ ZEND_ASSERT(IS_OBJ_VALID(EG(objects_store).object_buckets[handle]));
EG(objects_store).object_buckets[handle] = SET_OBJ_INVALID(object);
if (!(OBJ_FLAGS(object) & IS_OBJ_FREE_CALLED)) {
GC_ADD_FLAGS(object, IS_OBJ_FREE_CALLED);
- GC_ADDREF(object);
+ GC_SET_REFCOUNT(object, 1);
object->handlers->free_obj(object);
- GC_DELREF(object);
}
ptr = ((char*)object) - object->handlers->offset;
GC_REMOVE_FROM_BUFFER(object);