diff options
author | Stefan Reinauer <stefan.reinauer@coreboot.org> | 2015-11-09 13:38:50 -0800 |
---|---|---|
committer | Stefan Reinauer <stefan.reinauer@coreboot.org> | 2015-11-10 20:23:36 +0100 |
commit | a2d131511ffc6dcac1df391690acc66fc7c40954 (patch) | |
tree | 4b402f0db8bb0a800d6a3949f62cba3a64d448fd /src | |
parent | bb3934c3c287715ee758ded30414a8ab301aef29 (diff) | |
download | coreboot-a2d131511ffc6dcac1df391690acc66fc7c40954.tar.xz |
[REMOVAL] drivers/trident/blade3d
As announced in http://permalink.gmane.org/gmane.linux.bios/81918
I am removing all boards older than 10 years from the tree.
Change-Id: I180fd548e8f45fc94e5086159c0e3e9465c74598
Signed-off-by: Stefan Reinauer <stefan.reinauer@coreboot.org>
Reviewed-on: http://review.coreboot.org/12386
Reviewed-by: Ronald G. Minnich <rminnich@gmail.com>
Tested-by: build bot (Jenkins)
Diffstat (limited to 'src')
-rw-r--r-- | src/drivers/trident/Kconfig | 1 | ||||
-rw-r--r-- | src/drivers/trident/Makefile.inc | 1 | ||||
-rw-r--r-- | src/drivers/trident/blade3d/Kconfig | 2 | ||||
-rw-r--r-- | src/drivers/trident/blade3d/Makefile.inc | 1 | ||||
-rw-r--r-- | src/drivers/trident/blade3d/blade3d.c | 1027 |
5 files changed, 0 insertions, 1032 deletions
diff --git a/src/drivers/trident/Kconfig b/src/drivers/trident/Kconfig deleted file mode 100644 index 1dcd5f3382..0000000000 --- a/src/drivers/trident/Kconfig +++ /dev/null @@ -1 +0,0 @@ -source src/drivers/trident/blade3d/Kconfig diff --git a/src/drivers/trident/Makefile.inc b/src/drivers/trident/Makefile.inc deleted file mode 100644 index 730f8aba77..0000000000 --- a/src/drivers/trident/Makefile.inc +++ /dev/null @@ -1 +0,0 @@ -subdirs-y += blade3d diff --git a/src/drivers/trident/blade3d/Kconfig b/src/drivers/trident/blade3d/Kconfig deleted file mode 100644 index c5e2de0c2f..0000000000 --- a/src/drivers/trident/blade3d/Kconfig +++ /dev/null @@ -1,2 +0,0 @@ -config DRIVERS_TRIDENT_BLADE3D - bool diff --git a/src/drivers/trident/blade3d/Makefile.inc b/src/drivers/trident/blade3d/Makefile.inc deleted file mode 100644 index c4a8c8c7ba..0000000000 --- a/src/drivers/trident/blade3d/Makefile.inc +++ /dev/null @@ -1 +0,0 @@ -ramstage-$(CONFIG_DRIVERS_TRIDENT_BLADE3D) += blade3d.c diff --git a/src/drivers/trident/blade3d/blade3d.c b/src/drivers/trident/blade3d/blade3d.c deleted file mode 100644 index dfc77b9bfa..0000000000 --- a/src/drivers/trident/blade3d/blade3d.c +++ /dev/null @@ -1,1027 +0,0 @@ -/* - * firmware initialization code for Trident Blade3d graphics adapter - * written by Fuger Shen 2003-10-10 - * (C) 2003 XGI Technology Inc. - * This code is released under GPL with permission from XGI - */ -#include <delay.h> -#include <stdlib.h> -#include <string.h> -#include <arch/io.h> - -#include <console/console.h> -#include <device/device.h> -#include <device/pci.h> -#include <device/pci_ids.h> -#include <device/pci_ops.h> - - -//----------------------------------------------------------------------------// -// init chip 9880 -// Fuger Shen 2003-10-10 -//----------------------------------------------------------------------------// - -#define inp inb -#define outp(port,val) outb(val, port) - -#define WORD unsigned int -#define BYTE unsigned char -#define DWORD unsigned long - -#define SGRAMTimg 0x27 -#define CHIPREV 0x3 //1,RA 2,RB,3,RC - -#define Port_SRX 0x3c4 -#define Port_CRX 0x3d4 -#define Port_GRX 0x3ce -#define Port_BRX 0x3c0 - -static BYTE Mem_Clk_Table[][2] = { - //For EDO, 3x5.2a.3:2=01 3x4.28.2:0 - { 0x50, 0x46 }, //000, F_78 - { 0xCF, 0x51 }, //001, F_81 = 81.011Mhz - { 0x30, 0x83 }, //010, F_40 = 40.006Mhz - { 0x1B, 0x43 }, //011, F_50 = 49.999MHz - { 0x22, 0x43 }, //100, F_60 = 59.999MHz - { 0x42, 0x46 }, //101, F_66 = 65.988MHz - { 0x33, 0x44 }, //110, F_70 = 69.999Mhz - { 0x22, 0x42 }, //111, F_75 = 74,999Mhz - //for SGRAM, 3x5.2a.3:2=1x - { 0x3A, 0x05 }, //000, F_135 - { 0x38, 0x05 }, //001, F_130 - { 0x44, 0x44 }, //010, F_90 = 89.999MHz - { 0x22, 0x04 }, //011, F_100=100.227MHz - { 0x0E, 0x01 }, //100, F_105 - { 0x3D, 0x07 }, //101, F_110=109.989Mhz - { 0x22, 0x03 }, //110, F_120=119.999MHz - { 0x36, 0x05 }, //111, F_125 -}; - - -typedef struct Reg_struct { - WORD rPort; - BYTE rIndex; - BYTE rValue; - BYTE rMask; -} Def_Reg_struct; - -typedef Def_Reg_struct* lpDef_Reg_struct; -// , *pDef_Reg_struct, far * lpDef_Reg_struct; - -static Def_Reg_struct Mode3_temp[] = { //mode3 temp - //port index value mask - {Port_CRX, 0x00, 0x5F, 0x00}, - {Port_CRX, 0x01, 0x4F, 0x00}, - {Port_CRX, 0x02, 0x50, 0x00}, - {Port_CRX, 0x03, 0x82, 0x00}, - {Port_CRX, 0x04, 0x55, 0x00}, - {Port_CRX, 0x05, 0x81, 0x00}, - {Port_CRX, 0x06, 0xBF, 0x00}, - {Port_CRX, 0x07, 0x1F, 0x00}, - {Port_CRX, 0x08, 0x00, 0x00}, - {Port_CRX, 0x09, 0xC7, 0x00}, - {Port_CRX, 0x0a, 0x06, 0x00}, - {Port_CRX, 0x0b, 0x07, 0x00}, - {Port_CRX, 0x0c, 0x00, 0x00}, - {Port_CRX, 0x0d, 0x00, 0x00}, - {Port_CRX, 0x0e, 0x00, 0x00}, - {Port_CRX, 0x0f, 0x00, 0x00}, - {Port_CRX, 0x10, 0x9C, 0x00}, - {Port_CRX, 0x11, 0x8E, 0x00}, - {Port_CRX, 0x12, 0x8F, 0x00}, - {Port_CRX, 0x13, 0x28, 0x00}, - {Port_CRX, 0x14, 0x1F, 0x00}, - {Port_CRX, 0x15, 0x96, 0x00}, - {Port_CRX, 0x16, 0xB9, 0x00}, - {Port_CRX, 0x17, 0xA3, 0x00}, - {Port_CRX, 0x18, 0xFF, 0x00}, -}; - -WORD Length_Mode3_temp = sizeof(Mode3_temp) / sizeof(Def_Reg_struct); - -Def_Reg_struct Mode3_reg[] = { //mode3 - //port index value mask - {Port_CRX, 0x00, 0x5F, 0x00}, //3d5 - {Port_CRX, 0x01, 0x4F, 0x00}, - {Port_CRX, 0x02, 0x50, 0x00}, - {Port_CRX, 0x03, 0x82, 0x00}, - {Port_CRX, 0x04, 0x55, 0x00}, - {Port_CRX, 0x05, 0x81, 0x00}, - {Port_CRX, 0x06, 0xBF, 0x00}, - {Port_CRX, 0x07, 0x1F, 0x00}, - {Port_CRX, 0x08, 0x00, 0x00}, - {Port_CRX, 0x09, 0x4F, 0x00}, - {Port_CRX, 0x0a, 0x0D, 0x00}, - {Port_CRX, 0x0b, 0x0E, 0x00}, - {Port_CRX, 0x0c, 0x00, 0x00}, - {Port_CRX, 0x0d, 0x00, 0x00}, - {Port_CRX, 0x0e, 0x00, 0x00}, - {Port_CRX, 0x0f, 0x00, 0x00}, - {Port_CRX, 0x10, 0x9C, 0x00}, - {Port_CRX, 0x11, 0x8E, 0x00}, - {Port_CRX, 0x12, 0x8F, 0x00}, - {Port_CRX, 0x13, 0x28, 0x00}, - {Port_CRX, 0x14, 0x1F, 0x00}, - {Port_CRX, 0x15, 0x96, 0x00}, - {Port_CRX, 0x16, 0xB9, 0x00}, - {Port_CRX, 0x17, 0xA3, 0x00}, - {Port_CRX, 0x18, 0xFF, 0x00}, - - //brx - {Port_BRX, 0x00, 0x00, 0x00}, - {Port_BRX, 0x01, 0x01, 0x00}, - {Port_BRX, 0x02, 0x02, 0x00}, - {Port_BRX, 0x03, 0x03, 0x00}, - {Port_BRX, 0x04, 0x04, 0x00}, - {Port_BRX, 0x05, 0x05, 0x00}, - {Port_BRX, 0x06, 0x14, 0x00}, - {Port_BRX, 0x07, 0x07, 0x00}, - {Port_BRX, 0x08, 0x38, 0x00}, - {Port_BRX, 0x09, 0x39, 0x00}, - {Port_BRX, 0x0a, 0x3A, 0x00}, - {Port_BRX, 0x0b, 0x3B, 0x00}, - {Port_BRX, 0x0c, 0x3C, 0x00}, - {Port_BRX, 0x0d, 0x3D, 0x00}, - {Port_BRX, 0x0e, 0x3E, 0x00}, - {Port_BRX, 0x0f, 0x3F, 0x00}, - {Port_BRX, 0x10, 0x0C, 0x00}, - {Port_BRX, 0x11, 0x00, 0x00}, - {Port_BRX, 0x12, 0x0F, 0x00}, - {Port_BRX, 0x13, 0x08, 0x00}, - {Port_BRX, 0x14, 0x00, 0x00}, - - {Port_SRX, 0x00, 0x03, 0x00}, - {Port_SRX, 0x01, 0x00, 0x00}, - {Port_SRX, 0x02, 0x03, 0x00}, - {Port_SRX, 0x03, 0x00, 0x00}, - {Port_SRX, 0x04, 0x02, 0x00}, - {Port_SRX, 0x18, 0xa6, 0x00}, //VCLK - {Port_SRX, 0x19, 0xc9, 0x00}, - {Port_SRX, 0x0D, 0x20, 0x00}, - {Port_SRX, 0x12, 0x11, 0x00}, - - {Port_CRX, 0x19, 0x4a, 0x00}, - //{Port_CRX, 0x20, 0x20, 0x00}, - //{Port_CRX, 0x23, 0x00, 0x00}, - //{Port_CRX, 0x1E, 0x89, 0x00}, - {Port_CRX, 0x21, 0xce, 0x00}, - //{Port_CRX, 0x25, 0x07, 0x00}, - //{Port_CRX, 0x27, 0x08, 0x00}, - //{Port_CRX, 0x2B, 0x00, 0x00}, - //{Port_CRX, 0x29, 0x04, 0x00}, - //{Port_CRX, 0x2F, 0x22, 0x00}, - {Port_CRX, 0x37, 0x81, 0x00}, - //{Port_CRX, 0x38, 0x00, 0x00}, - //{Port_CRX, 0x3b, 0x01, 0x00}, - {Port_CRX, 0x56, 0x00, 0x00}, - {Port_CRX, 0x57, 0x54, 0x00}, - - {Port_GRX, 0x05, 0x10, 0x00}, - {Port_GRX, 0x06, 0x0e, 0x00}, // - {Port_GRX, 0x0F, 0x20, 0x00}, - //{Port_GRX, 0x31, 0x06, 0x00}, - //{Port_GRX, 0x33, 0x30, 0x00}, - //{Port_GRX, 0x52, 0x10, 0x00}, -}; - -static WORD Length_Mode3_reg = sizeof(Mode3_reg) / sizeof(Def_Reg_struct); - -static Def_Reg_struct Init_reg[] = { - //port index value mask - {Port_GRX, 0x25, 0x00, 0x00}, - {Port_GRX, 0x21, 0x00, 0x00}, - {Port_GRX, 0x22, 0x00, 0x00}, - {Port_GRX, 0x26, 0x08, 0x00}, - {Port_GRX, 0x27, 0x00, 0x00}, - {Port_GRX, 0x28, 0xFF, 0x00}, - {Port_GRX, 0x29, 0x00, 0x00}, - {Port_GRX, 0x2A, 0x00, 0x00}, - {Port_GRX, 0x2C, 0x06, 0x00}, - {Port_GRX, 0x2E, 0x00, 0x00}, - {Port_GRX, 0x2F, 0x00, 0x00}, - {Port_GRX, 0x20, 0x80, 0x00}, - - {Port_SRX, 0x24, 0x0F, 0x00}, - {Port_SRX, 0x37, 0x30, 0x00}, - {Port_SRX, 0x38, 0x04, 0x00}, - - {Port_GRX, 0x23, 0x00, 0x00}, - {Port_GRX, 0x33, 0x20, 0x00}, - {Port_GRX, 0x30, 0x00, 0x00}, - // - {Port_GRX, 0x28, 0x18, 0x00}, - - {Port_CRX, 0x0F, 0x20, 0x40}, - {Port_CRX, 0x1F, 0x00, 0x00}, - {Port_CRX, 0x20, 0x30, 0x00}, - {Port_CRX, 0x23, 0x10, 0x00}, - {Port_CRX, 0x25, 0x86, 0x00}, - {Port_CRX, 0x2F, 0x1F, 0x00}, - {Port_CRX, 0x30, 0x0F, 0x00}, - {Port_CRX, 0x33, 0x00, 0x00}, - {Port_CRX, 0x38, 0x10, 0x00}, - {Port_CRX, 0x39, 0x00, 0x00}, - {Port_CRX, 0x5E, 0x00, 0x00}, - {Port_CRX, 0x29, 0x04, 0x00}, - - {Port_GRX, 0x5C, 0x00, 0x80}, - {Port_GRX, 0x62, 0x00, 0x08}, - - {Port_SRX, 0x20, 0x04, 0x00}, - {Port_GRX, 0x2F, 0x23, 0x00}, - {Port_SRX, 0x0B, 0x00, 0x00}, - {Port_SRX, 0x0D, 0x28, 0x00}, -}; - -static WORD Length_Init_reg = sizeof(Init_reg) / sizeof(Def_Reg_struct); - -static BYTE C8x16_Char[][8] = { - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //;0 - { 0x00, 0x00, 0x7E, 0x81, 0xA5, 0x81, 0x81, 0xBD }, - { 0x99, 0x81, 0x81, 0x7E, 0x00, 0x00, 0x00, 0x00 }, //;1 - { 0x00, 0x00, 0x7E, 0xFF, 0xDB, 0xFF, 0xFF, 0xC3 }, - { 0xE7, 0xFF, 0xFF, 0x7E, 0x00, 0x00, 0x00, 0x00 }, //;2 - { 0x00, 0x00, 0x00, 0x00, 0x6C, 0xFE, 0xFE, 0xFE }, - { 0xFE, 0x7C, 0x38, 0x10, 0x00, 0x00, 0x00, 0x00 }, //;3 - { 0x00, 0x00, 0x00, 0x00, 0x10, 0x38, 0x7C, 0xFE }, - { 0x7C, 0x38, 0x10, 0x00, 0x00, 0x00, 0x00, 0x00 }, //;4 - { 0x00, 0x00, 0x00, 0x18, 0x3C, 0x3C, 0xE7, 0xE7 }, - { 0xE7, 0x99, 0x18, 0x3C, 0x00, 0x00, 0x00, 0x00 }, //;5 - { 0x00, 0x00, 0x00, 0x18, 0x3C, 0x7E, 0xFF, 0xFF }, - { 0x7E, 0x18, 0x18, 0x3C, 0x00, 0x00, 0x00, 0x00 }, //;6 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x18, 0x3C }, - { 0x3C, 0x18, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //;7 - { 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xE7, 0xC3 }, - { 0xC3, 0xE7, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF }, //;8 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x3C, 0x66, 0x42 }, - { 0x42, 0x66, 0x3C, 0x00, 0x00, 0x00, 0x00, 0x00 }, //;9 - { 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xC3, 0x99, 0xBD }, - { 0xBD, 0x99, 0xC3, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF }, ////10 - { 0x00, 0x00, 0x1E, 0x0E, 0x1A, 0x32, 0x78, 0xCC }, - { 0xCC, 0xCC, 0xCC, 0x78, 0x00, 0x00, 0x00, 0x00 }, //11 - { 0x00, 0x00, 0x3C, 0x66, 0x66, 0x66, 0x66, 0x3C }, - { 0x18, 0x7E, 0x18, 0x18, 0x00, 0x00, 0x00, 0x00 }, //12 - { 0x00, 0x00, 0x3F, 0x33, 0x3F, 0x30, 0x30, 0x30 }, - { 0x30, 0x70, 0xF0, 0xE0, 0x00, 0x00, 0x00, 0x00 }, //13 - { 0x00, 0x00, 0x7F, 0x63, 0x7F, 0x63, 0x63, 0x63 }, - { 0x63, 0x67, 0xE7, 0xE6, 0xC0, 0x00, 0x00, 0x00 }, //14 - { 0x00, 0x00, 0x00, 0x18, 0x18, 0xDB, 0x3C, 0xE7 }, - { 0x3C, 0xDB, 0x18, 0x18, 0x00, 0x00, 0x00, 0x00 }, //15 - { 0x00, 0x80, 0xC0, 0xE0, 0xF0, 0xF8, 0xFE, 0xF8 }, - { 0xF0, 0xE0, 0xC0, 0x80, 0x00, 0x00, 0x00, 0x00 }, //16 - { 0x00, 0x02, 0x06, 0x0E, 0x1E, 0x3E, 0xFE, 0x3E }, - { 0x1E, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00 }, //17 - { 0x00, 0x00, 0x18, 0x3C, 0x7E, 0x18, 0x18, 0x18 }, - { 0x18, 0x7E, 0x3C, 0x18, 0x00, 0x00, 0x00, 0x00 }, //18 - { 0x00, 0x00, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66 }, - { 0x66, 0x00, 0x66, 0x66, 0x00, 0x00, 0x00, 0x00 }, //19 - { 0x00, 0x00, 0x7F, 0xDB, 0xDB, 0xDB, 0x7B, 0x1B }, - { 0x1B, 0x1B, 0x1B, 0x1B, 0x00, 0x00, 0x00, 0x00 }, //20 - { 0x00, 0x7C, 0xC6, 0x60, 0x38, 0x6C, 0xC6, 0xC6 }, - { 0x6C, 0x38, 0x0C, 0xC6, 0x7C, 0x00, 0x00, 0x00 }, //21 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, - { 0xFE, 0xFE, 0xFE, 0xFE, 0x00, 0x00, 0x00, 0x00 }, //22 - { 0x00, 0x00, 0x18, 0x3C, 0x7E, 0x18, 0x18, 0x18 }, - { 0x18, 0x7E, 0x3C, 0x18, 0x7E, 0x00, 0x00, 0x00 }, //23 - { 0x00, 0x00, 0x18, 0x3C, 0x7E, 0x18, 0x18, 0x18 }, - { 0x18, 0x18, 0x18, 0x18, 0x00, 0x00, 0x00, 0x00 }, //24 - { 0x00, 0x00, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18 }, - { 0x18, 0x7E, 0x3C, 0x18, 0x00, 0x00, 0x00, 0x00 }, //25 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x18, 0x0C, 0xFE }, - { 0x0C, 0x18, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //26 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, 0x60, 0xFE }, - { 0x60, 0x30, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //27 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0xC0, 0xC0, 0xC0 }, - { 0xC0, 0xFE, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //28 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x28, 0x6C, 0xFE }, - { 0x6C, 0x28, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //29 - { 0x00, 0x00, 0x00, 0x00, 0x10, 0x38, 0x38, 0x7C }, - { 0x7C, 0xFE, 0xFE, 0x00, 0x00, 0x00, 0x00, 0x00 }, //30 - { 0x00, 0x00, 0x00, 0x00, 0xFE, 0xFE, 0x7C, 0x7C }, - { 0x38, 0x38, 0x10, 0x00, 0x00, 0x00, 0x00, 0x00 }, //31 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //32 - { 0x00, 0x00, 0x18, 0x3C, 0x3C, 0x3C, 0x18, 0x18 }, - { 0x18, 0x00, 0x18, 0x18, 0x00, 0x00, 0x00, 0x00 }, //33 - { 0x00, 0x66, 0x66, 0x66, 0x24, 0x00, 0x00, 0x00 }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //34 - { 0x00, 0x00, 0x00, 0x6C, 0x6C, 0xFE, 0x6C, 0x6C }, - { 0x6C, 0xFE, 0x6C, 0x6C, 0x00, 0x00, 0x00, 0x00 }, //35 - { 0x18, 0x18, 0x7C, 0xC6, 0xC2, 0xC0, 0x7C, 0x06 }, - { 0x86, 0xC6, 0x7C, 0x18, 0x18, 0x00, 0x00, 0x00 }, //36 - { 0x00, 0x00, 0x00, 0x00, 0xC2, 0xC6, 0x0C, 0x18 }, - { 0x30, 0x60, 0xC6, 0x86, 0x00, 0x00, 0x00, 0x00 }, //37 - { 0x00, 0x00, 0x38, 0x6C, 0x6C, 0x38, 0x76, 0xDC }, - { 0xCC, 0xCC, 0xCC, 0x76, 0x00, 0x00, 0x00, 0x00 }, //38 - { 0x00, 0x30, 0x30, 0x30, 0x60, 0x00, 0x00, 0x00 }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //39 - { 0x00, 0x00, 0x0C, 0x18, 0x30, 0x30, 0x30, 0x30 }, - { 0x30, 0x30, 0x18, 0x0C, 0x00, 0x00, 0x00, 0x00 }, //40 - { 0x00, 0x00, 0x30, 0x18, 0x0C, 0x0C, 0x0C, 0x0C }, - { 0x0C, 0x0C, 0x18, 0x30, 0x00, 0x00, 0x00, 0x00 }, //41 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x66, 0x3C, 0xFF }, - { 0x3C, 0x66, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //42 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x18, 0x18, 0x7E }, - { 0x18, 0x18, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //43 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, - { 0x00, 0x18, 0x18, 0x18, 0x30, 0x00, 0x00, 0x00 }, //44 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFE }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //45 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, - { 0x00, 0x00, 0x18, 0x18, 0x00, 0x00, 0x00, 0x00 }, //46 - { 0x00, 0x00, 0x00, 0x00, 0x02, 0x06, 0x0C, 0x18 }, - { 0x30, 0x60, 0xC0, 0x80, 0x00, 0x00, 0x00, 0x00 }, //47 - { 0x00, 0x00, 0x7C, 0xC6, 0xC6, 0xC6, 0xD6, 0xD6 }, - { 0xC6, 0xC6, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //48 - { 0x00, 0x00, 0x18, 0x38, 0x78, 0x18, 0x18, 0x18 }, - { 0x18, 0x18, 0x18, 0x7E, 0x00, 0x00, 0x00, 0x00 }, //49 - { 0x00, 0x00, 0x7C, 0xC6, 0x06, 0x0C, 0x18, 0x30 }, - { 0x60, 0xC0, 0xC6, 0xFE, 0x00, 0x00, 0x00, 0x00 }, //50 - { 0x00, 0x00, 0x7C, 0xC6, 0x06, 0x06, 0x3C, 0x06 }, - { 0x06, 0x06, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //51 - { 0x00, 0x00, 0x0C, 0x1C, 0x3C, 0x6C, 0xCC, 0xFE }, - { 0x0C, 0x0C, 0x0C, 0x1E, 0x00, 0x00, 0x00, 0x00 }, //52 - { 0x00, 0x00, 0xFE, 0xC0, 0xC0, 0xC0, 0xFC, 0x0E }, - { 0x06, 0x06, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //53 - { 0x00, 0x00, 0x38, 0x60, 0xC0, 0xC0, 0xFC, 0xC6 }, - { 0xC6, 0xC6, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //54 - { 0x00, 0x00, 0xFE, 0xC6, 0x06, 0x06, 0x0C, 0x18 }, - { 0x30, 0x30, 0x30, 0x30, 0x00, 0x00, 0x00, 0x00 }, //55 - { 0x00, 0x00, 0x7C, 0xC6, 0xC6, 0xC6, 0x7C, 0xC6 }, - { 0xC6, 0xC6, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //56 - { 0x00, 0x00, 0x7C, 0xC6, 0xC6, 0xC6, 0x7E, 0x06 }, - { 0x06, 0x06, 0x0C, 0x78, 0x00, 0x00, 0x00, 0x00 }, //57 - { 0x00, 0x00, 0x00, 0x00, 0x18, 0x18, 0x00, 0x00 }, - { 0x00, 0x18, 0x18, 0x00, 0x00, 0x00, 0x00, 0x00 }, //58 - { 0x00, 0x00, 0x00, 0x00, 0x18, 0x18, 0x00, 0x00 }, - { 0x00, 0x18, 0x18, 0x30, 0x00, 0x00, 0x00, 0x00 }, //59 - { 0x00, 0x00, 0x00, 0x06, 0x0C, 0x18, 0x30, 0x60 }, - { 0x30, 0x18, 0x0C, 0x06, 0x00, 0x00, 0x00, 0x00 }, //60 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFE, 0x00 }, - { 0x00, 0xFE, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //61 - { 0x00, 0x00, 0x00, 0x60, 0x30, 0x18, 0x0C, 0x06 }, - { 0x0C, 0x18, 0x30, 0x60, 0x00, 0x00, 0x00, 0x00 }, //62 - { 0x00, 0x00, 0x7C, 0xC6, 0xC6, 0x0C, 0x18, 0x18 }, - { 0x18, 0x00, 0x18, 0x18, 0x00, 0x00, 0x00, 0x00 }, //63 - { 0x00, 0x00, 0x00, 0x7C, 0xC6, 0xC6, 0xDE, 0xDE }, - { 0xDE, 0xDC, 0xC0, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //64 - { 0x00, 0x00, 0x10, 0x38, 0x6C, 0xC6, 0xC6, 0xFE }, - { 0xC6, 0xC6, 0xC6, 0xC6, 0x00, 0x00, 0x00, 0x00 }, //65 - { 0x00, 0x00, 0xFC, 0x66, 0x66, 0x66, 0x7C, 0x66 }, - { 0x66, 0x66, 0x66, 0xFC, 0x00, 0x00, 0x00, 0x00 }, //66 - { 0x00, 0x00, 0x3C, 0x66, 0xC2, 0xC0, 0xC0, 0xC0 }, - { 0xC0, 0xC2, 0x66, 0x3C, 0x00, 0x00, 0x00, 0x00 }, //67 - { 0x00, 0x00, 0xF8, 0x6C, 0x66, 0x66, 0x66, 0x66 }, - { 0x66, 0x66, 0x6C, 0xF8, 0x00, 0x00, 0x00, 0x00 }, //68 - { 0x00, 0x00, 0xFE, 0x66, 0x62, 0x68, 0x78, 0x68 }, - { 0x60, 0x62, 0x66, 0xFE, 0x00, 0x00, 0x00, 0x00 }, //69 - { 0x00, 0x00, 0xFE, 0x66, 0x62, 0x68, 0x78, 0x68 }, - { 0x60, 0x60, 0x60, 0xF0, 0x00, 0x00, 0x00, 0x00 }, //70 - { 0x00, 0x00, 0x3C, 0x66, 0xC2, 0xC0, 0xC0, 0xDE }, - { 0xC6, 0xC6, 0x66, 0x3A, 0x00, 0x00, 0x00, 0x00 }, //71 - { 0x00, 0x00, 0xC6, 0xC6, 0xC6, 0xC6, 0xFE, 0xC6 }, - { 0xC6, 0xC6, 0xC6, 0xC6, 0x00, 0x00, 0x00, 0x00 }, //72 - { 0x00, 0x00, 0x3C, 0x18, 0x18, 0x18, 0x18, 0x18 }, - { 0x18, 0x18, 0x18, 0x3C, 0x00, 0x00, 0x00, 0x00 }, //73 - { 0x00, 0x00, 0x1E, 0x0C, 0x0C, 0x0C, 0x0C, 0x0C }, - { 0xCC, 0xCC, 0xCC, 0x78, 0x00, 0x00, 0x00, 0x00 }, //74 - { 0x00, 0x00, 0xE6, 0x66, 0x6C, 0x6C, 0x78, 0x78 }, - { 0x6C, 0x66, 0x66, 0xE6, 0x00, 0x00, 0x00, 0x00 }, //75 - { 0x00, 0x00, 0xF0, 0x60, 0x60, 0x60, 0x60, 0x60 }, - { 0x60, 0x62, 0x66, 0xFE, 0x00, 0x00, 0x00, 0x00 }, //76 - { 0x00, 0x00, 0xC6, 0xEE, 0xFE, 0xFE, 0xD6, 0xC6 }, - { 0xC6, 0xC6, 0xC6, 0xC6, 0x00, 0x00, 0x00, 0x00 }, //77 - { 0x00, 0x00, 0xC6, 0xE6, 0xF6, 0xFE, 0xDE, 0xCE }, - { 0xC6, 0xC6, 0xC6, 0xC6, 0x00, 0x00, 0x00, 0x00 }, //78 - { 0x00, 0x00, 0x38, 0x6C, 0xC6, 0xC6, 0xC6, 0xC6 }, - { 0xC6, 0xC6, 0x6C, 0x38, 0x00, 0x00, 0x00, 0x00 }, //79 - { 0x00, 0x00, 0xFC, 0x66, 0x66, 0x66, 0x7C, 0x60 }, - { 0x60, 0x60, 0x60, 0xF0, 0x00, 0x00, 0x00, 0x00 }, //80 - { 0x00, 0x00, 0x7C, 0xC6, 0xC6, 0xC6, 0xC6, 0xC6 }, - { 0xC6, 0xD6, 0xDE, 0x7C, 0x0C, 0x0E, 0x00, 0x00 }, //81 - { 0x00, 0x00, 0xFC, 0x66, 0x66, 0x66, 0x7C, 0x6C }, - { 0x66, 0x66, 0x66, 0xE6, 0x00, 0x00, 0x00, 0x00 }, //82 - { 0x00, 0x00, 0x7C, 0xC6, 0xC6, 0x60, 0x38, 0x0C }, - { 0x06, 0xC6, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //83 - { 0x00, 0x00, 0x7E, 0x7E, 0x5A, 0x18, 0x18, 0x18 }, - { 0x18, 0x18, 0x18, 0x3C, 0x00, 0x00, 0x00, 0x00 }, //84 - { 0x00, 0x00, 0xC6, 0xC6, 0xC6, 0xC6, 0xC6, 0xC6 }, - { 0xC6, 0xC6, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //85 - { 0x00, 0x00, 0xC6, 0xC6, 0xC6, 0xC6, 0xC6, 0xC6 }, - { 0xC6, 0x6C, 0x38, 0x10, 0x00, 0x00, 0x00, 0x00 }, //86 - { 0x00, 0x00, 0xC6, 0xC6, 0xC6, 0xC6, 0xC6, 0xD6 }, - { 0xD6, 0xFE, 0x6C, 0x6C, 0x00, 0x00, 0x00, 0x00 }, //87 - { 0x00, 0x00, 0xC6, 0xC6, 0x6C, 0x6C, 0x38, 0x38 }, - { 0x6C, 0x6C, 0xC6, 0xC6, 0x00, 0x00, 0x00, 0x00 }, //88 - { 0x00, 0x00, 0x66, 0x66, 0x66, 0x66, 0x3C, 0x18 }, - { 0x18, 0x18, 0x18, 0x3C, 0x00, 0x00, 0x00, 0x00 }, //89 - { 0x00, 0x00, 0xFE, 0xC6, 0x86, 0x0C, 0x18, 0x30 }, - { 0x60, 0xC2, 0xC6, 0xFE, 0x00, 0x00, 0x00, 0x00 }, //90 - { 0x00, 0x00, 0x3C, 0x30, 0x30, 0x30, 0x30, 0x30 }, - { 0x30, 0x30, 0x30, 0x3C, 0x00, 0x00, 0x00, 0x00 }, //91 - { 0x00, 0x00, 0x00, 0x80, 0xC0, 0xE0, 0x70, 0x38 }, - { 0x1C, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00 }, //92 - { 0x00, 0x00, 0x3C, 0x0C, 0x0C, 0x0C, 0x0C, 0x0C }, - { 0x0C, 0x0C, 0x0C, 0x3C, 0x00, 0x00, 0x00, 0x00 }, //93 - { 0x10, 0x38, 0x6C, 0xC6, 0x00, 0x00, 0x00, 0x00 }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //94 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0xFF, 0x00, 0x00 }, //95 - { 0x30, 0x30, 0x18, 0x00, 0x00, 0x00, 0x00, 0x00 }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //96 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x78, 0x0C, 0x7C }, - { 0xCC, 0xCC, 0xCC, 0x76, 0x00, 0x00, 0x00, 0x00 }, //97 - { 0x00, 0x00, 0xE0, 0x60, 0x60, 0x78, 0x6C, 0x66 }, - { 0x66, 0x66, 0x66, 0xDC, 0x00, 0x00, 0x00, 0x00 }, //98 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x7C, 0xC6, 0xC0 }, - { 0xC0, 0xC0, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //99 - { 0x00, 0x00, 0x1C, 0x0C, 0x0C, 0x3C, 0x6C, 0xCC }, - { 0xCC, 0xCC, 0xCC, 0x76, 0x00, 0x00, 0x00, 0x00 }, //100 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x7C, 0xC6, 0xFE }, - { 0xC0, 0xC0, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //101 - { 0x00, 0x00, 0x38, 0x6C, 0x64, 0x60, 0xF0, 0x60 }, - { 0x60, 0x60, 0x60, 0xF0, 0x00, 0x00, 0x00, 0x00 }, //102 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x76, 0xCC, 0xCC }, - { 0xCC, 0xCC, 0xCC, 0x7C, 0x0C, 0xCC, 0x78, 0x00 }, //103 - { 0x00, 0x00, 0xE0, 0x60, 0x60, 0x6C, 0x76, 0x66 }, - { 0x66, 0x66, 0x66, 0xE6, 0x00, 0x00, 0x00, 0x00 }, //104 - { 0x00, 0x00, 0x18, 0x18, 0x00, 0x38, 0x18, 0x18 }, - { 0x18, 0x18, 0x18, 0x3C, 0x00, 0x00, 0x00, 0x00 }, //105 - { 0x00, 0x00, 0x06, 0x06, 0x00, 0x0E, 0x06, 0x06 }, - { 0x06, 0x06, 0x06, 0x06, 0x66, 0x66, 0x3C, 0x00 }, //106 - { 0x00, 0x00, 0xE0, 0x60, 0x60, 0x66, 0x6C, 0x78 }, - { 0x78, 0x6C, 0x66, 0xE6, 0x00, 0x00, 0x00, 0x00 }, //107 - { 0x00, 0x00, 0x38, 0x18, 0x18, 0x18, 0x18, 0x18 }, - { 0x18, 0x18, 0x18, 0x3C, 0x00, 0x00, 0x00, 0x00 }, //108 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0xEC, 0xFE, 0xD6 }, - { 0xD6, 0xD6, 0xD6, 0xD6, 0x00, 0x00, 0x00, 0x00 }, //109 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0xDC, 0x66, 0x66 }, - { 0x66, 0x66, 0x66, 0x66, 0x00, 0x00, 0x00, 0x00 }, //110 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x7C, 0xC6, 0xC6 }, - { 0xC6, 0xC6, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //111 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0xDC, 0x66, 0x66 }, - { 0x66, 0x66, 0x66, 0x7C, 0x60, 0x60, 0xF0, 0x00 }, //112 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x76, 0xCC, 0xCC }, - { 0xCC, 0xCC, 0xCC, 0x7C, 0x0C, 0x0C, 0x1E, 0x00 }, //113 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0xDC, 0x76, 0x62 }, - { 0x60, 0x60, 0x60, 0xF0, 0x00, 0x00, 0x00, 0x00 }, //114 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x7C, 0xC6, 0x60 }, - { 0x38, 0x0C, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //115 - { 0x00, 0x00, 0x10, 0x30, 0x30, 0xFC, 0x30, 0x30 }, - { 0x30, 0x30, 0x36, 0x1C, 0x00, 0x00, 0x00, 0x00 }, //116 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0xCC, 0xCC, 0xCC }, - { 0xCC, 0xCC, 0xCC, 0x76, 0x00, 0x00, 0x00, 0x00 }, //117 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x66, 0x66, 0x66 }, - { 0x66, 0x66, 0x3C, 0x18, 0x00, 0x00, 0x00, 0x00 }, //118 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0xC6, 0xC6, 0xC6 }, - { 0xD6, 0xD6, 0xFE, 0x6C, 0x00, 0x00, 0x00, 0x00 }, //119 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0xC6, 0x6C, 0x38 }, - { 0x38, 0x38, 0x6C, 0xC6, 0x00, 0x00, 0x00, 0x00 }, //120 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0xC6, 0xC6, 0xC6 }, - { 0xC6, 0xC6, 0xC6, 0x7E, 0x06, 0x0C, 0xF8, 0x00 }, //121 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0xFE, 0xCC, 0x18 }, - { 0x30, 0x60, 0xC6, 0xFE, 0x00, 0x00, 0x00, 0x00 }, //122 - { 0x00, 0x00, 0x0E, 0x18, 0x18, 0x18, 0x70, 0x18 }, - { 0x18, 0x18, 0x18, 0x0E, 0x00, 0x00, 0x00, 0x00 }, //123 - { 0x00, 0x00, 0x18, 0x18, 0x18, 0x18, 0x00, 0x18 }, - { 0x18, 0x18, 0x18, 0x18, 0x00, 0x00, 0x00, 0x00 }, //124 - { 0x00, 0x00, 0x70, 0x18, 0x18, 0x18, 0x0E, 0x18 }, - { 0x18, 0x18, 0x18, 0x70, 0x00, 0x00, 0x00, 0x00 }, //125 - { 0x00, 0x00, 0x76, 0xDC, 0x00, 0x00, 0x00, 0x00 }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //126 - { 0x00, 0x00, 0x00, 0x00, 0x10, 0x38, 0x6C, 0xC6 }, - { 0xC6, 0xC6, 0xFE, 0x00, 0x00, 0x00, 0x00, 0x00 }, //127 - { 0x00, 0x00, 0x3C, 0x66, 0xC2, 0xC0, 0xC0, 0xC0 }, - { 0xC2, 0x66, 0x3C, 0x0C, 0x06, 0x7C, 0x00, 0x00 }, //128 - { 0x00, 0x00, 0xCC, 0xCC, 0x00, 0xCC, 0xCC, 0xCC }, - { 0xCC, 0xCC, 0xCC, 0x76, 0x00, 0x00, 0x00, 0x00 }, //129 - { 0x00, 0x0C, 0x18, 0x30, 0x00, 0x7C, 0xC6, 0xFE }, - { 0xC0, 0xC0, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //130 - { 0x00, 0x10, 0x38, 0x6C, 0x00, 0x78, 0x0C, 0x7C }, - { 0xCC, 0xCC, 0xCC, 0x76, 0x00, 0x00, 0x00, 0x00 }, //131 - { 0x00, 0x00, 0xCC, 0xCC, 0x00, 0x78, 0x0C, 0x7C }, - { 0xCC, 0xCC, 0xCC, 0x76, 0x00, 0x00, 0x00, 0x00 }, //132 - { 0x00, 0x60, 0x30, 0x18, 0x00, 0x78, 0x0C, 0x7C }, - { 0xCC, 0xCC, 0xCC, 0x76, 0x00, 0x00, 0x00, 0x00 }, //133 - { 0x00, 0x38, 0x6C, 0x38, 0x00, 0x78, 0x0C, 0x7C }, - { 0xCC, 0xCC, 0xCC, 0x76, 0x00, 0x00, 0x00, 0x00 }, //134 - { 0x00, 0x00, 0x00, 0x00, 0x3C, 0x66, 0x60, 0x60 }, - { 0x66, 0x3C, 0x0C, 0x06, 0x3C, 0x00, 0x00, 0x00 }, //135 - { 0x00, 0x10, 0x38, 0x6C, 0x00, 0x7C, 0xC6, 0xFE }, - { 0xC0, 0xC0, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //136 - { 0x00, 0x00, 0xC6, 0xC6, 0x00, 0x7C, 0xC6, 0xFE }, - { 0xC0, 0xC0, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //137 - { 0x00, 0x60, 0x30, 0x18, 0x00, 0x7C, 0xC6, 0xFE }, - { 0xC0, 0xC0, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //138 - { 0x00, 0x00, 0x66, 0x66, 0x00, 0x38, 0x18, 0x18 }, - { 0x18, 0x18, 0x18, 0x3C, 0x00, 0x00, 0x00, 0x00 }, //139 - { 0x00, 0x18, 0x3C, 0x66, 0x00, 0x38, 0x18, 0x18 }, - { 0x18, 0x18, 0x18, 0x3C, 0x00, 0x00, 0x00, 0x00 }, //140 - { 0x00, 0x60, 0x30, 0x18, 0x00, 0x38, 0x18, 0x18 }, - { 0x18, 0x18, 0x18, 0x3C, 0x00, 0x00, 0x00, 0x00 }, //141 - { 0x00, 0xC6, 0xC6, 0x10, 0x38, 0x6C, 0xC6, 0xC6 }, - { 0xFE, 0xC6, 0xC6, 0xC6, 0x00, 0x00, 0x00, 0x00 }, //142 - { 0x38, 0x6C, 0x38, 0x00, 0x38, 0x6C, 0xC6, 0xC6 }, - { 0xFE, 0xC6, 0xC6, 0xC6, 0x00, 0x00, 0x00, 0x00 }, //143 - { 0x18, 0x30, 0x60, 0x00, 0xFE, 0x66, 0x60, 0x7C }, - { 0x60, 0x60, 0x66, 0xFE, 0x00, 0x00, 0x00, 0x00 }, //144 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0xCC, 0x76, 0x36 }, - { 0x7E, 0xD8, 0xD8, 0x6E, 0x00, 0x00, 0x00, 0x00 }, //145 - { 0x00, 0x00, 0x3E, 0x6C, 0xCC, 0xCC, 0xFE, 0xCC }, - { 0xCC, 0xCC, 0xCC, 0xCE, 0x00, 0x00, 0x00, 0x00 }, //146 - { 0x00, 0x10, 0x38, 0x6C, 0x00, 0x7C, 0xC6, 0xC6 }, - { 0xC6, 0xC6, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //147 - { 0x00, 0x00, 0xC6, 0xC6, 0x00, 0x7C, 0xC6, 0xC6 }, - { 0xC6, 0xC6, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //148 - { 0x00, 0x60, 0x30, 0x18, 0x00, 0x7C, 0xC6, 0xC6 }, - { 0xC6, 0xC6, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //149 - { 0x00, 0x30, 0x78, 0xCC, 0x00, 0xCC, 0xCC, 0xCC }, - { 0xCC, 0xCC, 0xCC, 0x76, 0x00, 0x00, 0x00, 0x00 }, //150 - { 0x00, 0x60, 0x30, 0x18, 0x00, 0xCC, 0xCC, 0xCC }, - { 0xCC, 0xCC, 0xCC, 0x76, 0x00, 0x00, 0x00, 0x00 }, //151 - { 0x00, 0x00, 0xC6, 0xC6, 0x00, 0xC6, 0xC6, 0xC6 }, - { 0xC6, 0xC6, 0xC6, 0x7E, 0x06, 0x0C, 0x78, 0x00 }, //152 - { 0x00, 0xC6, 0xC6, 0x00, 0x38, 0x6C, 0xC6, 0xC6 }, - { 0xC6, 0xC6, 0x6C, 0x38, 0x00, 0x00, 0x00, 0x00 }, //153 - { 0x00, 0xC6, 0xC6, 0x00, 0xC6, 0xC6, 0xC6, 0xC6 }, - { 0xC6, 0xC6, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //154 - { 0x00, 0x18, 0x18, 0x3C, 0x66, 0x60, 0x60, 0x60 }, - { 0x66, 0x3C, 0x18, 0x18, 0x00, 0x00, 0x00, 0x00 }, //155 - { 0x00, 0x38, 0x6C, 0x64, 0x60, 0xF0, 0x60, 0x60 }, - { 0x60, 0x60, 0xE6, 0xFC, 0x00, 0x00, 0x00, 0x00 }, //156 - { 0x00, 0x00, 0x66, 0x66, 0x3C, 0x18, 0x7E, 0x18 }, - { 0x7E, 0x18, 0x18, 0x18, 0x00, 0x00, 0x00, 0x00 }, //157 - { 0x00, 0xF8, 0xCC, 0xCC, 0xF8, 0xC4, 0xCC, 0xDE }, - { 0xCC, 0xCC, 0xCC, 0xC6, 0x00, 0x00, 0x00, 0x00 }, //158 - { 0x00, 0x0E, 0x1B, 0x18, 0x18, 0x18, 0x7E, 0x18 }, - { 0x18, 0x18, 0x18, 0x18, 0xD8, 0x70, 0x00, 0x00 }, //159 - { 0x00, 0x18, 0x30, 0x60, 0x00, 0x78, 0x0C, 0x7C }, - { 0xCC, 0xCC, 0xCC, 0x76, 0x00, 0x00, 0x00, 0x00 }, //160 - { 0x00, 0x0C, 0x18, 0x30, 0x00, 0x38, 0x18, 0x18 }, - { 0x18, 0x18, 0x18, 0x3C, 0x00, 0x00, 0x00, 0x00 }, //161 - { 0x00, 0x18, 0x30, 0x60, 0x00, 0x7C, 0xC6, 0xC6 }, - { 0xC6, 0xC6, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //162 - { 0x00, 0x18, 0x30, 0x60, 0x00, 0xCC, 0xCC, 0xCC }, - { 0xCC, 0xCC, 0xCC, 0x76, 0x00, 0x00, 0x00, 0x00 }, //163 - { 0x00, 0x00, 0x76, 0xDC, 0x00, 0xDC, 0x66, 0x66 }, - { 0x66, 0x66, 0x66, 0x66, 0x00, 0x00, 0x00, 0x00 }, //164 - { 0x76, 0xDC, 0x00, 0xC6, 0xE6, 0xF6, 0xFE, 0xDE }, - { 0xCE, 0xC6, 0xC6, 0xC6, 0x00, 0x00, 0x00, 0x00 }, //165 - { 0x00, 0x3C, 0x6C, 0x6C, 0x3E, 0x00, 0x7E, 0x00 }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //166 - { 0x00, 0x38, 0x6C, 0x6C, 0x38, 0x00, 0x7C, 0x00 }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //167 - { 0x00, 0x00, 0x30, 0x30, 0x00, 0x30, 0x30, 0x60 }, - { 0xC0, 0xC6, 0xC6, 0x7C, 0x00, 0x00, 0x00, 0x00 }, //168 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFE, 0xC0 }, - { 0xC0, 0xC0, 0xC0, 0x00, 0x00, 0x00, 0x00, 0x00 }, //169 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFE, 0x06 }, - { 0x06, 0x06, 0x06, 0x00, 0x00, 0x00, 0x00, 0x00 }, //170 - { 0x00, 0xC0, 0xC0, 0xC2, 0xC6, 0xCC, 0x18, 0x30 }, - { 0x60, 0xCE, 0x93, 0x06, 0x0C, 0x1F, 0x00, 0x00 }, //171 - { 0x00, 0xC0, 0xC0, 0xC2, 0xC6, 0xCC, 0x18, 0x30 }, - { 0x66, 0xCE, 0x9A, 0x3F, 0x06, 0x0F, 0x00, 0x00 }, //172 - { 0x00, 0x00, 0x18, 0x18, 0x00, 0x18, 0x18, 0x18 }, - { 0x3C, 0x3C, 0x3C, 0x18, 0x00, 0x00, 0x00, 0x00 }, //173 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x33, 0x66, 0xCC }, - { 0x66, 0x33, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //174 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0xCC, 0x66, 0x33 }, - { 0x66, 0xCC, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //175 - { 0x11, 0x44, 0x11, 0x44, 0x11, 0x44, 0x11, 0x44 }, - { 0x11, 0x44, 0x11, 0x44, 0x11, 0x44, 0x11, 0x44 }, //176 - { 0x55, 0xAA, 0x55, 0xAA, 0x55, 0xAA, 0x55, 0xAA }, - { 0x55, 0xAA, 0x55, 0xAA, 0x55, 0xAA, 0x55, 0xAA }, //177 - { 0xDD, 0x77, 0xDD, 0x77, 0xDD, 0x77, 0xDD, 0x77 }, - { 0xDD, 0x77, 0xDD, 0x77, 0xDD, 0x77, 0xDD, 0x77 }, //178 - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18 }, - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18 }, //179 - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0xF8 }, - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18 }, //180 - { 0x18, 0x18, 0x18, 0x18, 0x18, 0xF8, 0x18, 0xF8 }, - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18 }, //181 - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0xF6 }, - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36 }, //182 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFE }, - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36 }, //183 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0xF8, 0x18, 0xF8 }, - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18 }, //184 - { 0x36, 0x36, 0x36, 0x36, 0x36, 0xF6, 0x06, 0xF6 }, - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36 }, //185 - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36 }, - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36 }, //186 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0xFE, 0x06, 0xF6 }, - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36 }, //187 - { 0x36, 0x36, 0x36, 0x36, 0x36, 0xF6, 0x06, 0xFE }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //188 - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0xFE }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //189 - { 0x18, 0x18, 0x18, 0x18, 0x18, 0xF8, 0x18, 0xF8 }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //190 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xF8 }, - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18 }, //191 - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x1F }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //192 - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0xFF }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //193 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFF }, - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18 }, //194 - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x1F }, - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18 }, //195 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFF }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //196 - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0xFF }, - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18 }, //197 - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x1F, 0x18, 0x1F }, - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18 }, //198 - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x37 }, - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36 }, //199 - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x37, 0x30, 0x3F }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //200 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x3F, 0x30, 0x37 }, - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36 }, //201 - { 0x36, 0x36, 0x36, 0x36, 0x36, 0xF7, 0x00, 0xFF }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //202 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0xFF, 0x00, 0xF7 }, - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36 }, //203 - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x37, 0x30, 0x37 }, - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36 }, //204 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0xFF, 0x00, 0xFF }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //205 - { 0x36, 0x36, 0x36, 0x36, 0x36, 0xF7, 0x00, 0xF7 }, - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36 }, //206 - { 0x18, 0x18, 0x18, 0x18, 0x18, 0xFF, 0x00, 0xFF }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //207 - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0xFF }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //208 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0xFF, 0x00, 0xFF }, - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18 }, //209 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFF }, - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36 }, //210 - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x3F }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //211 - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x1F, 0x18, 0x1F }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //212 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x1F, 0x18, 0x1F }, - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18 }, //213 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x3F }, - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36 }, //214 - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0xFF }, - { 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36, 0x36 }, //215 - { 0x18, 0x18, 0x18, 0x18, 0x18, 0xFF, 0x18, 0xFF }, - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18 }, //216 - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0xF8 }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //217 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x1F }, - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18 }, //218 - { 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF }, - { 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF }, //219 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFF }, - { 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF }, //220 - { 0xF0, 0xF0, 0xF0, 0xF0, 0xF0, 0xF0, 0xF0, 0xF0 }, - { 0xF0, 0xF0, 0xF0, 0xF0, 0xF0, 0xF0, 0xF0, 0xF0 }, //221 - { 0x0F, 0x0F, 0x0F, 0x0F, 0x0F, 0x0F, 0x0F, 0x0F }, - { 0x0F, 0x0F, 0x0F, 0x0F, 0x0F, 0x0F, 0x0F, 0x0F }, //222 - { 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x00 }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //223 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x76, 0xDC, 0xD8 }, - { 0xD8, 0xD8, 0xDC, 0x76, 0x00, 0x00, 0x00, 0x00 }, //224 - { 0x00, 0x00, 0x7C, 0xC6, 0xC6, 0xC6, 0xDC, 0xC6 }, - { 0xC3, 0xC3, 0xC3, 0xCE, 0x00, 0x00, 0x00, 0x00 }, //225 - { 0x00, 0x00, 0xFE, 0xC6, 0xC6, 0xC0, 0xC0, 0xC0 }, - { 0xC0, 0xC0, 0xC0, 0xC0, 0x00, 0x00, 0x00, 0x00 }, //226 - { 0x00, 0x00, 0x00, 0x00, 0x80, 0xFE, 0x6C, 0x6C }, - { 0x6C, 0x6C, 0x6C, 0x6C, 0x00, 0x00, 0x00, 0x00 }, //227 - { 0x00, 0x00, 0x00, 0xFE, 0xC6, 0x60, 0x30, 0x18 }, - { 0x30, 0x60, 0xC6, 0xFE, 0x00, 0x00, 0x00, 0x00 }, //228 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x7E, 0xD8, 0xD8 }, - { 0xD8, 0xD8, 0xD8, 0x70, 0x00, 0x00, 0x00, 0x00 }, //229 - { 0x00, 0x00, 0x00, 0x00, 0x66, 0x66, 0x66, 0x66 }, - { 0x66, 0x7C, 0x60, 0x60, 0xC0, 0x00, 0x00, 0x00 }, //230 - { 0x00, 0x00, 0x00, 0x00, 0x76, 0xDC, 0x18, 0x18 }, - { 0x18, 0x18, 0x18, 0x18, 0x00, 0x00, 0x00, 0x00 }, //231 - { 0x00, 0x00, 0x00, 0x7E, 0x18, 0x3C, 0x66, 0x66 }, - { 0x66, 0x3C, 0x18, 0x7E, 0x00, 0x00, 0x00, 0x00 }, //232 - { 0x00, 0x00, 0x00, 0x38, 0x6C, 0xC6, 0xC6, 0xFE }, - { 0xC6, 0xC6, 0x6C, 0x38, 0x00, 0x00, 0x00, 0x00 }, //233 - { 0x00, 0x00, 0x38, 0x6C, 0xC6, 0xC6, 0xC6, 0x6C }, - { 0x6C, 0x6C, 0x6C, 0xEE, 0x00, 0x00, 0x00, 0x00 }, //234 - { 0x00, 0x00, 0x1E, 0x30, 0x18, 0x0C, 0x3E, 0x66 }, - { 0x66, 0x66, 0x66, 0x3C, 0x00, 0x00, 0x00, 0x00 }, //235 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x7E, 0xDB, 0xDB }, - { 0xDB, 0x7E, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //236 - { 0x00, 0x00, 0x00, 0x03, 0x06, 0x7E, 0xCF, 0xDB }, - { 0xF3, 0x7E, 0x60, 0xC0, 0x00, 0x00, 0x00, 0x00 }, //237 - { 0x00, 0x00, 0x1C, 0x30, 0x60, 0x60, 0x7C, 0x60 }, - { 0x60, 0x60, 0x30, 0x1C, 0x00, 0x00, 0x00, 0x00 }, //238 - { 0x00, 0x00, 0x00, 0x7C, 0xC6, 0xC6, 0xC6, 0xC6 }, - { 0xC6, 0xC6, 0xC6, 0xC6, 0x00, 0x00, 0x00, 0x00 }, //239 - { 0x00, 0x00, 0x00, 0x00, 0xFE, 0x00, 0x00, 0xFE }, - { 0x00, 0x00, 0xFE, 0x00, 0x00, 0x00, 0x00, 0x00 }, //240 - { 0x00, 0x00, 0x00, 0x00, 0x18, 0x18, 0x7E, 0x18 }, - { 0x18, 0x00, 0x00, 0xFF, 0x00, 0x00, 0x00, 0x00 }, //241 - { 0x00, 0x00, 0x00, 0x30, 0x18, 0x0C, 0x06, 0x0C }, - { 0x18, 0x30, 0x00, 0x7E, 0x00, 0x00, 0x00, 0x00 }, //242 - { 0x00, 0x00, 0x00, 0x0C, 0x18, 0x30, 0x60, 0x30 }, - { 0x18, 0x0C, 0x00, 0x7E, 0x00, 0x00, 0x00, 0x00 }, //243 - { 0x00, 0x00, 0x0E, 0x1B, 0x1B, 0x18, 0x18, 0x18 }, - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18 }, //244 - { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18 }, - { 0xD8, 0xD8, 0xD8, 0x70, 0x00, 0x00, 0x00, 0x00 }, //245 - { 0x00, 0x00, 0x00, 0x00, 0x18, 0x18, 0x00, 0x7E }, - { 0x00, 0x18, 0x18, 0x00, 0x00, 0x00, 0x00, 0x00 }, //246 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x76, 0xDC, 0x00 }, - { 0x76, 0xDC, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //247 - { 0x00, 0x38, 0x6C, 0x6C, 0x38, 0x00, 0x00, 0x00 }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //248 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x18 }, - { 0x18, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //249 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, - { 0x18, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //250 - { 0x00, 0x0F, 0x0C, 0x0C, 0x0C, 0x0C, 0x0C, 0xEC }, - { 0x6C, 0x6C, 0x3C, 0x1C, 0x00, 0x00, 0x00, 0x00 }, //251 - { 0x00, 0xD8, 0x6C, 0x6C, 0x6C, 0x6C, 0x6C, 0x00 }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //252 - { 0x00, 0x70, 0x98, 0x30, 0x60, 0xC8, 0xF8, 0x00 }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //253 - { 0x00, 0x00, 0x00, 0x00, 0x7C, 0x7C, 0x7C, 0x7C }, - { 0x7C, 0x7C, 0x7C, 0x00, 0x00, 0x00, 0x00, 0x00 }, //254 - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, - { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, //255 -}; - -static void config_OEM_regs(void); -static void unprotect_reg(void); -static void reprotect_reg(void); -static void set_memCLK(BYTE mem_Type, BYTE mem_MD); -static void init_SGRAM(void); -static void config_video_memory(void); -static void set_video_mode(void); -static void clear_MEM(void); -static void set_font(void); - -static int init9880(void) -{ - unprotect_reg(); - - //if use SDRAM - //outp(Port_CRX, 0x2a); - //outp(Port_CRX+1, (inp(Port_CRX+1) & ~0x0c) | 0x08); - //disable other card - - //enable VGA - outp(0x3c3, 0x01); - outp(0x4e68, 0x08); - - outp(0x3c2, 0x23); - - //if chip revB - if (CHIPREV == 0x02) { - printk(BIOS_DEBUG, "blade3d: chip revision B\n"); - outp(Port_CRX, 0xc0); - outp(Port_CRX + 1, 0x00); - } - config_OEM_regs(); - init_SGRAM(); - //config_video_memory(); - set_video_mode(); - reprotect_reg(); - //screen on - outp(Port_SRX, 0x01); - outp(Port_SRX + 1, inp(Port_SRX + 1) & ~0x20); - - return 0; -} - -static void config_OEM_regs(void) -{ - BYTE CRX_2A, Old_value; - BYTE mem_Type; - BYTE mem_MD; - WORD i; - - lpDef_Reg_struct lpMode3_temp; - lpDef_Reg_struct lpInit_reg; - lpMode3_temp = &Mode3_temp[0]; - lpInit_reg = &Init_reg[0]; - - printk(BIOS_DEBUG, "blade3d: config_OEM_regs()\n"); - - outp(Port_GRX, 0x24); - outp(Port_GRX + 1, 0xe0); - //MCLK VCLK to 16 bit - outp(Port_CRX, 0xcf); - outp(Port_CRX + 1, inp(Port_CRX + 1) | 0x03); - //3c5.0e - //outp(Port_SRX, 0x3b); - //outp(Port_SRX+1, inp(Port_SRX+1) | 0x20); - // - outp(Port_CRX, 0x3b); - outp(Port_CRX + 1, inp(Port_CRX + 1) | 0x20); - // - outp(Port_CRX, 0x1a); - outp(Port_CRX + 1, inp(Port_CRX + 1) & 0x08); - // - outp(Port_CRX, 0x2a); - CRX_2A = inp(Port_CRX + 1); - outp(Port_CRX + 1, CRX_2A & ~0x20); - - mem_Type = (CRX_2A & ~0x20) & 0x08; - - outp(Port_GRX, 0x0f); - if (0x08 == mem_Type) - outp(Port_GRX + 1, inp(Port_GRX + 1) | 0x20); - else - outp(Port_GRX + 1, inp(Port_GRX + 1) & ~0x20); - - outp(Port_CRX, 0x28); - mem_MD = inp(Port_CRX + 1) & 0x07; - - set_memCLK(mem_Type, mem_MD); - delay(100); - - if (0x08 == mem_Type) { - outp(Port_CRX, 0x2e); - outp(Port_CRX + 1, 0x00); - delay(100); - outp(Port_CRX, 0x2d); - outp(Port_CRX + 1, 0x92); - } else { - outp(Port_CRX, 0x2d); - outp(Port_CRX + 1, 0x82); - } - - for (i = 0; i < Length_Mode3_temp; i++) { - outp(lpMode3_temp[i].rPort, lpMode3_temp[i].rIndex); - Old_value = inp(lpMode3_temp[i].rPort + 1); - outp(lpMode3_temp[i].rPort + 1, - lpMode3_temp[i].rValue | (Old_value & lpMode3_temp[i]. - rMask)); - } - //screen off - outp(Port_SRX, 0x01); - outp(Port_SRX + 1, inp(Port_SRX + 1) | 0x20); - - for (i = 0; i < Length_Init_reg; i++) { - outp(lpInit_reg[i].rPort, lpInit_reg[i].rIndex); - Old_value = inp(lpInit_reg[i].rPort + 1); - outp(lpInit_reg[i].rPort + 1, - lpInit_reg[i].rValue | (Old_value & lpInit_reg[i]. - rMask)); - } - delay(10); - init_SGRAM(); - - outp(Port_CRX, 0x1a); - if (0x08 == inp(Port_CRX + 1)) { - outp(Port_CRX, 0x20); - outp(Port_CRX + 1, inp(Port_CRX + 1) | 0x04); - } - -} //end config_OEM_reg - -//---------------------------------------------------------------------------// - -static void unprotect_reg(void) -{ - outp(Port_SRX, 0x11); - outp(Port_SRX + 1, 0x92); -} - -static void reprotect_reg(void) -{ - outp(Port_SRX, 0x11); - outp(Port_SRX + 1, 0x87); -} - -static void set_memCLK(BYTE mem_Type, BYTE mem_MD) -{ - BYTE Index; - - Index = ((mem_Type + mem_MD) << 0x01) & 0xf; - outp(Port_SRX, 0x16); - outp(Port_SRX + 1, Mem_Clk_Table[Index][0]); - outp(Port_SRX, 0x17); - outp(Port_SRX + 1, Mem_Clk_Table[Index][1]); - -} - -static void init_SGRAM(void) -{ - BYTE Temp, i; - - outp(Port_CRX, 0x2a); - if (inp(Port_CRX + 1) & 0x08) //SGRAM - { - outp(Port_CRX, 0x28); - if (inp(Port_CRX + 1) & 0x08) { - outp(Port_CRX, 0x1c); - outp(Port_CRX + 1, 0x7a); - } else { - outp(Port_CRX, 0x1c); - outp(Port_CRX + 1, 0x3a); - } - outp(Port_CRX, 0x1b); - outp(Port_CRX + 1, SGRAMTimg); - if (CHIPREV >= 0x03) { - outp(Port_CRX, 0x1a); - outp(Port_CRX + 1, inp(Port_CRX + 1) | 0x01); - } else { - outp(Port_CRX, 0x1a); - outp(Port_CRX + 1, 0x16); - outp(Port_CRX + 1, inp(Port_CRX + 1) | 0x16); - for (i = 0; i < 10; i++) { - outp(Port_CRX, 0x1c); - outp(Port_CRX + 1, - inp(Port_CRX + 1) | 0x40); - } - delay(100); - outp(Port_CRX, 0x1c); - Temp = (inp(Port_CRX + 1) | 0x20) & 0x3c; - outp(Port_CRX + 1, Temp); - outp(Port_CRX + 1, Temp & 0x08); - } - - } else { //SGRAM - printk(BIOS_DEBUG, "blade3d: No SGRAM found.\n"); - } -} - -static void config_video_memory(void) -{ - printk(BIOS_DEBUG, "blade3d: Error: no video memory init\n"); -} - -static void set_video_mode(void) -{ - BYTE i; - BYTE Old_value; - lpDef_Reg_struct lpMode3_reg; - lpMode3_reg = &Mode3_reg[0]; - - printk(BIOS_DEBUG, "blade3d: setting video mode\n"); - outp(0x3c2, 0x67); - for (i = 0; i < Length_Mode3_reg; i++) { - if (lpMode3_reg[i].rPort == Port_BRX) { - inp(0x3DA); - delay(3); - outp(lpMode3_reg[i].rPort, lpMode3_reg[i].rIndex); - outp(lpMode3_reg[i].rPort, lpMode3_reg[i].rValue); - } else { - outp(lpMode3_reg[i].rPort, lpMode3_reg[i].rIndex); - Old_value = inp(lpMode3_reg[i].rPort + 1); - outp(lpMode3_reg[i].rPort + 1, - lpMode3_reg[i]. - rValue | (Old_value & lpMode3_reg[i].rMask)); - } - } - //set_font(); - //clear_MEM(); -} - -static void set_font(void) -{ - - printk(BIOS_DEBUG, "blade3d: setting font (not implemented)\n"); -} - -static void clear_MEM(void) -{ - //_fmemset(MK_FP(0xb800,0),0x720,0x4000); - __asm__("push %ax\n\t" - "push %cx\n\t" - "push %di\n\t" - "push %es\n\t" - "mov %ax, 0xb800\n\t" - "mov %es, %ax\n\t" - "mov %ax, 0x720\n\t" - "mov %cx, 0x4000\n\t" - "xor %di, %di\n\t" - "rep stosw\n\t" - "pop %es\n\t" - "pop %di\n\t" - "pop %cx\n\t" - "pop %ax\n\t" - ); -} - - -static void trident_blade3d_init(struct device *dev) -{ - printk(BIOS_INFO, "blade3d: initializing video card\n"); - init9880(); -} - -static struct device_operations trident_blade3d_ops = { - .read_resources = pci_dev_read_resources, - .set_resources = pci_dev_set_resources, - .enable_resources = pci_dev_enable_resources, - .init = trident_blade3d_init, - .scan_bus = 0, -}; - -static const struct pci_driver trident_blade3d_driver __pci_driver = { - .ops = &trident_blade3d_ops, - .vendor = 0x1023, - .device = 0x9880, -}; |