ID: 35751
User updated by: lehmann at ans-netz dot de
Reported By: lehmann at ans-netz dot de
-Status: Feedback
+Status: Open
Bug Type: Date/time related
Operating System: FreeBSD 6.0/alpha
PHP Version: 5.1.1
New Comment:
here is the backtrace from the latest cvs snapshot (please don't be
iretated by the path i renamed php5-CVS... to php-5.1.1)
#0 0x0000000120029ce8 in php_format_date (
format=0x2 <Address 0x2 out of bounds>, format_len=1, ts=10000,
localtime=1)
at
/usr/obj/alpha-ev56-6.0/usr/ports/lang/php5/work/php-5.1.1/ext/date/php_date.c:465
465 switch (format[i]) {
(gdb) bt
#0 0x0000000120029ce8 in php_format_date (
format=0x2 <Address 0x2 out of bounds>, format_len=1, ts=10000,
localtime=1)
at
/usr/obj/alpha-ev56-6.0/usr/ports/lang/php5/work/php-5.1.1/ext/date/php_date.c:465
#1 0x0000000000000002 in ?? ()
Cannot access memory at address 0xfffffffffffffffe
(gdb) up 0
#0 0x0000000120029ce8 in php_format_date (
format=0x2 <Address 0x2 out of bounds>, format_len=1, ts=10000,
localtime=1)
at
/usr/obj/alpha-ev56-6.0/usr/ports/lang/php5/work/php-5.1.1/ext/date/php_date.c:465
465 switch (format[i]) {
(gdb) list
460 }
461 buffer[32] = '\0';
462 timelib_isoweek_from_date(t->y, t->m, t->d, &isoweek,
&isoyear);
463
464 for (i = 0; i < format_len; i++) {
465 switch (format[i]) {
466 /* day */
467 case 'd': snprintf(buffer, 32, "%02d",
(int) t->d); break;
468 case 'D': snprintf(buffer, 32, "%s",
day_short_names[timelib_day_of_week(t->y, t->m, t->d)]); break;
469 case 'j': snprintf(buffer, 32, "%d",
(int) t->d); break;
(gdb)
Previous Comments:
------------------------------------------------------------------------
[2005-12-20 23:00:28] [EMAIL PROTECTED]
Please try using this CVS snapshot:
http://snaps.php.net/php5.1-latest.tar.gz
For Windows:
http://snaps.php.net/win32/php5.1-win32-latest.zip
------------------------------------------------------------------------
[2005-12-20 20:53:59] lehmann at ans-netz dot de
here is the backtrace:
(gdb) bt
#0 0x00000001200297c8 in php_format_date (format=0x120132fd8 "\036",
format_len=540212224, ts=10000, localtime=46)
at
/usr/obj/alpha-ev56-6.0/usr/ports/lang/php5/work/php-5.1.1/ext/date/php_date.c:467
#1 0x0000000000000000 in ?? ()
Previous frame identical to this frame (corrupt stack?)
(gdb) up 0
#0 0x00000001200297c8 in php_format_date (format=0x120132fd8 "\036",
format_len=540212224, ts=10000, localtime=46)
at
/usr/obj/alpha-ev56-6.0/usr/ports/lang/php5/work/php-5.1.1/ext/date/php_date.c:467
467 switch (format[i]) {
(gdb) list
462 }
463 buffer[32] = '\0';
464 timelib_isoweek_from_date(t->y, t->m, t->d, &isoweek,
&isoyear);
465
466 for (i = 0; i < format_len; i++) {
467 switch (format[i]) {
468 /* day */
469 case 'd': snprintf(buffer, 32, "%02d",
(int) t->d); break;
470 case 'D': snprintf(buffer, 32, "%s",
day_short_names[timelib_day_of_week(t->y, t->m, t->d)]); break;
471 case 'j': snprintf(buffer, 32, "%d",
(int) t->d); break;
(gdb)
------------------------------------------------------------------------
[2005-12-20 20:33:57] [EMAIL PROTECTED]
Instead of running it through your webserver, try the command line...
(with GDB too).
------------------------------------------------------------------------
[2005-12-20 20:25:19] lehmann at ans-netz dot de
I'm not able to get a working backtrace, i compiled php with
--enable-debug during configure:
[EMAIL PROTECTED] php-5.1.1> gdb /usr/local/sbin/httpd /tmp/httpd.core
GNU gdb 6.1.1 [FreeBSD]
Copyright 2004 Free Software Foundation, Inc.
GDB is free software, covered by the GNU General Public License, and
you are
welcome to change it and/or distribute copies of it under certain
conditions.
Type "show copying" to see the conditions.
There is absolutely no warranty for GDB. Type "show warranty" for
details.
This GDB was configured as "alpha-marcel-freebsd"...(no debugging
symbols found)...
Core was generated by `httpd'.
Program terminated with signal 11, Segmentation fault.
Reading symbols from /lib/libz.so.3...(no debugging symbols
found)...done.
Loaded symbols for /lib/libz.so.3
Reading symbols from /usr/lib/libssl.so.4...(no debugging symbols
found)...done.
Loaded symbols for /usr/lib/libssl.so.4
[...]
Loaded symbols for /usr/local/libexec/apache2/libphp5.so
Reading symbols from /usr/local/lib/libxml2.so.5...done.
Loaded symbols for /usr/local/lib/libxml2.so.5
Reading symbols from /libexec/ld-elf.so.1...done.
Loaded symbols for /libexec/ld-elf.so.1
#0 0x0000000160953668 in ?? () from
/usr/local/libexec/apache2/libphp5.so
(gdb) bt
#0 0x0000000160953668 in ?? () from
/usr/local/libexec/apache2/libphp5.so
#1 0x0000000000000002 in ?? ()
Cannot access memory at address 0xfffffffffffffffe
(gdb)
------------------------------------------------------------------------
[2005-12-20 19:11:13] lehmann at ans-netz dot de
Description:
------------
Using date() in combination with a timestamp makes my httpd segfault on
FreeBSD 5.0/alpha - it worked with PHP 5.0.5 like a charm.
Using just date() with a format string, but w/o a timestamp works w/o
problems.
Reproduce code:
---------------
<?echo date('Y',10000)?>
Expected result:
----------------
it should work?
Actual result:
--------------
[EMAIL PROTECTED] php5> ktrace httpd -X
pid 30132 (httpd): unaligned access: va=0x11ffc72c pc=0x160a59720
ra=0x160a59e44 op=stq
Segmentation fault
Exit 139
[EMAIL PROTECTED] php5>
last part of the ktrace:
27732 httpd RET read 487/0x1e7
27732 httpd CALL stat(0x1605da495,0x11ffe658)
27732 httpd NAMI "/etc/nsswitch.conf"
27732 httpd RET stat 0
27732 httpd CALL stat(0x1605da495,0x11ffe658)
27732 httpd Events dropped.
27732 httpd RET stat 0
27732 httpd Events dropped.
27732 httpd CALL open(0x1202e43c0,0,0x1b6)
27732 httpd Events dropped.
27732 httpd RET lstat 0
27732 httpd Events dropped.
27732 httpd RET open 23/0x17
27732 httpd Events dropped.
27732 httpd RET open 23/0x17
27732 httpd Events dropped.
27732 httpd RET stat 0
27732 httpd Events dropped.
27732 httpd RET lstat 0
27732 httpd Events dropped.
27732 httpd RET lstat 0
27732 httpd Events dropped.
27732 httpd RET lstat 0
27732 httpd Events dropped.
27732 httpd RET lstat 0
27732 httpd Events dropped.
27732 httpd CALL gettimeofday(0x11ffc548,0)
[EMAIL PROTECTED] php5>
------------------------------------------------------------------------
--
Edit this bug report at http://bugs.php.net/?id=35751&edit=1