X-Authentication-Warning: delorie.com: mailnull set sender to djgpp-bounces using -f From: joey_deeb AT yahoo DOT com (joey) Newsgroups: comp.os.msdos.djgpp Subject: Re: Running any of the OpenGUI examples in dos mode crashes... Date: 7 Dec 2001 07:54:55 -0800 Organization: http://groups.google.com/ Lines: 54 Message-ID: <4e52c237.0112070754.7d317e85@posting.google.com> References: <4e52c237 DOT 0112061151 DOT 5ed1c367 AT posting DOT google DOT com> <3c0f795a DOT sandmann AT clio DOT rice DOT edu> NNTP-Posting-Host: 24.1.184.200 Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 8bit X-Trace: posting.google.com 1007740495 9253 127.0.0.1 (7 Dec 2001 15:54:55 GMT) X-Complaints-To: groups-abuse AT google DOT com NNTP-Posting-Date: 7 Dec 2001 15:54:55 GMT To: djgpp AT delorie DOT com DJ-Gateway: from newsgroup comp.os.msdos.djgpp Reply-To: djgpp AT delorie DOT com Hi Charles! Thanks a lot for the reply! I really appreciate it! Do you think I could fix this by going into the example source and changing to a different video mode? Or maybe use an older version of the cwsdpmi? thanks a lot, and have a great day. "Charles Sandmann" wrote in message news:<3c0f795a DOT sandmann AT clio DOT rice DOT edu>... > > I've compiled all the OpenGUI examples with DJGPP, and they run fine > > under windows, but when I try to run them under DOS only mode, they > > all crash... > > The crash below is inside CWSDPMI. > > The cs is in the GDT (not invalid). Using the CWSDPMI.MAP file > from the CWSDPMI build it is says this IP should be tables.asm). > I can use dos "debug" on CWSDPMI.EXE to look at the instruction > stream near crash point, and I locate those instructions in > tables.asm. > > This is in the entry to > a interrupt 0x31 (call to the DPMI provider) - doing a simulate real > mode interrupt. It seems to be calling a video interrupt 0x10. > The real mode call structure is at ES:EDI going into the procedure; > at the crash point those values are in DS:ESI (cwsdpmi source). > The limit on DS is 1Mb and it is pointed at the XMS area(?) - but > ESI is clearly outside this limit. There is a bug in the program > which has modifed DS and not reset it properly. The call traceback > (did it print?) might tell you where this problem is. > > Windows probably just ignores this call or returns an error flag. > > > I'm using the cwsdpmi extender (v0.90 r5). Here is the crash: > > > > Exiting due to signal to SIGSEGV > > General Protection Fault at eip=00003e02 > > eax=32450300 ebx=00000010 ecx=00000019 > > edx=000000cf esi=00112524 edi=000010c0 > > ebp=000fa440 esp=00fa418 program=c:\hello.exe > > cs: sel=002b invalid > > ds: sel=00bf base=1000000 limit=000fffff > > es: sel=0033 invalid > > fs: sel=008f base=0001dac0 limit=0000ffff > > gs: sel=00c7 base=00000000 limit=0010ffff > > ss: sel=00af base=10000000 limit=0015ffff > > App stack: [000faac4..0007aac4] Exceptn stack: [0007aa20..00078ae0] > > > > I've also used a different extender (PMODE), and it crashes as well... > > As it should, since this is invalid code. Someone really should > test things in an environment other than Windows.