grub-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[patch] Fix for vga terminal


From: Vesa Jääskeläinen
Subject: [patch] Fix for vga terminal
Date: Sat, 10 Nov 2007 16:04:13 +0200
User-agent: Thunderbird 2.0.0.6 (Windows/20070728)

Hi All,

Here is patch for fixing vga terminal. At least it worked fine on qemu.
Now it uses only font system to get fonts so you need to load font
module and use fonts. See gfxterm section on the wiki on how to do that.

I had to edit patch by hand as 64bit patch is still pending and I need
that to compile my codes. But it should still apply nicely to current CVS.

Thanks,
Vesa Jääskeläinen
Index: ChangeLog
===================================================================
RCS file: /sources/grub/grub2/ChangeLog,v
retrieving revision 1.438
diff -u -r1.438 ChangeLog
--- ChangeLog   6 Nov 2007 21:23:59 -0000       1.438
+++ ChangeLog   10 Nov 2007 13:57:07 -0000
@@ -1,3 +1,23 @@
+2007-11-10  Vesa Jaaskelainen  <address@hidden>
+
+       * conf/i386-pc.rmk (pkgdata_MODULES): Added vga.mod.
+       (vga_mod_SOURCES): Added.
+       (vga_mod_CFLAGS): Likewise.
+       (vga_mod_LDFLAGS): Likewise.
+
+       * term/i386/pc/vga.c (get_map_mask): Switch order of arguments in
+       grub_outb() calls.
+       (set_map_mask): Likewise.
+       (set_read_map): Likewise.
+       (set_read_address): Likewise.
+       (vga_font): Removed variable.
+       (get_vga_glyph): Removed function.
+       (invalidate_char): Likewise.
+       (write_char): Changed to use grub_font_get_glyph() for font
+       information.
+       (grub_vga_putchar): Likewise.
+       (grub_vga_getcharwidth): Likewise.
+
 2007-11-06  Robert Millan  <address@hidden>
 
        * term/i386/pc/serial.c (serial_hw_put): Switch order of arguments
Index: conf/i386-pc.rmk
===================================================================
RCS file: /sources/grub/grub2/conf/i386-pc.rmk,v
retrieving revision 1.91
diff -u -r1.91 i386-pc.rmk
--- conf/i386-pc.rmk    31 Oct 2007 22:29:20 -0000      1.91
+++ conf/i386-pc.rmk    10 Nov 2007 13:57:13 -0000
@@ -129,7 +129,8 @@
 pkgdata_MODULES = biosdisk.mod _chain.mod _linux.mod linux.mod normal.mod \
        _multiboot.mod chain.mod multiboot.mod reboot.mod halt.mod      \
        vbe.mod vbetest.mod vbeinfo.mod video.mod gfxterm.mod \
-       videotest.mod play.mod bitmap.mod tga.mod cpuid.mod serial.mod ata.mod
+       videotest.mod play.mod bitmap.mod tga.mod cpuid.mod serial.mod ata.mod \
+       vga.mod
 
 # For biosdisk.mod.
 biosdisk_mod_SOURCES = disk/i386/pc/biosdisk.c
@@ -251,4 +252,9 @@
 ata_mod_CFLAGS = $(COMMON_CFLAGS)
 ata_mod_LDFLAGS = $(COMMON_LDFLAGS)
 
+# For vga.mod.
+vga_mod_SOURCES = term/i386/pc/vga.c
+vga_mod_CFLAGS = $(COMMON_CFLAGS)
+vga_mod_LDFLAGS = $(COMMON_LDFLAGS)
+
 include $(srcdir)/conf/common.mk
Index: term/i386/pc/vga.c
===================================================================
RCS file: /sources/grub/grub2/term/i386/pc/vga.c,v
retrieving revision 1.12
diff -u -r1.12 vga.c
--- term/i386/pc/vga.c  3 Oct 2007 20:13:21 -0000       1.12
+++ term/i386/pc/vga.c  10 Nov 2007 13:57:15 -0000
@@ -18,6 +18,7 @@
 
 #include <grub/machine/vga.h>
 #include <grub/machine/console.h>
+#include <grub/cpu/io.h>
 #include <grub/term.h>
 #include <grub/types.h>
 #include <grub/dl.h>
