+ outb(0x80, (counter & 0xFF));
+
+ strcpy(thestr, "15-412! xxxxxxxx xxxxxxxx");
+ tohex(thestr + 8, inl(0x0834));
+ tohex(thestr + 17, counter);
+ strblit(thestr, 0, 0);
+
+ if (inl(0x834) & 0x20)
+ dolog("Warning: unhandled APM access");
+ if (inl(0x834) & 0x1000)
+ {
+ if (inl(0x844) & 0x1000) /* devact_sts */
+ {
+ pci_dump();
+ outl(0x844, 0x1000); /* ack it */
+ }
+ }
+ if (inl(0x834) & 0x4000)
+ dolog("Long periodic timer");
+ if (inl(0x840) & 0x1000)
+ {
+ pci_dump();
+ outl(0x840, 0x1100);
+ outl(0x840, 0x0100);
+ }
+ if (inl(0x834) & ~(0x4160))
+ {
+ char s[40];
+ strcpy(s, "Unknown: xxxxxxxx");
+ tohex(s + 9, inl(0x834) & ~(0x140));
+ dolog(s);
+ }
+
+
+ outlog();
+
+ outl(0xCF8, pcisave);
+ outb(0x3D4, vgasave);
+
+ outl(0x848, 0x1000);
+ outl(0x834, /*0x40*/0xFFFF); // ack the periodic IRQ
+ outb(0x830, (inb(0x830) | 0x2) & ~0x40);
+ outb(0x830, inb(0x830) | 0x40);
+