From:             
Operating system: Debian Lenny (5.0.5)
PHP version:      5.2.13
Package:          PCRE related
Bug Type:         Bug
Bug description:crash in preg_replace_impl

Description:
------------
the crash occuring is most likely related to very high integer/double
values(>10M) being inserted in a long string(~20K).

the problem does not occur on PHP5.3.something so it might be a simple
backport :). unless somebody can tell me how i get more information out of
the crashing process this is all i have (trying to print local variables of
the crashing function results in:



(gdb) p **regex

Cannot access memory at address 0x686f72393438343e

os similar



the regular expression involved is most likely:

'/\{([A-Z0-9_]*)(?:\|(?P<escaper>[A-Z0-9_]+))?\}/'

executed by preg_replace_callback, where the callback is an
array('class_name', 'some_private_function')



if required i try to build a small test script and attach that - but i
guess its not required.





probably related to http://bugs.php.net/bug.php?id=39016



reproducible: always



Test script:
---------------
<?php

//no test script currently available

?>

Expected result:
----------------
no php crash correctly replaced string

Actual result:
--------------
Program received signal SIGSEGV, Segmentation fault.

[Switching to Thread 0x7f877c078750 (LWP 6259)]

preg_replace_impl (ht=5, return_value=0x12a8a90,
return_value_ptr=0x137c970, this_ptr=0xb9e82fb02f28a27c,
return_value_used=0, is_callable_replace=0 '\0')

    at /usr/src/php5/source/php5-5.2.13/Zend/zend_variables.h:32

warning: Source file is more recent than executable.

32              if (zvalue->type <= IS_BOOL) {

(gdb) bt

#0  preg_replace_impl (ht=5, return_value=0x12a8a90,
return_value_ptr=0x137c970, this_ptr=0xb9e82fb02f28a27c,
return_value_used=0, 

    is_callable_replace=0 '\0') at
/usr/src/php5/source/php5-5.2.13/Zend/zend_variables.h:32

#1  0x00007f8774cef3cd in zend_do_fcall_common_helper_SPEC
(execute_data=0x7fffffff5410) at
/usr/src/php5/source/php5-5.2.13/Zend/zend_vm_execute.h:200

#2  0x00007f8774cd8134 in execute (op_array=0xf02040) at
/usr/src/php5/source/php5-5.2.13/Zend/zend_vm_execute.h:92

#3  0x00007f8774ceecde in zend_do_fcall_common_helper_SPEC
(execute_data=0x7fffffff5760) at
/usr/src/php5/source/php5-5.2.13/Zend/zend_vm_execute.h:234

#4  0x00007f8774cd8134 in execute (op_array=0xef48b0) at
/usr/src/php5/source/php5-5.2.13/Zend/zend_vm_execute.h:92

#5  0x00007f8774ceecde in zend_do_fcall_common_helper_SPEC
(execute_data=0x7fffffff5e70) at
/usr/src/php5/source/php5-5.2.13/Zend/zend_vm_execute.h:234

#6  0x00007f8774cd8134 in execute (op_array=0xf03780) at
/usr/src/php5/source/php5-5.2.13/Zend/zend_vm_execute.h:92

#7  0x00007f8774ceecde in zend_do_fcall_common_helper_SPEC
(execute_data=0x7fffffff6330) at
/usr/src/php5/source/php5-5.2.13/Zend/zend_vm_execute.h:234

#8  0x00007f8774cd8134 in execute (op_array=0xf02c90) at
/usr/src/php5/source/php5-5.2.13/Zend/zend_vm_execute.h:92

#9  0x00007f8774ceecde in zend_do_fcall_common_helper_SPEC
(execute_data=0x7fffffff9ac0) at
/usr/src/php5/source/php5-5.2.13/Zend/zend_vm_execute.h:234

#10 0x00007f8774cd8134 in execute (op_array=0xa2aa70) at
/usr/src/php5/source/php5-5.2.13/Zend/zend_vm_execute.h:92

#11 0x00007f8774cb41c8 in zend_execute_scripts (type=32767, retval=0x0,
file_count=-25624) at /usr/src/php5/source/php5-5.2.13/Zend/zend.c:1215

#12 0x00007f8774c6e0ea in php_execute_script (primary_file=Cannot access
memory at address 0x8000ffff8b50

) at /usr/src/php5/source/php5-5.2.13/main/main.c:2058

#13 0x00007f8774d2aa73 in php_handler (r=0x7f877423690a) at
/usr/src/php5/source/php5-5.2.13/sapi/apache2handler/sapi_apache2.c:643

#14 0x0000000000438f73 in ap_run_handler (r=0xecc9a8) at
/build/buildd-apache2_2.2.9-10+lenny8-amd64-OpzZ7v/apache2-2.2.9/server/config.c:159

#15 0x000000000043c53f in ap_invoke_handler (r=0xecc9a8) at
/build/buildd-apache2_2.2.9-10+lenny8-amd64-OpzZ7v/apache2-2.2.9/server/config.c:373

#16 0x000000000044970e in ap_process_request (r=0xecc9a8)

    at
/build/buildd-apache2_2.2.9-10+lenny8-amd64-OpzZ7v/apache2-2.2.9/modules/http/http_request.c:258

#17 0x0000000000446838 in ap_process_http_connection (c=0xdfec88)

    at