@@ -62,7 +63,6 @@
 static int cursor_state;
 static unsigned char fg_color, bg_color;
 static struct colored_char text_buf[TEXT_WIDTH * TEXT_HEIGHT];
-static unsigned char *vga_font;
 static unsigned char saved_map_mask;
 static int page = 0;
 
@@ -97,11 +97,11 @@
   unsigned char old_data;
   
   old_addr = grub_inb (SEQUENCER_ADDR_PORT);
-  grub_outb (SEQUENCER_ADDR_PORT, MAP_MASK_REGISTER);
+  grub_outb (MAP_MASK_REGISTER, SEQUENCER_ADDR_PORT);
   
   old_data = grub_inb (SEQUENCER_DATA_PORT);
   
-  grub_outb (SEQUENCER_ADDR_PORT, old_addr);
+  grub_outb (old_addr, SEQUENCER_ADDR_PORT);
 
   return old_data;
 }
@@ -113,11 +113,11 @@
   unsigned char old_addr;
   
   old_addr = grub_inb (SEQUENCER_ADDR_PORT);
-  grub_outb (SEQUENCER_ADDR_PORT, MAP_MASK_REGISTER);
+  grub_outb (MAP_MASK_REGISTER, SEQUENCER_ADDR_PORT);
   
-  grub_outb (SEQUENCER_DATA_PORT, mask);
+  grub_outb (mask, SEQUENCER_DATA_PORT);
   
-  grub_outb (SEQUENCER_ADDR_PORT, old_addr);
+  grub_outb (old_addr, SEQUENCER_ADDR_PORT);
 }
 
 /* Set Read Map Register.  */
@@ -128,10 +128,10 @@
   
   old_addr = grub_inb (GRAPHICS_ADDR_PORT);
 
-  grub_outb (GRAPHICS_ADDR_PORT, READ_MAP_REGISTER);
-  grub_outb (GRAPHICS_DATA_PORT, map);
+  grub_outb (READ_MAP_REGISTER, GRAPHICS_ADDR_PORT);
+  grub_outb (map, GRAPHICS_DATA_PORT);
 
-  grub_outb (GRAPHICS_ADDR_PORT, old_addr);
+  grub_outb (old_addr, GRAPHICS_ADDR_PORT);
 }
 
 /* Set start address.  */
@@ -142,19 +142,18 @@
   
   old_addr = grub_inb (CRTC_ADDR_PORT);
   
-  grub_outb (CRTC_ADDR_PORT, START_ADDR_LOW_REGISTER);
-  grub_outb (CRTC_DATA_PORT, start & 0xFF);
+  grub_outb (START_ADDR_LOW_REGISTER, CRTC_ADDR_PORT);
+  grub_outb (start & 0xFF, CRTC_DATA_PORT);
   
-  grub_outb (CRTC_ADDR_PORT, START_ADDR_HIGH_REGISTER);
-  grub_outb (CRTC_DATA_PORT, start >> 8);
+  grub_outb (START_ADDR_HIGH_REGISTER, CRTC_ADDR_PORT);
+  grub_outb (start >> 8, CRTC_DATA_PORT);
 
-  grub_outb (CRTC_ADDR_PORT, old_addr);
+  grub_outb (old_addr, CRTC_ADDR_PORT);
 }
 
 static grub_err_t
 grub_vga_mod_init (void)
 {
-  vga_font = grub_vga_get_font ();
   text_mode = grub_vga_set_mode (0x10);
   cursor_state = 1;
   fg_color = DEFAULT_FG_COLOR;
@@ -175,77 +174,6 @@
 }
 
 static int
