ZealOS/src/Demo/Lectures/PCIInterrupts.CC

74 lines
1.3 KiB
HolyC
Raw Normal View History

2020-02-15 20:01:48 +00:00
//See $LK,"PCI",A="HI:PCI"$.
2020-02-16 00:20:04 +00:00
#if mp_count>1
#define DEST_CPU 1
2020-02-15 20:01:48 +00:00
#else
#define DEST_CPU 0
2020-02-15 20:01:48 +00:00
#endif
#assert I_USER==0x40
interrupt U0 IntMy40()
{
lock {progress1++;}
2020-02-15 20:01:48 +00:00
*(dev.uncached_alias+LAPIC_EOI)(U32 *)=0;
}
interrupt U0 IntMy41()
{
lock {progress2++;}
2020-02-15 20:01:48 +00:00
*(dev.uncached_alias+LAPIC_EOI)(U32 *)=0;
}
interrupt U0 IntMy42()
{
lock {progress3++;}
2020-02-15 20:01:48 +00:00
*(dev.uncached_alias+LAPIC_EOI)(U32 *)=0;
}
interrupt U0 IntMy43()
{
lock {progress4++;}
2020-02-15 20:01:48 +00:00
*(dev.uncached_alias+LAPIC_EOI)(U32 *)=0;
}
I64 vect[4]={&IntMy40,&IntMy41,&IntMy42,&IntMy43};
U0 Main()
{
I64 i;
U8 *da=dev.uncached_alias+IOAPIC_REG;
U32 *_d=dev.uncached_alias+IOAPIC_DATA;
2020-02-15 20:01:48 +00:00
ProgressBarsReset;
for (i=I_USER;i<I_USER+4;i++)
IntEntrySet(i,vect[i&3],IDTET_IRQ);
2020-02-15 20:01:48 +00:00
//There are like 4*6 vects. Bus zero
//has the first four vects.
for (i=IOREDTAB;i<IOREDTAB+4*2;i+=2) {
*da=i+1;
*_d=dev.mp_apic_ids[DEST_CPU]<<24;
*da=i;
*_d=0x4000+0x40+(i-IOREDTAB)/2;
}
2020-02-15 20:01:48 +00:00
Sleep(1000);
"The keyboard and timer seem to be active.\n"
"IntA:%d IntB:%d IntC:%d IntD:%d\n\n"
"IntB is my keyboard and regs a single KEY-UP.\n"
"Rerun and press a few keys.\n",
progress1,progress2,progress3,progress4;
2020-02-15 20:01:48 +00:00
//Disable vects
for (i=IOREDTAB;i<IOREDTAB+4*2;i+=2) {
*da=i+1;
*_d=dev.mp_apic_ids[DEST_CPU]<<24;
*da=i;
*_d=0x14000+0x40+(i-IOREDTAB)/2;
}
ProgressBarsReset;
2020-02-15 20:01:48 +00:00
}
Main;