/build/buildd-apache2_2.2.9-10+lenny8-amd64-OpzZ7v/apache2-2.2.9/modules/http/http_core.c:190

#18 0x0000000000440493 in ap_run_process_connection (c=0xdfec88) at
/build/buildd-apache2_2.2.9-10+lenny8-amd64-OpzZ7v/apache2-2.2.9/server/connection.c:43

#19 0x000000000044dd10 in child_main (child_num_arg=<value optimized out>)

    at
/build/buildd-apache2_2.2.9-10+lenny8-amd64-OpzZ7v/apache2-2.2.9/server/mpm/prefork/prefork.c:680

#20 0x000000000044e064 in make_child (s=0x675968, slot=1)

    at
/build/buildd-apache2_2.2.9-10+lenny8-amd64-OpzZ7v/apache2-2.2.9/server/mpm/prefork/prefork.c:777

#21 0x000000000044e60c in ap_mpm_run (_pconf=<value optimized out>,
plog=<value optimized out>, s=0x675968)

    at
/build/buildd-apache2_2.2.9-10+lenny8-amd64-OpzZ7v/apache2-2.2.9/server/mpm/prefork/prefork.c:795

#22 0x0000000000425be5 in main (argc=3, argv=0x7fffffffc558) at
/build/buildd-apache2_2.2.9-10+lenny8-amd64-OpzZ7v/apache2-2.2.9/server/main.c:732

(gdb) bt full

#0  preg_replace_impl (ht=5, return_value=0x12a8a90,
return_value_ptr=0x137c970, this_ptr=0xb9e82fb02f28a27c,
return_value_used=0, 

    is_callable_replace=0 '\0') at
/usr/src/php5/source/php5-5.2.13/Zend/zend_variables.h:32

        regex = (zval **) 0xa155b0

        replace = (zval **) 0xa155b8

        subject = (zval **) 0xa155c0

        limit = (zval **) 0x7f8774cd1a4d

        subject_entry = (zval **) 0xa155c8

        zcount = (zval **) 0x7f8774d1b868

        result = 0x12a8a08 "�\220*\001"

        result_len = 0

        limit_val = -1

        string_key = 0x10 <Address 0x10 out of bounds>

        num_key = 19345208

        callback_name = 0xef2b88 "pE9\001"

        replace_count = 10573224

        replace_count_ptr = (int *) 0x7fffffff4cd0

#1  0x00007f8774cef3cd in zend_do_fcall_common_helper_SPEC
(execute_data=0x7fffffff5410) at
/usr/src/php5/source/php5-5.2.13/Zend/zend_vm_execute.h:200

        return_reference = 1 '\001'

        opline = (zend_op *) 0x8

        original_return_value = (zval **) 0x80a370

        current_scope = (zend_class_entry *) 0xf04fe8

        current_this = (zval *) 0x0

        return_value_used = 0

        should_change_scope = 41 ')'

#2  0x00007f8774cd8134 in execute (op_array=0xf02040) at
/usr/src/php5/source/php5-5.2.13/Zend/zend_vm_execute.h:92

        execute_data = Cannot access memory at address 0x8000ffff5410

(gdb) 

-- 
Edit bug report at http://bugs.php.net/bug.php?id=52368&edit=1
-- 
Try a snapshot (PHP 5.2):            
http://bugs.php.net/fix.php?id=52368&r=trysnapshot52
Try a snapshot (PHP 5.3):            
http://bugs.php.net/fix.php?id=52368&r=trysnapshot53
Try a snapshot (trunk):              
http://bugs.php.net/fix.php?id=52368&r=trysnapshottrunk
Fixed in SVN:                        
http://bugs.php.net/fix.php?id=52368&r=fixed
Fixed in SVN and need be documented: 
http://bugs.php.net/fix.php?id=52368&r=needdocs
Fixed in release:                    
http://bugs.php.net/fix.php?id=52368&r=alreadyfixed
Need backtrace:                      
http://bugs.php.net/fix.php?id=52368&r=needtrace
Need Reproduce Script:               
http://bugs.php.net/fix.php?id=52368&r=needscript
Try newer version:                   
http://bugs.php.net/fix.php?id=52368&r=oldversion
Not developer issue:                 
http://bugs.php.net/fix.php?id=52368&r=support
Expected behavior:                   
http://bugs.php.net/fix.php?id=52368&r=notwrong
Not enough info:                     
http://bugs.php.net/fix.php?id=52368&r=notenoughinfo
Submitted twice:                     
http://bugs.php.net/fix.php?id=52368&r=submittedtwice
register_globals:                    
http://bugs.php.net/fix.php?id=52368&r=globals
PHP 4 support discontinued:          http://bugs.php.net/fix.php?id=52368&r=php4
Daylight Savings:                    http://bugs.php.net/fix.php?id=52368&r=dst
IIS Stability:                       
http://bugs.php.net/fix.php?id=52368&r=isapi
Install GNU Sed:                     
http://bugs.php.net/fix.php?id=52368&r=gnused
Floating point limitations:          
http://bugs.php.net/fix.php?id=52368&r=float
No Zend Extensions:                  
http://bugs.php.net/fix.php?id=52368&r=nozend
MySQL Configuration Error:           
http://bugs.php.net/fix.php?id=52368&r=mysqlcfg

Reply via email to