-get_vga_glyph (grub_uint32_t code, unsigned char bitmap[32], unsigned *width)
-{
-  if (code > 0x7f)
-    {
-      /* Map some unicode characters to the VGA font, if possible.  */
-      switch (code)
-       {
-       case 0x2190:    /* left arrow */
-         code = 0x1b;
-         break;
-       case 0x2191:    /* up arrow */
-         code = 0x18;
-         break;
-       case 0x2192:    /* right arrow */
-         code = 0x1a;
-         break;
-       case 0x2193:    /* down arrow */
-         code = 0x19;
-         break;
-       case 0x2501:    /* horizontal line */
-         code = 0xc4;
-         break;
-       case 0x2503:    /* vertical line */
-         code = 0xb3;
-         break;
-       case 0x250F:    /* upper-left corner */
-         code = 0xda;
-         break;
-       case 0x2513:    /* upper-right corner */
-         code = 0xbf;
-         break;
-       case 0x2517:    /* lower-left corner */
-         code = 0xc0;
-         break;
-       case 0x251B:    /* lower-right corner */
-         code = 0xd9;
-         break;
-
-       default:
-         return grub_font_get_glyph (code, bitmap, width);
-       }
-    }
-
-  if (bitmap)
-    grub_memcpy (bitmap, vga_font + code * CHAR_HEIGHT, CHAR_HEIGHT);
-  
-  *width = 1;
-  return 1;
-}
-
-static void
-invalidate_char (struct colored_char *p)
-{
-  p->code = 0xFFFF;
-  
-  if (p->width)
-    {
-      struct colored_char *q;
-
-      for (q = p + 1; q <= p + p->width; q++)
-       {
-         q->code = 0xFFFF;
-         q->width = 0;
-         q->index = 0;
-       }
-    }
-
-  p->width = 0;
-}
-
-static int
 check_vga_mem (void *p)
 {
   return (p >= (void *) (VGA_MEM + PAGE_OFFSET (page))
@@ -257,8 +185,7 @@
 write_char (void)
 {
   struct colored_char *p = text_buf + xpos + ypos * TEXT_WIDTH;
-  unsigned char bitmap[32];
-  unsigned width;
+  struct grub_font_glyph glyph;
   unsigned char *mem_base;
   unsigned plane;
 
@@ -266,8 +193,8 @@
              ypos * CHAR_HEIGHT * TEXT_WIDTH + PAGE_OFFSET (page)) - p->index;
   p -= p->index;
 
-  if (! get_vga_glyph (p->code, bitmap, &width))
-    invalidate_char (p);
+  /* Get glyph for character.  */
+  grub_font_get_glyph (p->code, &glyph);
   
   for (plane = 0x01; plane <= 0x08; plane <<= 1)
     {
@@ -283,12 +210,12 @@
        {
          unsigned i;
 
-         for (i = 0; i < width && offset < 32; i++)
+         for (i = 0; i < glyph.char_width && offset < 32; i++)
            {
              unsigned char fg_mask, bg_mask;
              
-             fg_mask = (p->fg_color & plane) ? bitmap[offset] : 0;
-             bg_mask = (p->bg_color & plane) ? ~(bitmap[offset]) : 0;
+             fg_mask = (p->fg_color & plane) ? glyph.bitmap[offset] : 0;
+             bg_mask = (p->bg_color & plane) ? ~(glyph.bitmap[offset]) : 0;
              offset++;
 
              if (check_vga_mem (mem + i))
@@ -393,36 +320,36 @@
     }
   else
     {
-      unsigned width;
+      struct grub_font_glyph glyph;
       struct colored_char *p;
       
-      get_vga_glyph (c, 0, &width);
+      grub_font_get_glyph(c, &glyph);
 
-      if (xpos + width > TEXT_WIDTH)
+      if (xpos + glyph.char_width > TEXT_WIDTH)
        grub_putchar ('\n');
 
       p = text_buf + xpos + ypos * TEXT_WIDTH;
       p->code = c;
       p->fg_color = fg_color;
       p->bg_color = bg_color;
-      p->width = width - 1;
+      p->width = glyph.char_width - 1;
       p->index = 0;
 
-      if (width > 1)
+      if (glyph.char_width > 1)
        {
          unsigned i;
 
-         for (i = 1; i < width; i++)
+         for (i = 1; i < glyph.char_width; i++)
            {
              p[i].code = ' ';
-             p[i].width = width - 1;
+             p[i].width = glyph.char_width - 1;
              p[i].index = i;
            }
        }
          
       write_char ();
   
-      xpos += width;
+      xpos += glyph.char_width;
       if (xpos >= TEXT_WIDTH)
        {
          xpos = 0;
@@ -454,12 +381,11 @@
 static grub_ssize_t
 grub_vga_getcharwidth (grub_uint32_t c)
 {
-  unsigned width;
+  struct grub_font_glyph glyph;
   
-  if (! get_vga_glyph (c, 0, &width))
-    return 0;
-
-  return width;
+  grub_font_get_glyph (c, &glyph);
+  
+  return glyph.char_width;
 }
 
 static grub_uint16_t

reply via email to

[Prev in Thread] Current Thread [Next in Thread]