Message-ID: <008a01bf0fe9$926f7d80$293f8589@gv015029.bgo.nera.no> From: "Gisle Vanem" <gvanem AT eunet DOT no> To: <djgpp AT delorie DOT com> Subject: Re: interrupt service routine in protected mode for a PCI device Date: Wed, 6 Oct 1999 12:57:17 +0200 MIME-Version: 1.0 Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: 7bit X-Priority: 3 X-MSMail-Priority: Normal X-Mailer: Microsoft Outlook Express 4.72.3110.5 X-MimeOLE: Produced By Microsoft MimeOLE V4.72.3110.3 Reply-To: djgpp AT delorie DOT com Martin Czamai <Martin_Czamai AT peak-service DOT com> said: >can anybody tell me, whats wrong with this code? >... > BYTE PCI_INT = GetINT(Device); // Interrupt Line Number read from >the configuration space > > // interrupt service routine (ISR) must NOT be swaped out to file > _go32_dpmi_lock_code(ISR, (DWORD)LOCK_ISR - (DWORD)ISR); >// _go32_dpmi_lock_data((void*) &Msg, (long)sizeof(Msg)); // >currently not used > > _go32_dpmi_get_protected_mode_interrupt_vector(PCI_INT, >&OldHandler); > Handler.pm_offset = (int)ISR; > _go32_dpmi_allocate_iret_wrapper(&Handler); > _go32_dpmi_set_protected_mode_interrupt_vector(PCI_INT, &Handler); >... >// SYSTEM CRASHES NOW!!! (sinply hangs up) AFAICS, because you use assert(): >void ISR(void) > { assert(0); // not implemented > } 'assert(0)' will call DOS-functions to print some text. Use cputs() if you need to print something in an IRQ-handler. And besides you didn't send an EOI command to the intr-controller. Gisle V.