c35fc5bd15
* grub-core/Makefile.core.def (mda_text): New module. * grub-core/lib/legacy_parse.c (grub_legacy_parse): Support `hercules'. * grub-core/term/i386/vga_common.c (grub_console_cur_color): Moved to .. * grub-core/term/i386/pc/vga_text.c (cur_color): ... here * grub-core/term/i386/pc/console.c (grub_console_cur_color): ... and here. * grub-core/term/i386/vga_common.c (grub_console_getwh): Moved to .. * grub-core/term/i386/pc/vga_text.c (grub_console_getwh): ... here * grub-core/term/i386/pc/console.c (grub_console_getwh): ... and here. * grub-core/term/i386/vga_common.c (grub_console_setcolorstate): Moved to .. * grub-core/term/i386/pc/vga_text.c (grub_console_setcolorstate): ... here * grub-core/term/i386/pc/console.c (grub_console_setcolorstate): ... and here. * grub-core/term/i386/vga_common.c: Removed. * include/grub/i386/vga_common.h: Likewise. * include/grub/vga.h (grub_vga_cr_bw_write): New function. (grub_vga_cr_bw_read): Likewise. * include/grub/vgaregs.h (GRUB_VGA_IO_CR_BW_INDEX): New enum value. (GRUB_VGA_IO_CR_BW_DATA): Likewise. * grub-core/term/i386/pc/vga_text.c [MODE_MDA]: Call grub_vga_cr_bw_read/grub_vga_cr_bw_write instead of grub_vga_cr_read/grub_vga_cr_write. (grub_vga_text_setcolorstate) [MODE_MDA]: Ignore color.
307 lines
9.4 KiB
C
307 lines
9.4 KiB
C
/*
|
|
* GRUB -- GRand Unified Bootloader
|
|
* Copyright (C) 2010 Free Software Foundation, Inc.
|
|
*
|
|
* GRUB is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* GRUB is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with GRUB. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifndef GRUB_VGAREGS_HEADER
|
|
#define GRUB_VGAREGS_HEADER 1
|
|
|
|
#ifdef ASM_FILE
|
|
#define GRUB_VGA_IO_SR_INDEX 0x3c4
|
|
#define GRUB_VGA_IO_SR_DATA 0x3c5
|
|
#else
|
|
|
|
enum
|
|
{
|
|
GRUB_VGA_IO_CR_BW_INDEX = 0x3b4,
|
|
GRUB_VGA_IO_CR_BW_DATA = 0x3b5,
|
|
GRUB_VGA_IO_ARX = 0x3c0,
|
|
GRUB_VGA_IO_ARX_READ = 0x3c1,
|
|
GRUB_VGA_IO_MISC_WRITE = 0x3c2,
|
|
GRUB_VGA_IO_SR_INDEX = 0x3c4,
|
|
GRUB_VGA_IO_SR_DATA = 0x3c5,
|
|
GRUB_VGA_IO_PIXEL_MASK = 0x3c6,
|
|
GRUB_VGA_IO_PALLETTE_READ_INDEX = 0x3c7,
|
|
GRUB_VGA_IO_PALLETTE_WRITE_INDEX = 0x3c8,
|
|
GRUB_VGA_IO_PALLETTE_DATA = 0x3c9,
|
|
GRUB_VGA_IO_GR_INDEX = 0x3ce,
|
|
GRUB_VGA_IO_GR_DATA = 0x3cf,
|
|
GRUB_VGA_IO_CR_INDEX = 0x3d4,
|
|
GRUB_VGA_IO_CR_DATA = 0x3d5,
|
|
GRUB_VGA_IO_INPUT_STATUS1_REGISTER = 0x3da
|
|
};
|
|
|
|
#define GRUB_VGA_IO_INPUT_STATUS1_VERTR_BIT 0x08
|
|
|
|
enum
|
|
{
|
|
GRUB_VGA_CR_HTOTAL = 0x00,
|
|
GRUB_VGA_CR_HORIZ_END = 0x01,
|
|
GRUB_VGA_CR_HBLANK_START = 0x02,
|
|
GRUB_VGA_CR_HBLANK_END = 0x03,
|
|
GRUB_VGA_CR_HORIZ_SYNC_PULSE_START = 0x04,
|
|
GRUB_VGA_CR_HORIZ_SYNC_PULSE_END = 0x05,
|
|
GRUB_VGA_CR_VERT_TOTAL = 0x06,
|
|
GRUB_VGA_CR_OVERFLOW = 0x07,
|
|
GRUB_VGA_CR_BYTE_PANNING = 0x08,
|
|
GRUB_VGA_CR_CELL_HEIGHT = 0x09,
|
|
GRUB_VGA_CR_CURSOR_START = 0x0a,
|
|
GRUB_VGA_CR_CURSOR_END = 0x0b,
|
|
GRUB_VGA_CR_START_ADDR_HIGH_REGISTER = 0x0c,
|
|
GRUB_VGA_CR_START_ADDR_LOW_REGISTER = 0x0d,
|
|
GRUB_VGA_CR_CURSOR_ADDR_HIGH = 0x0e,
|
|
GRUB_VGA_CR_CURSOR_ADDR_LOW = 0x0f,
|
|
GRUB_VGA_CR_VSYNC_START = 0x10,
|
|
GRUB_VGA_CR_VSYNC_END = 0x11,
|
|
GRUB_VGA_CR_VDISPLAY_END = 0x12,
|
|
GRUB_VGA_CR_PITCH = 0x13,
|
|
GRUB_VGA_CR_UNDERLINE_LOCATION = 0x14,
|
|
GRUB_VGA_CR_VERTICAL_BLANK_START = 0x15,
|
|
GRUB_VGA_CR_VERTICAL_BLANK_END = 0x16,
|
|
GRUB_VGA_CR_MODE = 0x17,
|
|
GRUB_VGA_CR_LINE_COMPARE = 0x18,
|
|
};
|
|
|
|
enum
|
|
{
|
|
GRUB_VGA_CR_BYTE_PANNING_NORMAL = 0
|
|
};
|
|
|
|
enum
|
|
{
|
|
GRUB_VGA_CR_UNDERLINE_LOCATION_DWORD_MODE = 0x40
|
|
};
|
|
|
|
enum
|
|
{
|
|
GRUB_VGA_IO_MISC_COLOR = 0x01,
|
|
GRUB_VGA_IO_MISC_ENABLE_VRAM_ACCESS = 0x02,
|
|
GRUB_VGA_IO_MISC_28MHZ = 0x04,
|
|
GRUB_VGA_IO_MISC_EXTERNAL_CLOCK_0 = 0x08,
|
|
GRUB_VGA_IO_MISC_UPPER_64K = 0x20,
|
|
GRUB_VGA_IO_MISC_NEGATIVE_HORIZ_POLARITY = 0x40,
|
|
GRUB_VGA_IO_MISC_NEGATIVE_VERT_POLARITY = 0x80,
|
|
};
|
|
|
|
enum
|
|
{
|
|
GRUB_VGA_ARX_MODE = 0x10,
|
|
GRUB_VGA_ARX_OVERSCAN = 0x11,
|
|
GRUB_VGA_ARX_COLOR_PLANE_ENABLE = 0x12,
|
|
GRUB_VGA_ARX_HORIZONTAL_PANNING = 0x13,
|
|
GRUB_VGA_ARX_COLOR_SELECT = 0x14
|
|
};
|
|
|
|
enum
|
|
{
|
|
GRUB_VGA_ARX_MODE_TEXT = 0x00,
|
|
GRUB_VGA_ARX_MODE_GRAPHICS = 0x01,
|
|
GRUB_VGA_ARX_MODE_ENABLE_256COLOR = 0x40
|
|
};
|
|
|
|
#define GRUB_VGA_CR_WIDTH_DIVISOR 8
|
|
|
|
#define GRUB_VGA_CR_OVERFLOW_VERT_DISPLAY_ENABLE_END1_SHIFT 7
|
|
#define GRUB_VGA_CR_OVERFLOW_VERT_DISPLAY_ENABLE_END1_MASK 0x02
|
|
#define GRUB_VGA_CR_OVERFLOW_VERT_DISPLAY_ENABLE_END2_SHIFT 3
|
|
#define GRUB_VGA_CR_OVERFLOW_VERT_DISPLAY_ENABLE_END2_MASK 0x40
|
|
|
|
#define GRUB_VGA_CR_OVERFLOW_VERT_TOTAL1_SHIFT 8
|
|
#define GRUB_VGA_CR_OVERFLOW_VERT_TOTAL1_MASK 0x01
|
|
#define GRUB_VGA_CR_OVERFLOW_VERT_TOTAL2_SHIFT 4
|
|
#define GRUB_VGA_CR_OVERFLOW_VERT_TOTAL2_MASK 0x20
|
|
|
|
#define GRUB_VGA_CR_OVERFLOW_VSYNC_START1_SHIFT 6
|
|
#define GRUB_VGA_CR_OVERFLOW_VSYNC_START1_MASK 0x04
|
|
#define GRUB_VGA_CR_OVERFLOW_VSYNC_START2_SHIFT 2
|
|
#define GRUB_VGA_CR_OVERFLOW_VSYNC_START2_MASK 0x80
|
|
|
|
#define GRUB_VGA_CR_OVERFLOW_HEIGHT1_SHIFT 7
|
|
#define GRUB_VGA_CR_OVERFLOW_HEIGHT1_MASK 0x02
|
|
#define GRUB_VGA_CR_OVERFLOW_HEIGHT2_SHIFT 3
|
|
#define GRUB_VGA_CR_OVERFLOW_HEIGHT2_MASK 0xc0
|
|
#define GRUB_VGA_CR_OVERFLOW_LINE_COMPARE_SHIFT 4
|
|
#define GRUB_VGA_CR_OVERFLOW_LINE_COMPARE_MASK 0x10
|
|
|
|
#define GRUB_VGA_CR_CELL_HEIGHT_LINE_COMPARE_MASK 0x40
|
|
#define GRUB_VGA_CR_CELL_HEIGHT_LINE_COMPARE_SHIFT 3
|
|
#define GRUB_VGA_CR_CELL_HEIGHT_VERTICAL_BLANK_MASK 0x20
|
|
#define GRUB_VGA_CR_CELL_HEIGHT_VERTICAL_BLANK_SHIFT 4
|
|
#define GRUB_VGA_CR_CELL_HEIGHT_DOUBLE_SCAN 0x80
|
|
enum
|
|
{
|
|
GRUB_VGA_CR_CURSOR_START_DISABLE = (1 << 5)
|
|
};
|
|
|
|
#define GRUB_VGA_CR_PITCH_DIVISOR 8
|
|
|
|
enum
|
|
{
|
|
GRUB_VGA_CR_MODE_NO_CGA = 0x01,
|
|
GRUB_VGA_CR_MODE_NO_HERCULES = 0x02,
|
|
GRUB_VGA_CR_MODE_ADDRESS_WRAP = 0x20,
|
|
GRUB_VGA_CR_MODE_BYTE_MODE = 0x40,
|
|
GRUB_VGA_CR_MODE_TIMING_ENABLE = 0x80
|
|
};
|
|
|
|
enum
|
|
{
|
|
GRUB_VGA_SR_RESET = 0,
|
|
GRUB_VGA_SR_CLOCKING_MODE = 1,
|
|
GRUB_VGA_SR_MAP_MASK_REGISTER = 2,
|
|
GRUB_VGA_SR_CHAR_MAP_SELECT = 3,
|
|
GRUB_VGA_SR_MEMORY_MODE = 4,
|
|
};
|
|
|
|
enum
|
|
{
|
|
GRUB_VGA_SR_RESET_ASYNC = 1,
|
|
GRUB_VGA_SR_RESET_SYNC = 2
|
|
};
|
|
|
|
enum
|
|
{
|
|
GRUB_VGA_SR_CLOCKING_MODE_8_DOT_CLOCK = 1
|
|
};
|
|
|
|
enum
|
|
{
|
|
GRUB_VGA_SR_MEMORY_MODE_NORMAL = 0,
|
|
GRUB_VGA_SR_MEMORY_MODE_EXTERNAL_VIDEO_MEMORY = 2,
|
|
GRUB_VGA_SR_MEMORY_MODE_SEQUENTIAL_ADDRESSING = 4,
|
|
GRUB_VGA_SR_MEMORY_MODE_CHAIN4 = 8,
|
|
};
|
|
|
|
enum
|
|
{
|
|
GRUB_VGA_GR_SET_RESET_PLANE = 0,
|
|
GRUB_VGA_GR_SET_RESET_PLANE_ENABLE = 1,
|
|
GRUB_VGA_GR_COLOR_COMPARE = 2,
|
|
GRUB_VGA_GR_DATA_ROTATE = 3,
|
|
GRUB_VGA_GR_READ_MAP_REGISTER = 4,
|
|
GRUB_VGA_GR_MODE = 5,
|
|
GRUB_VGA_GR_GR6 = 6,
|
|
GRUB_VGA_GR_COLOR_COMPARE_DISABLE = 7,
|
|
GRUB_VGA_GR_BITMASK = 8,
|
|
GRUB_VGA_GR_MAX
|
|
};
|
|
|
|
#define GRUB_VGA_ALL_PLANES 0xf
|
|
#define GRUB_VGA_NO_PLANES 0x0
|
|
|
|
enum
|
|
{
|
|
GRUB_VGA_GR_DATA_ROTATE_NOP = 0
|
|
};
|
|
|
|
enum
|
|
{
|
|
GRUB_VGA_TEXT_TEXT_PLANE = 0,
|
|
GRUB_VGA_TEXT_ATTR_PLANE = 1,
|
|
GRUB_VGA_TEXT_FONT_PLANE = 2
|
|
};
|
|
|
|
enum
|
|
{
|
|
GRUB_VGA_GR_GR6_GRAPHICS_MODE = 1,
|
|
GRUB_VGA_GR_GR6_MMAP_A0 = (1 << 2),
|
|
GRUB_VGA_GR_GR6_MMAP_CGA = (3 << 2)
|
|
};
|
|
|
|
enum
|
|
{
|
|
GRUB_VGA_GR_MODE_READ_MODE1 = 0x08,
|
|
GRUB_VGA_GR_MODE_ODD_EVEN = 0x10,
|
|
GRUB_VGA_GR_MODE_ODD_EVEN_SHIFT = 0x20,
|
|
GRUB_VGA_GR_MODE_256_COLOR = 0x40
|
|
};
|
|
|
|
struct grub_video_hw_config
|
|
{
|
|
unsigned vertical_total;
|
|
unsigned vertical_blank_start;
|
|
unsigned vertical_blank_end;
|
|
unsigned vertical_sync_start;
|
|
unsigned vertical_sync_end;
|
|
unsigned line_compare;
|
|
unsigned vdisplay_end;
|
|
unsigned pitch;
|
|
unsigned horizontal_total;
|
|
unsigned horizontal_blank_start;
|
|
unsigned horizontal_blank_end;
|
|
unsigned horizontal_sync_pulse_start;
|
|
unsigned horizontal_sync_pulse_end;
|
|
unsigned horizontal_end;
|
|
};
|
|
|
|
static inline void
|
|
grub_vga_set_geometry (struct grub_video_hw_config *config,
|
|
void (*cr_write) (grub_uint8_t val, grub_uint8_t addr))
|
|
{
|
|
unsigned vertical_total = config->vertical_total - 2;
|
|
unsigned vertical_blank_start = config->vertical_blank_start - 1;
|
|
unsigned vdisplay_end = config->vdisplay_end - 1;
|
|
grub_uint8_t overflow, cell_height_reg;
|
|
|
|
/* Disable CR0-7 write protection. */
|
|
cr_write (0, GRUB_VGA_CR_VSYNC_END);
|
|
|
|
overflow = ((vertical_total >> GRUB_VGA_CR_OVERFLOW_VERT_TOTAL1_SHIFT)
|
|
& GRUB_VGA_CR_OVERFLOW_VERT_TOTAL1_MASK)
|
|
| ((vertical_total >> GRUB_VGA_CR_OVERFLOW_VERT_TOTAL2_SHIFT)
|
|
& GRUB_VGA_CR_OVERFLOW_VERT_TOTAL2_MASK)
|
|
| ((config->vertical_sync_start >> GRUB_VGA_CR_OVERFLOW_VSYNC_START2_SHIFT)
|
|
& GRUB_VGA_CR_OVERFLOW_VSYNC_START2_MASK)
|
|
| ((config->vertical_sync_start >> GRUB_VGA_CR_OVERFLOW_VSYNC_START1_SHIFT)
|
|
& GRUB_VGA_CR_OVERFLOW_VSYNC_START1_MASK)
|
|
| ((vdisplay_end >> GRUB_VGA_CR_OVERFLOW_VERT_DISPLAY_ENABLE_END1_SHIFT)
|
|
& GRUB_VGA_CR_OVERFLOW_VERT_DISPLAY_ENABLE_END1_MASK)
|
|
| ((vdisplay_end >> GRUB_VGA_CR_OVERFLOW_VERT_DISPLAY_ENABLE_END2_SHIFT)
|
|
& GRUB_VGA_CR_OVERFLOW_VERT_DISPLAY_ENABLE_END2_MASK)
|
|
| ((config->vertical_sync_start >> GRUB_VGA_CR_OVERFLOW_VSYNC_START1_SHIFT)
|
|
& GRUB_VGA_CR_OVERFLOW_VSYNC_START1_MASK)
|
|
| ((config->line_compare >> GRUB_VGA_CR_OVERFLOW_LINE_COMPARE_SHIFT)
|
|
& GRUB_VGA_CR_OVERFLOW_LINE_COMPARE_MASK);
|
|
|
|
cell_height_reg = ((vertical_blank_start
|
|
>> GRUB_VGA_CR_CELL_HEIGHT_VERTICAL_BLANK_SHIFT)
|
|
& GRUB_VGA_CR_CELL_HEIGHT_VERTICAL_BLANK_MASK)
|
|
| ((config->line_compare >> GRUB_VGA_CR_CELL_HEIGHT_LINE_COMPARE_SHIFT)
|
|
& GRUB_VGA_CR_CELL_HEIGHT_LINE_COMPARE_MASK);
|
|
|
|
cr_write (config->horizontal_total - 1, GRUB_VGA_CR_HTOTAL);
|
|
cr_write (config->horizontal_end - 1, GRUB_VGA_CR_HORIZ_END);
|
|
cr_write (config->horizontal_blank_start - 1, GRUB_VGA_CR_HBLANK_START);
|
|
cr_write (config->horizontal_blank_end, GRUB_VGA_CR_HBLANK_END);
|
|
cr_write (config->horizontal_sync_pulse_start,
|
|
GRUB_VGA_CR_HORIZ_SYNC_PULSE_START);
|
|
cr_write (config->horizontal_sync_pulse_end,
|
|
GRUB_VGA_CR_HORIZ_SYNC_PULSE_END);
|
|
cr_write (vertical_total & 0xff, GRUB_VGA_CR_VERT_TOTAL);
|
|
cr_write (overflow, GRUB_VGA_CR_OVERFLOW);
|
|
cr_write (cell_height_reg, GRUB_VGA_CR_CELL_HEIGHT);
|
|
cr_write (config->vertical_sync_start & 0xff, GRUB_VGA_CR_VSYNC_START);
|
|
cr_write (config->vertical_sync_end & 0x0f, GRUB_VGA_CR_VSYNC_END);
|
|
cr_write (vdisplay_end & 0xff, GRUB_VGA_CR_VDISPLAY_END);
|
|
cr_write (config->pitch & 0xff, GRUB_VGA_CR_PITCH);
|
|
cr_write (vertical_blank_start & 0xff, GRUB_VGA_CR_VERTICAL_BLANK_START);
|
|
cr_write (config->vertical_blank_end & 0xff, GRUB_VGA_CR_VERTICAL_BLANK_END);
|
|
cr_write (config->line_compare & 0xff, GRUB_VGA_CR_LINE_COMPARE);
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif
|