X-Authentication-Warning: delorie.com: mailnull set sender to djgpp-bounces using -f
From: Pavol Juhas <juhas AT seas DOT upenn DOT edu>
Newsgroups: comp.os.msdos.djgpp,comp.editors
Subject: Re: vim (dos32) hangs under djgpp bash
Date: Sun, 27 Jan 2002 01:36:02 -0500
Organization: University of Pennsylvania
Lines: 49
Message-ID: <3C539FD2.F493B6DA@seas.upenn.edu>
References: <a2qffr$fcc$1 AT netnews DOT upenn DOT edu> <a2r44l$sjt$1 AT antares DOT lu DOT erisoft DOT se> <a2sk29$93$1 AT netnews DOT upenn DOT edu> <1190-Sat26Jan2002094040+0200-eliz AT is DOT elta DOT co DOT il>
NNTP-Posting-Host: lrsm325pc2.lrsm.upenn.edu
Mime-Version: 1.0
Content-Type: text/plain; charset=iso-8859-2
Content-Transfer-Encoding: 7bit
X-Mailer: Mozilla 4.78 [en] (Win98; U)
X-Accept-Language: en
To: djgpp AT delorie DOT com
DJ-Gateway: from newsgroup comp.os.msdos.djgpp
Reply-To: djgpp AT delorie DOT com

Thanks for reply,  I tried your suggestions and after some
experiments and about 15 reboots I found this strange behavior:

The crash of repeated "vim -c q" never occured when invoked via make, I
saw it only after running from bash.  Strangely enough, if I call make,
grep or gawk (from bash, no arguments) before testing vim, the
crash would not occur.  However, I would always get it if my test
script was the _first_ thing to run in bash.  

I checked the source code of vim, indeed there are calls to int86()
and __dpmi_yield() in os_msdos.c.  I tried to comment out the single
call to __dpmi_yield() and recompile, but it did not help. 
I guess that leaves int86() as another option to check.

Eli Zaretskii (eliz AT is DOT elta DOT co DOT il) wrote:
> This rings a bell.  Could you please try the following experiment:
> invoke vim from COMMAND.COM, but via Make, like this:

>   c:\> make -f -
>   all:
> 	vim -c q
> 	vim -c q
> 	vim -c q
>   ^Z

> Every line after "all:" should begin with a TAB.  The "^Z" at the end
> is the Ctrl-Z character: it ends the Makefile and starts the Make run.

> (It doesn't really matter what commands are in the `all:' rule, as
> long as they are similar to those which cause the system to freeze
> when you invoke vim from Bash.  Also, I only put several identical
> lines in the above bacause you seemed to indicate that was a good way
> of reproducing the problem; if a single command is enough, please use
> just that single command.)

> The idea here is to see whether vim freezes when invoked from _any_
> DJGPP program, or just from Bash.  You could also try other DJGPP
> programs which can invoke arbitrary programs, like Less or Info.

> If invocation from other DJGPP programs also cause the freezes, then
> the problem is likely to be the one described in section 6.1 of the
> DJGPP FAQ list: on some Windows systems, calling some functions of
> interrupt 2Fh has such a nasty effect, probably due to a bug in one of
> the Windows components.  (The FAQ talks about function 1680h, but the
> problem is not limited to that function alone.)  So you could ask the
> vim developers to check whether the DJGPP port either uses the library
> function __dpmi_yield, or invokes some other function of Int 2Fh via
> int86 (as opposed to __dpmi_int).  If it does, this could be the
> cause of your problems.