ID:               23415
 User updated by:  bginter at ndevtech dot net
 Reported By:      bginter at ndevtech dot net
-Status:           Open
+Status:           Closed
 Bug Type:         Session related
 Operating System: Linux 2.4.20
 PHP Version:      PHP 4.3.2
 New Comment:

Since it doesn't appear this bug will be fixed any time soon, we have
already rewritten our software to use mod_perl.  I will no longer
follow up on this bug.

What a waste of time and money...


Previous Comments:
------------------------------------------------------------------------

[2003-06-03 22:33:28] bginter at ndevtech dot net

Yes, it persists in 4.3.2.  Has anything been addressed to warrant
trying a snapshot?

I don't want this bug to be forgotten and I intend to follow up until
it can get fixed.  So please let me know how I can assist further.

Thank you.


Program received signal SIGSEGV, Segmentation fault.
0x40426ef3 in _mem_block_check (ptr=0x8309e8c, silent=1,
__zend_filename=0x4050a1c0
"/usr/local/src/php-4.3.2/Zend/zend_execute_API.c", __zend_lineno=488,

    __zend_orig_filename=0x4050a840
"/usr/local/src/php-4.3.2/Zend/zend_variables.c",
__zend_orig_lineno=44) at
/usr/local/src/php-4.3.2/Zend/zend_alloc.c:675
675             memcpy(&end_magic, (((char *)
p)+sizeof(zend_mem_header)+MEM_HEADER_PADDING+p->size), sizeof(long));
(gdb) bt
#0  0x40426ef3 in _mem_block_check (ptr=0x8309e8c, silent=1,
__zend_filename=0x4050a1c0
"/usr/local/src/php-4.3.2/Zend/zend_execute_API.c", __zend_lineno=488,

    __zend_orig_filename=0x4050a840
"/usr/local/src/php-4.3.2/Zend/zend_variables.c",
__zend_orig_lineno=44) at
/usr/local/src/php-4.3.2/Zend/zend_alloc.c:675
#1  0x40425d54 in _efree (ptr=0x8309e8c, __zend_filename=0x4050a1c0
"/usr/local/src/php-4.3.2/Zend/zend_execute_API.c", __zend_lineno=488,

    __zend_orig_filename=0x4050a840
"/usr/local/src/php-4.3.2/Zend/zend_variables.c",
__zend_orig_lineno=44) at
/usr/local/src/php-4.3.2/Zend/zend_alloc.c:243
#2  0x404395f6 in _zval_dtor (zvalue=0xbf800188,
__zend_filename=0x4050a1c0
"/usr/local/src/php-4.3.2/Zend/zend_execute_API.c", __zend_lineno=488)
    at /usr/local/src/php-4.3.2/Zend/zend_variables.c:44
#3  0x4042fe50 in call_user_function_ex (function_table=0x8580898,
object_pp=0x14317f78, function_name=0xbf80021c,
retval_ptr_ptr=0xbf800228, param_count=0, 
    params=0x0, no_separation=1, symbol_table=0x0) at
/usr/local/src/php-4.3.2/Zend/zend_execute_API.c:488
#4  0x403bf119 in php_var_serialize_intern (buf=0xbffff1a0,
struc=0x14317f78, var_hash=0xbffff174) at
/usr/local/src/php-4.3.2/ext/standard/var.c:534
#5  0x403bf384 in php_var_serialize_intern (buf=0xbffff1a0,
struc=0x14317120, var_hash=0xbffff174) at
/usr/local/src/php-4.3.2/ext/standard/var.c:599
#6  0x403bf384 in php_var_serialize_intern (buf=0xbffff1a0,
struc=0x14317f78, var_hash=0xbffff174) at
/usr/local/src/php-4.3.2/ext/standard/var.c:599

------------------------------------------------------------------------

[2003-05-15 20:46:46] bginter at ndevtech dot net

With PHP4.2.3RC3 and --enable-memory-limit, I do get the same warning
messages you provided.  

When the limit is set to 100M like in your example, subsequent reloads
of that page seem to silently fail.  That is, no error/warning messages
are displayed and no apache processes are churning up to 100MB.  How
the process escapes the infinite loop in the example is a mystery.

When the limit is set to 250M, the crashes still occur as in previous
entries on this bug.  I can provide an updated backtrace if requested.

When the limit is set to the default (16M), the crashes do not occur. 
Subsequent reloads of the page show an ever increasing memory size
limit:

Fatal error: Allowed memory size of 16777216 bytes exhausted (tried to
allocate 44 bytes) in /usr/local/apache/lariat/lariat2/test/crash.php
on line 68
Fatal error: Allowed memory size of 17825808 bytes exhausted (tried to
allocate 35 bytes) in /usr/local/apache/lariat/lariat2/test/crash.php
on line 12
Fatal error: Allowed memory size of 18874424 bytes exhausted (tried to
allocate 40 bytes) in /usr/local/apache/lariat/lariat2/test/crash.php
on line 24
Fatal error: Allowed memory size of 19923024 bytes exhausted (tried to
allocate 44 bytes) in /usr/local/apache/lariat/lariat2/test/crash.php
on line 68
Fatal error: Allowed memory size of 20971648 bytes exhausted (tried to
allocate 41 bytes) in /usr/local/apache/lariat/lariat2/test/crash.php
on line 10
etc...

Let me stress that my code doesn't utilize memory like in the example
program.  The example demonstrates the bug in a short amount of code
and exaggerates something that seems to have been occuring in my code
on a more subtle level.

I believe that the memory limit is not a fix and at best only masks the
bug.  Maybe the increasing value in the exhausted memory errors are a
clue to the root cause of this bug?

------------------------------------------------------------------------

[2003-05-15 19:06:42] [EMAIL PROTECTED]

With PHP 4.3.2RC3 I get only this:

Fatal error: Allowed memory size of 104857600 bytes exhausted (tried to
allocate 32 bytes) in /www/apache-1.3.27/htdocs/t.php on line 83

Fatal error: Allowed memory size of 105906208 bytes exhausted (tried to
allocate 130 bytes) in Unknown on line 0

Try PHP 4.3.2RC3 and add --enable-memory-limit to your configure line.


------------------------------------------------------------------------

[2003-05-15 14:20:47] bginter at ndevtech dot net

Unfortunately, the bug persists.

In the final loop of the example code, taking a reference using the
following line causes overrun warnings in the log file:

   $subgroup =& $group1->get( $i );

Some sample error messages:

---------------------------------------
/usr/local/src/php4-STABLE-200305151730/Zend/zend_execute.h(44) : Block
0x08308530 status:
Beginning:      Overrun (magic=0x0831CB40, expected=0x7312F8DC)
      End:      Unknown
---------------------------------------
/usr/local/src/php4-STABLE-200305151730/Zend/zend_execute.h(44) : Block
0x08307648 status:
Beginning:      Overrun (magic=0x40252868, expected=0x7312F8DC)
      End:      Unknown
---------------------------------------


In the final loop of the example code, taking a copy using the
following line causes a repeatable segmentation fault.

   $subgroup = $group1->get( $i );


Here is the relevant lines of the backtrace.  Note that after line 3,
the php_var_serialize_intern line is repeated thousands of times. 

Program received signal SIGSEGV, Segmentation fault.
0x40426333 in _mem_block_check (ptr=0x830d4d4, silent=1,
__zend_filename=0x4050a040
"/usr/local/src/php4-STABLE-200305151730/Zend/zend_execute_API.c", 
    __zend_lineno=488, __zend_orig_filename=0x4050a720
"/usr/local/src/php4-STABLE-200305151730/Zend/zend_variables.c",
__zend_orig_lineno=44)
    at /usr/local/src/php4-STABLE-200305151730/Zend/zend_alloc.c:675
675             memcpy(&end_magic, (((char *)
p)+sizeof(zend_mem_header)+MEM_HEADER_PADDING+p->size), sizeof(long));
(gdb) bt
#0  0x40426333 in _mem_block_check (ptr=0x830d4d4, silent=1,
__zend_filename=0x4050a040
"/usr/local/src/php4-STABLE-200305151730/Zend/zend_execute_API.c", 
    __zend_lineno=488, __zend_orig_filename=0x4050a720
"/usr/local/src/php4-STABLE-200305151730/Zend/zend_variables.c",
__zend_orig_lineno=44)
    at /usr/local/src/php4-STABLE-200305151730/Zend/zend_alloc.c:675
#1  0x40425464 in _efree (ptr=0x830d4d4, __zend_filename=0x4050a040
"/usr/local/src/php4-STABLE-200305151730/Zend/zend_execute_API.c",
__zend_lineno=488, 
    __zend_orig_filename=0x4050a720
"/usr/local/src/php4-STABLE-200305151730/Zend/zend_variables.c",
__zend_orig_lineno=44)
    at /usr/local/src/php4-STABLE-200305151730/Zend/zend_alloc.c:243
