From Jcurtis@VERT to ALL on Tuesday, June 24, 2025 20:27:00
By trial and error I discovered EMM calls enable interrupts. This can
cause havoc in a TSR where you need interrupts disabled. Finding these
bugs is not easy. My TSR enables interrupts part of the time, so I do
EMM calls there. Here's an example with comments.
void
next_irq (void)
{
int x;
next:
x = next (); /* service IRQs with */
enable (); /* interrupts enabled */
# ifndef noemm /* EMM call enables interrupts, do */
emm_get_page_map (e1); /* not do it before enable () above */ # endif
if (x) {
service_com_irqs (x);
} else
service_ticktock ();
# ifndef noemm
emm_set_page_map (e1);
# endif
disable ();
if (x)
mask_irq (NO, x);
if (iq[iz])
goto next;
}
* SLMR 2.1a *
* SLMR 2.1a *
---
þ Synchronet þ Vertrauen þ Home of Synchronet þ [vert/cvs/bbs].synchro.net
Who's Online
Recent Visitors
Guest
Tuesday, March 10, 2026 18:06:38
from
Hackertown, North Korea
via
Telnet
Guest
Monday, March 09, 2026 22:42:26
from
Philidelphia, Pa
via
Telnet
BitByter
Saturday, March 07, 2026 04:14:30
from
Groton, CT
via
Telnet
Guest
Friday, February 13, 2026 04:32:48
from
Plano
via
Raw