I get a SIGSEGV exception when loading certain images in:
intfgraphics.pas, line 4990. package LCLBase.
The error occurs both in my own app and in the otherwise excellent image viewer example application (imgview).
I am loading playing cards in a card game. Some load OK, many do not.
This freezes attempts to convert my D7 app to Lazarus.
Steps to reproduce:
Compile and run the image viewer application.
Try opening the bitmaps of playing cards in the attached zip file:
H02.bmp, C04.bmp do not load and produce the error.
D13.bmp is loaded correctly (no error).
Additional information:
The bug was reported in the Graphics forum. One answer was:
Quote
Had a bit of the same problem a few years ago.
I changed my images to PNG and everything was
working again, so i never looked at the problem ?
Maybe it was just lucky
Unquote.
"Compile and run the image viewer application." assuming he means $(lazarusdir)\examples\imgviewer
Tried on FPC trunk x86, Laz trunk, Win, opening the directory; SIGSEGV at 5239, in this line:
LineBuf[idx+1] := LineBuf[idx+1] shl 4;
#0 DORLE4(0x218f284) at intfgraphics.pas:5239#1 TLAZREADERDIB__READSCANLINE(88, <error reading variable>) at intfgraphics.pas:5297#2 TLAZREADERDIB__INTERNALREADBODY(<error reading variable>) at intfgraphics.pas:5895#3 TLAZREADERDIB__INTERNALREAD(0x22cf860, 0x232e9a0, <error reading variable>) at intfgraphics.pas:5593#4 FPIMAGE$_$TFPCUSTOMIMAGEREADER_$__$$_IMAGEREAD$TSTREAM$TFPCUSTOMIMAGE$$TFPCUSTOMIMAGE at :0#5 TFPIMAGEBITMAP__READSTREAM(0x22cf860, 1822, <error reading variable>) at .\include\fpimagebitmap.inc:141#6 TRASTERIMAGE__LOADFROMSTREAM(0x22e66d0, 1822, <error reading variable>) at .\include\rasterimage.inc:441#7 TBITMAP__LOADFROMSTREAM(0x22e66d0, 1822, <error reading variable>) at .\include\bitmap.inc:147#8 TRASTERIMAGE__LOADFROMSTREAM(0x22e66d0, <error reading variable>) at .\include\rasterimage.inc:417#9 TPICTURE__LOADFROMSTREAMWITHCLASS(0x22e66d0, <incomplete type>, <error reading variable>) at .\include\picture.inc:771#10 TPICTURE__LOADFROMSTREAMWITHFILEEXT(0x22e66d0, 0x22d2dcc '&'#215, <error reading variable>) at .\include\picture.inc:652#11 TPICTURE__LOADFROMFILE(0x22deefc 'C'#165#196'6'#247#5#199'E'#196'3'#3'B'#230'&'#215, <error reading variable>) at .\include\picture.inc:518#12 TMAINFORM__SHOWFILE(0, <error reading variable>) at frmmain.pas:180#13 TMAINFORM__ADDFILE(0x22beeec 'D:\Cop\t\C04.bmp', true, <error reading variable>) at frmmain.pas:159#14 TMAINFORM__ADDDIR(0x22cf72c 'C'#165#196'6'#247#5#199'E'#192#6'p', false, <error reading variable>) at frmmain.pas:243#15 TMAINFORM__AOPENDIREXECUTE(0x2375260, <error reading variable>) at frmmain.pas:220#16 CLASSES$_$TBASICACTION_$__$$_EXECUTE$$BOOLEAN at :0#17 TCONTAINEDACTION__EXECUTE(<error reading variable>) at .\include\containedaction.inc:98#18 TCUSTOMACTION__EXECUTE(<error reading variable>) at .\include\customaction.inc:246#19 CLASSES$_$TBASICACTIONLINK_$__$$_EXECUTE$TCOMPONENT$$BOOLEAN at :0#20 TMENUITEM__CLICK(<error reading variable>) at .\include\menuitem.inc:87#21 TMENUITEM__DOCLICKED(void, <error reading variable>) at .\include\menuitem.inc:282#22 SYSTEM$_$TOBJECT_$__$$_DISPATCH$formal at :0#23 VMT_$MENUS_$$_TMENU at :0#24 ?? at :0#25 ?? at :0#26 ?? at :0#27 CUSTOMFORMWNDPROC(10749032, 273, 3, 0) at .\win32\win32wsforms.pp:395#28 USER32!OffsetRect at :0#29 ?? at :0#30 USER32!IsWindow at :0#31 ADJUSTFORMBOUNDS at .\win32\win32wsforms.pp:316#32 USER32!AnyPopup at :0#33 ?? at :0
Lazarus 1.3 r43475 FPC 2.6.2 i386-win32-win32/win64 32-bit fpc on Win7-64
Only D13.bmp opens.
Attempts to open any of the other bmp's freezes the $(lazarusdir)\examples\imgviewer application and Windows will kill it.
Running it in gdb and trying to open "C04.bmp" gives:
C:\devel\lazarus\examples\imgviewer>gdb imgviewer
GNU gdb (GDB) 7.2
Copyright (C) 2010 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later &LtPos;http://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law. Type "show copying"
and "show warranty" for details.
This GDB was configured as "mingw32".
For bug reporting instructions, please see:
&LtPos;http://www.gnu.org/software/gdb/bugs/>...
Reading symbols from C:\devel\lazarus\examples\imgviewer/imgviewer.exe...done.
(gdb) run
Starting program: C:\devel\lazarus\examples\imgviewer/imgviewer.exe
[New Thread 1072.0x15d8] //Press Ctrl+O to open file
[New Thread 1072.0x1380]
[New Thread 1072.0xe9c]
[New Thread 1072.0xb2c]
[New Thread 1072.0x1298]
[New Thread 1072.0x150c]
[New Thread 1072.0xfb4]
[New Thread 1072.0xbcc]
[New Thread 1072.0x4a0]
[New Thread 1072.0xe14]
[New Thread 1072.0x13a8]
[New Thread 1072.0x1694]
[New Thread 1072.0x16a8]
[New Thread 1072.0x780]
[New Thread 1072.0x117c]
[New Thread 1072.0x2e0]
[New Thread 1072.0xd58]
[New Thread 1072.0x944]
[New Thread 1072.0x171c]
[New Thread 1072.0xd4c]
[New Thread 1072.0x1388]
BFD: C:\Windows\SysWOW64\WMVCORE.DLL: Warning: Ignoring section flag IMAGE_SCN_M
EM_NOT_PAGED in section .reloc
//At this point the Windows OpenDialog has appeared
[New Thread 1072.0xbf0] //click on a file in the Open dialog
[New Thread 1072.0x15dc]
I have tried loading the playing cards after converting them from .bmp to .png.
the images do load correctly in imgview, which uses a TPicture.LoadFromFile call.
However, this does not solve the problem.
TPicture.LoadFromFile supports the .jpg format as well as .bmp and .png, and a similar problem occurs. For example, in the attached test_jpg.zip, welcome.jpg is loaded correctly, and andre.jpg crashes the app.
There may be .png files out there that create a similar problem, which must be deeper than a format issue.
No, sorry, this doesn't help. We're talking about a bug with bmp handling, not other formats. Please post other discussion on the forum thread.
Please open a new bug report for the jpg issue, thanks - you cannot know if the cause is the same even if the symptoms are similar.
Edit: please check if the Lazarus jpg code supports the compression you use in that faulty jpg. There are multiple ways to encode jpgs and I strongly suspect not all of them are supported.
Note: are you SURE you haven't just renamed a bmp to Andre.jpg? That file starts with BM, which is probably a marker for BMP, not with hex FF F8 which is the magic number for jpg...
@(0071551):yes,perhapsthrowinawhiled[1]>0dobeginLineBuf[idx]:=(LineBuf[idx]and$F0)or(LineBuf[idx+1]shr4);LineBuf[idx+1]:=LineBuf[idx+1]shl4;Inc(idx);Dec(d[1]);//just added this after line 5240? without knowing what I'm doing... :(NotethatthebughappensinadifferentlineformewithFPCtrunk.