File:  [RetroPC.NET] / np2 / font / fontdata.c
Revision 1.4: download - view: text, annotated - select for diffs
Sun Feb 8 06:23:22 2004 JST (21 years, 8 months ago) by yui
Branches: MAIN
CVS tags: VER_0_80, VER_0_79, VER_0_78, VER_0_77, VER_0_76, VER_0_75, VER_0_74, HEAD
support crtc 15kHz mode (T.Yui)

#include	"compiler.h"
#include	"cpucore.h"
#include	"font.h"
#include	"fontdata.h"
#include	"fontdata.res"


const char pc88ankname[]	= "PC88.FNT";
const char pc88knj1name[]	= "KANJI1.ROM";
const char pc88knj2name[]	= "KANJI2.ROM";
const char pc98fontname[]	= "FONT.BMP";
const char v98fontname[]	= "FONT.ROM";
const char fm7ankname[]		= "SUBSYS_C.ROM";
const char fm7knjname[]		= "KANJI.ROM";
const char x1ank1name[]		= "FNT0808.X1";
const char x1ank2name[]		= "FNT0816.X1";
const char x1knjname[]		= "FNT1616.X1";
const char x68kfontname[]	= "CGROM.DAT";


static void patch29(UINT jish, const BYTE *src) {

	UINT	i;
	BYTE	*p;

	p = fontrom + 0x21000 + (jish << 4);
	for (i=0x21; i<0x7f; i++) {
		CopyMemory(p, src, 16);
		p += 0x1000;
		src += 16;
	}
}

static void patch2c(void) {

	UINT	i;
	UINT	j;
const BYTE	*p;
	BYTE	*q;

	p = fontdata_2c;
	q = fontrom + 0x240c0;
	for (i=0x24; i<0x70; i++) {
		for (j=0; j<16; j++) {
			q[j + 0x800] = p[0];
			q[j + 0x000] = p[1];
			p += 2;
		}
		q += 0x1000;
	}
}


// ----

void fontdata_ank8store(const BYTE *ptr, UINT pos, UINT cnt) {

	BYTE	*dat;

	dat = fontrom + 0x82000 + (pos * 16);
	while(cnt--) {
		CopyMemory(dat, ptr, 8);
		dat += 16;
		ptr += 8;
	}
}

void fontdata_patch16a(void) {

	CopyMemory(fontrom + 0x80000, fontdata_16 + 0*32*16, 32*16);
}

void fontdata_patch16b(void) {

	CopyMemory(fontrom + 0x80800, fontdata_16 + 1*32*16, 32*16);
	CopyMemory(fontrom + 0x80e00, fontdata_16 + 2*32*16, 32*16);
}

void fontdata_patchjis(void) {

	patch29(0x09, fontdata_29);
	patch29(0x0a, fontdata_2a);
	patch29(0x0b, fontdata_2b);
	patch2c();
}


RetroPC.NET-CVS <cvs@retropc.net>