Hi Rasmus,
It could actually be an fopencookie detection bug.
Can you try both of these things:
A. toggle the configure detected value for COOKIE_SEEKER_USES_FPOS_T
then recompile.
B. #undef HAVE_FOPENCOOKIE then recompile.
Hopefully the first one solves the problem (so we just need to fix
the configure check).
--Wez.
On 15/10/02, "Rasmus Lerdorf" <[EMAIL PROTECTED]> wrote:
> Wez, I think we need to pass a real FILE * into the ming stuff. Take a
> look at this segfault:
>
> (gdb) run ming.php
> Starting program: /usr/local/bin/php ming.php
> FWS%xe HdC
> Program received signal SIGSEGV, Segmentation fault.
> 0x403da4d4 in free () from /lib/libc.so.6
> (gdb) bt
> #0 0x403da4d4 in free () from /lib/libc.so.6
> #1 0x403cffe8 in _IO_free_wbackup_area_internal () from /lib/libc.so.6
> #2 0x403cdee0 in _IO_seekoff_internal () from /lib/libc.so.6
> #3 0x403d269a in fseek () from /lib/libc.so.6
> #4 0x40506d82 in SWFInput_file_seek (input=0x8321ae0, offset=0, whence=0) at
>input.c:93
> #5 0x40506c9e in SWFInput_seek (input=0x8321ae0, offset=0, whence=0) at input.c:52
> #6 0x40506d31 in SWFInput_rewind (input=0x8321ae0) at input.c:75
> #7 0x40507545 in methodWriteJpegFile (input=0x8321ae0, method=0x4001d610
><phpByteOutputMethod>, data=0x0)
> at jpeg.c:87
> #8 0x4050776d in writeSWFJpegBitmapToMethod (block=0x8321b58, method=0x4001d610
><phpByteOutputMethod>, data=0x0)
> at jpeg.c:181
> #9 0x40504451 in writeSWFBlockToMethod (block=0x8321b58, method=0x4001d610
><phpByteOutputMethod>, data=0x0)
> at block.c:87
> #10 0x404f2ab8 in SWFBlockList_writeBlocksToMethod (list=0x8314480,
>method=0x4001d610 <phpByteOutputMethod>,
> data=0x0) at blocklist.c:78
> #11 0x404f1ed2 in SWFMovie_output (movie=0x832cfd0, method=0x4001d610
><phpByteOutputMethod>, data=0x0)
> at movie.c:262
> #12 0x4001d681 in zif_swfmovie_output (ht=0, return_value=0x832da2c,
>this_ptr=0x83228d4, return_value_used=0)
> at /home/rasmus/php4/ext/ming/ming.c:1432
> #13 0x081d8807 in execute (op_array=0x8321104) at
>/home/rasmus/php4/Zend/zend_execute.c:1597
> #14 0x081c698c in zend_execute_scripts (type=8, retval=0x0, file_count=3) at
>/home/rasmus/php4/Zend/zend.c:839
> #15 0x0818f622 in php_execute_script (primary_file=0xbffff880) at
>/home/rasmus/php4/main/main.c:1542
> #16 0x081de9d6 in main (argc=2, argv=0xbffff924) at
>/home/rasmus/php4/sapi/cli/php_cli.c:695
> #17 0x4037d1c4 in __libc_start_main () from /lib/libc.so.6
> (gdb) up
> #1 0x403cffe8 in _IO_free_wbackup_area_internal () from /lib/libc.so.6
> (gdb) up
> #2 0x403cdee0 in _IO_seekoff_internal () from /lib/libc.so.6
> (gdb) up
> #3 0x403d269a in fseek () from /lib/libc.so.6
> (gdb) up
> #4 0x40506d82 in SWFInput_file_seek (input=0x8321ae0, offset=0, whence=0)
> at input.c:93
> 93 if(fseek((FILE *)input->data, offset, whence) == -1)
> (gdb) p *(FILE *)input->data
> $3 = {_flags = 1930623196, _IO_read_ptr = 0x82308e0
>"/home/rasmus/php4/Zend/zend_API.c",
> _IO_read_end = 0x255 <Address 0x255 out of bounds>, _IO_read_base = 0x0,
> _IO_write_base = 0x82308e0 "/home/rasmus/php4/Zend/zend_API.c",
> _IO_write_ptr = 0x249 <Address 0x249 out of bounds>, _IO_write_end = 0x8315030
>"\022s\017#\b\006\001",
> _IO_buf_base = 0x8314380 "\022s\017#\b", _IO_buf_end = 0x2c <Address 0x2c out of
>bounds>,
> _IO_save_base = 0x8 <Address 0x8 out of bounds>, _IO_backup_base = 0x7 <Address
>0x7 out of bounds>,
> _IO_save_end = 0x0, _markers = 0x0, _chain = 0x0, _fileno = 0, _blksize = 0,
>_old_offset = 137446308,
> _cur_column = 20156, _vtable_offset = 28 '\034', _shortbuf = "\b", _lock =
>0x5a010000,
> _offset = 3066894738570346496, __pad1 = 0x0, __pad2 = 0x83143d0, _mode = 81,
> _unused2 = "\022s\017#\b", '\0' <repeats 15 times>, " C1\bC1\b ", '\0' <repeats 18
>times>}
> (gdb) p *(php_stream*)input->data
> $7 = {ops = 0x7312f8dc, abstract = 0x82308e0, filterhead = 0x255, filtertail = 0x0,
>wrapper = 0x82308e0,
> wrapperthis = 0x249, wrapperdata = 0x8315030, fgetss_state = 137446272,
>is_persistent = 44,
> mode = "\b\0\0\0\a\0\0\0\0\0\0\0\0\0\0", rsrc_id = 0, in_free = 0,
>fclose_stdiocast = 0, stdiocast = 0x83143a4,
> __exposed = 136072892, __orig_path = 0x5a010000 "", context = 0x0, flags =
>714067076, position = 0,
> readbuf = 0x83143d0 "\022s\b#\bU\002", readbuflen = 81, readpos = 1930623196,
>writepos = 136515520,
> chunk_size = 178, eof = 0}
>
> It is casting it to a FILE * and trying to do an fseek, so passing it a
> php_stream is bad news here.
>
> -Rasmus
--
PHP Development Mailing List <http://www.php.net/>
To unsubscribe, visit: http://www.php.net/unsub.php