Mail Archives: djgpp/1997/09/23/06:33:57
On Tue, 23 Sep 1997, Mitchell Spector wrote:
> I ran it in a DOS box under Windows95, and found that I got
> 40-50 iterations per second. That's slow, but that's not the
> surprising part. The surprising part came when I launched
> Rhide, spawned a DOS shell from within Rhide (using the DOS shell
> menu item), and found that I got between 700 and 850 iterations per
> second!
Doesn't RHIDE hook the timer interrupt?
It might also matter that it hooks other hardware interrupts, such as the
keyboard, because Windows then might change the scheduling of that DOS
box. Try changing the Idle Sensitivity property and see if that matters.
> Does anybody know what difference there is between a DOS box
> spawned directly by Win95 and a DOS shell spawned by Rhide that
> could account for a 15-fold speed improvement when running
> under Rhide's DOS shell? Are interrupts handled differently
> in some way?
What happens if you spawn a DOS shell from a trivial DJGPP program, not
from RHIDE?
> I checked the various PIF's, but I don't see any differences
> between them (the PIF memory settings for DPMI memory, etc.,
> are all Win95's stock "Auto" setting).
"Auto" means that you are at Windows' mercy. Try setting 65535 (or any
other constant number) in both and see whether the difference still
persists.
> When I remove the interrupts from the program entirely,
> leaving just the overhead (loop, timing, and counting), the
> difference disappears, and I get around 3 million iterations
> per second, whether via Rhide or not. (Incidentally, this shows
> that the overhead is insignificant and that the interrupts
> themselves are very, very slow.)
Try to leave the call to __dpmi_int, but replace the interrupt and the
function by something else. E.g., let it return the BIOS clock tick, or
something else that should be almost a no-op. It might be that the
actual mechanism of issuing a real-mode interrupt is the slow part, not
the specific WINOLDAP interrupt that you are testing.
- Raw text -