#2  0x40438a36 in _zval_dtor (zvalue=0xbf800188,
__zend_filename=0x4050a040
"/usr/local/src/php4-STABLE-200305151730/Zend/zend_execute_API.c",
__zend_lineno=488)
    at
/usr/local/src/php4-STABLE-200305151730/Zend/zend_variables.c:44
#3  0x4042f290 in call_user_function_ex (function_table=0x830e648,
object_pp=0x1430e5d0, function_name=0xbf80021c,
retval_ptr_ptr=0xbf800228, param_count=0, 
    params=0x0, no_separation=1, symbol_table=0x0) at
/usr/local/src/php4-STABLE-200305151730/Zend/zend_execute_API.c:488
#4  0x403beb21 in php_var_serialize_intern (buf=0xbffff1a0,
struc=0x1430e5d0, var_hash=0xbffff174)
    at /usr/local/src/php4-STABLE-200305151730/ext/standard/var.c:534
#5  0x403bed84 in php_var_serialize_intern (buf=0xbffff1a0,
struc=0x1430d778, var_hash=0xbffff174)
    at /usr/local/src/php4-STABLE-200305151730/ext/standard/var.c:599


PHP was compiled with:

./configure \
--prefix=/usr/local/php_4.3.1 \
--with-apxs=/usr/local/apache/bin/apxs \
--enable-bcmath \
--enable-gd-native-ttf \
--with-gd \
--with-ttf \
--enable-calendar \
--with-mysql \
--with-openssl \
--with-iconv \
--enable-xml \
--with-pgsql=/usr/local/pgsql-7.3 \
--with-mcrypt \
--with-curl \
--with-zip \
--enable-ftp \
--with-zlib-dir=/usr \
--enable-debug

------------------------------------------------------------------------

[2003-05-14 13:34:42] [EMAIL PROTECTED]

In my case I can't get it to crash, but instead I see this in the
logs:

May 14 11:34:21 wb-01 project.ipv: PHP Fatal error:  Cannot redeclare
class baseobject:hosting in /imprev/include/hosting.inc on line 10
May 14 11:34:28 wb-01 \204W^Z^H: PHP Fatal error:  Cannot redeclare
class baseobject:hosting in /imprev/include/hosting.inc on line 10
May 14 11:34:48 wb-01 autoForms.ip\200^C: PHP Fatal error:  Cannot
redeclare class baseobject:hosting in /imprev/include/hosting.inc on
line 10
May 14 11:35:02 wb-01 (\237ÿ¿[EMAIL PROTECTED]ÿ¿v: PHP
Fatal error:  Cannot redeclare class baseobject:hosting in
/imprev/include/hosting.inc on line 10
May 14 11:35:55 wb-01 : PHP Fatal error:  Cannot redeclare class
baseobject:hosting in /imprev/include/hosting.inc on line 10
May 14 11:37:12 wb-01 8¯ÿ¿-ĞM@ ¾ÿ¿nsCoA:
PHP Fatal error:  Cannot redeclare class baseobject:hosting in
/imprev/include/hosting.inc on line 10
May 14 11:37:15 wb-01 ^B\210P@: PHP Fatal error:  Cannot redeclare
class baseobject:hosting in /imprev/include/hosting.inc on line 10
May 14 11:37:30 wb-01 ^S: PHP Fatal error:  Cannot redeclare class
baseobject:hosting in /imprev/include/hosting.inc on line 10
May 14 11:38:10 wb-01 ^C: PHP Fatal error:  Cannot redeclare class
baseobject:hosting in /imprev/include/hosting.inc on line 10
May 14 11:39:05 wb-01 i: PHP Fatal error:  Cannot redeclare class
baseobject:hosting in /imprev/include/hosting.inc on line 10
May 14 11:39:23 wb-01 A: PHP Fatal error:  Cannot redeclare class
baseobject:hosting in /imprev/include/hosting.inc on line 10

Notice the garbage instead of the filename. The website uses classes
extensively, and other pages seem to work just fine while this is the
only one that bombs (started to bomb earlier today after working for a
few weeks with no trouble). I can't verify that this is the SAME bug,
but it sure does look similar.

------------------------------------------------------------------------

The remainder of the comments for this report are too long. To view
the rest of the comments, please view the bug report online at
    http://bugs.php.net/23415

-- 
Edit this bug report at http://bugs.php.net/?id=23415&edit=1

Reply via email to