]> granicus.if.org Git - php/commitdiff
* Optimize argument_stack top lookup
authorAndi Gutmans <andi@php.net>
Tue, 13 Apr 1999 17:03:10 +0000 (17:03 +0000)
committerAndi Gutmans <andi@php.net>
Tue, 13 Apr 1999 17:03:10 +0000 (17:03 +0000)
* Fix a nasty bug in zend_ptr_stack_clean()

Zend/libzend.dsp
Zend/zend_API.c
Zend/zend_execute_API.c
Zend/zend_ptr_stack.c

index 9b30d47f10838d7e5d455881ecab203c6fc6ecb9..9dfde8e1514a262d7c12d0ff63fccb824962bbd3 100644 (file)
@@ -41,7 +41,7 @@ RSC=rc.exe
 # PROP Intermediate_Dir "Release"
 # PROP Target_Dir ""
 # ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_MBCS" /D "_LIB" /YX /FD /c
-# ADD CPP /nologo /MT /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_MBCS" /D "_LIB" /D "COMPILE_LIBZEND" /YX /FD /c
+# ADD CPP /nologo /MT /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_MBCS" /D "_LIB" /D "COMPILE_LIBZEND" /FR /YX /FD /c
 # ADD BASE RSC /l 0x40d /d "NDEBUG"
 # ADD RSC /l 0x40d /d "NDEBUG"
 BSC32=bscmake.exe
index 9a31fc5edced19715c991993fcb6c803e76bc9e6..caf097b01b6e411737e661ae6f1d2cfc78b79bf1 100644 (file)
@@ -33,7 +33,7 @@ HashTable list_destructors, module_registry;
 /* this function doesn't check for too many parameters */
 int getParameters(int ht, int param_count,...)
 {
-       void **p = EG(argument_stack).elements+EG(argument_stack).top-1;
+       void **p = EG(argument_stack).top_element-1;
        int arg_count = (ulong) *p;
        va_list ptr;
        zval **param, *param_ptr;
@@ -57,6 +57,7 @@ int getParameters(int ht, int param_count,...)
                        new_tmp->refcount = 1;
                        new_tmp->is_ref = 0;
                        param_ptr = new_tmp;
+                       ((zval *) *(p-param_count))->refcount--;
                        *(p-param_count) = param_ptr;
                }
                *param = param_ptr;
@@ -70,7 +71,7 @@ int getParameters(int ht, int param_count,...)
 
 int getParametersArray(int ht, int param_count, zval **argument_array)
 {
-       void **p = EG(argument_stack).elements+EG(argument_stack).top-1;
+       void **p = EG(argument_stack).top_element-1;
        int arg_count = (ulong) *p;
        zval *param_ptr;
        ELS_FETCH();
@@ -91,6 +92,7 @@ int getParametersArray(int ht, int param_count, zval **argument_array)
                        new_tmp->refcount = 1;
                        new_tmp->is_ref = 0;
                        param_ptr = new_tmp;
+                       ((zval *) *(p-param_count))->refcount--;
                        *(p-param_count) = param_ptr;
                }
                *(argument_array++) = param_ptr;
index 728e531a593ebdcaedacea082d370100b93749a6..e10be7d706ada715d7fcde45b6f98a9851175a29 100644 (file)
@@ -466,7 +466,7 @@ ZEND_API inline void zend_ptr_stack_clear_multiple(ELS_D)
 
 ZEND_API int zend_ptr_stack_get_arg(int requested_arg, void **data)
 {
-       void **p = EG(argument_stack).elements+EG(argument_stack).top-1;
+       void **p = EG(argument_stack).top_element-1;
        int arg_count = (ulong) *p;
 
        if (requested_arg>arg_count) {
index db83c2bd3f924bb5ad32ced323379425c403b3d7..f07f942aa26096a40b3bd8aae28edd9c3cc60b8f 100644 (file)
@@ -68,6 +68,7 @@ ZEND_API void zend_ptr_stack_clean(zend_ptr_stack *stack, void (*func)(void *))
 {
        zend_ptr_stack_apply(stack, func);
        stack->top = 0;
+       stack->top_element = stack->elements;
 }