| www.delorie.com/archives/browse.cgi | search | 
| Date: | Thu, 22 Aug 2002 10:56:27 +0300 | 
| From: | "Eli Zaretskii" <eliz AT is DOT elta DOT co DOT il> | 
| Sender: | halo1 AT zahav DOT net DOT il | 
| To: | "Alex Oleynikov" <alex AT compuweigh DOT com> | 
| Message-Id: | <7263-Thu22Aug2002105626+0300-eliz@is.elta.co.il> | 
| X-Mailer: | emacs 21.3.50 (via feedmail 8 I) and Blat ver 1.8.9 | 
| CC: | djgpp AT delorie DOT com | 
| In-reply-to: | <frN89.72711$Pb.3104967@news2.east.cox.net> (alex@compuweigh.com) | 
| Subject: | Re: Problem with tight kbhit() loop | 
| References: | <frN89.72711$Pb DOT 3104967 AT news2 DOT east DOT cox DOT net> | 
| Reply-To: | djgpp AT delorie DOT com | 
| Errors-To: | nobody AT delorie DOT com | 
| X-Mailing-List: | djgpp AT delorie DOT com | 
| X-Unsubscribes-To: | listserv AT delorie DOT com | 
> From: "Alex Oleynikov" <alex AT compuweigh DOT com>
> Newsgroups: comp.os.msdos.djgpp
> 
> I have a question about using kbhit() function in a tight loop like the one
> below:
> ...
> while( !kbhit() );
> 
> ch = getch();
> ...
> 
> If I just run the program that contains this code everything works fine.
> Now, if I run this program under the RHIDE's debugger and have some
> breakpoints prior to the code listed above, then this loop never quits and
> computer locks up completely (only cold re-boot helps to restart it) and
> sometimes even my CMOS settings are get screwed up, so BIOS loads their
> default values at start-up making me go nuts restoring them :o).
Is this on plain DOS or on Windows?
If the former, I think it's a known side-effect of the way CWDPMI
implements the DPMI Interrupt 31 handler: after certain operations
interrupts are left in disabled state.  Try inserting __asm__("sti")
inside the loop, and I think the problem will go away.
| webmaster | delorie software privacy | 
| Copyright © 2019 by DJ Delorie | Updated Jul 2019 |