counter++;
sprintf(statstr, "NetWatch! %08x %08x", smi_status(), counter);
- strblit(statstr, 0, 0);
+ strblit(statstr, 0, 0, 0);
serial_init();
eth_poll();
);
}
-void strblit(char *src, int row, int col)
+void strblit(char *src, int row, int col, int fill)
{
char *destp = vga_base() + row * 80 * 2 + col * 2;
outb(0x80, 0x3C);
{
*(destp++) = *(src++);
*(destp++) = COLOR;
+ col++;
}
+ if (fill)
+ while (col < 80)
+ {
+ *(destp++) = ' ';
+ *(destp++) = COLOR;
+ col++;
+ }
outb(0x80, 0x3F);
smram_restore_state(old_state);
void outlog()
{
- int y, x;
- char *basep = vga_base();
-
- smram_state_t old_state = smram_save_state();
-
- smram_aseg_set_state(SMRAM_ASEG_SMMCODE);
+ int y;
- for (y = 0; y < LOG_ONSCREEN; y++)
- for (x = 40; x < 80; x++)
- {
- basep[y*80*2+x*2] = ' ';
- basep[y*80*2+x*2+1] = 0x1F;
- }
-
- smram_restore_state(old_state);
-
for (y = -LOG_ONSCREEN; y < 0; y++)
- strblit(logents[(y + prodptr) % LOGLEN], y + LOG_ONSCREEN, 40);
+ strblit(logents[(y + prodptr) % LOGLEN], y + LOG_ONSCREEN, 40, 1);
}
void dolog(const char *s)
void vga_flush_imm(int enb);
-void strblit(char *src, int row, int col);
+void strblit(char *src, int row, int col, int fill);
void dolog(char *s);
void dologf(char *s, ...);