--- xmil/vram/palettes.c 2004/08/17 14:46:37 1.14 +++ xmil/vram/palettes.c 2005/02/04 06:42:12 1.18 @@ -35,9 +35,21 @@ static const UINT16 pal4096banktbl[2][64 0x101, 0x103, 0x121, 0x123, 0x301, 0x303, 0x321, 0x323, 0x110, 0x112, 0x130, 0x132, 0x310, 0x312, 0x330, 0x332, 0x111, 0x113, 0x131, 0x133, 0x311, 0x313, 0x331, 0x333}}; + +static void pal4096to64(RGB32 *pal, const UINT16 *map) { + + UINT r; + + r = 64; + do { + pal->d = xmil_pal32[XMILPAL_4096G + (*map++)].d; + pal++; + } while(--r); +} #endif +// ---- void pal_makegrad(RGB32 *pal, int pals, UINT32 bg, UINT32 fg) { @@ -97,7 +109,7 @@ static void pal_settext(REG8 num) { pals.text[num+8].p.b = (UINT8)((pals.skipline * rgb.p.b) >> 8); pals.text[num+8].p.g = (UINT8)((pals.skipline * rgb.p.g) >> 8); pals.text[num+8].p.r = (UINT8)((pals.skipline * rgb.p.r) >> 8); - makescrn.palandply = 1; + crtc.e.palandply = 1; } #else void pal_settext(REG8 num) { @@ -136,7 +148,7 @@ void pal_settext(REG8 num) { pals.text[num+8].p.b = (UINT8)((pals.skipline * rgb.p.b) >> 8); pals.text[num+8].p.g = (UINT8)((pals.skipline * rgb.p.g) >> 8); pals.text[num+8].p.r = (UINT8)((pals.skipline * rgb.p.r) >> 8); - makescrn.palandply = 1; + crtc.e.palandply = 1; } void pal_setgrph(REG8 bank, REG8 num) { @@ -173,7 +185,7 @@ void pal_setgrph(REG8 bank, REG8 num) { pals.grph[bank][num+8].p.g = (UINT8)((pals.skipline * rgb.p.g) >> 8); pals.grph[bank][num+8].p.r = (UINT8)((pals.skipline * rgb.p.r) >> 8); } - makescrn.palandply = 1; + crtc.e.palandply = 1; } void pal_setgrph4096(UINT num) { @@ -208,27 +220,13 @@ void pal_setgrph4096(UINT num) { xmil_pal16[XMILPAL_4096G + num] = scrnmng_makepal16(rgb); } #endif - makescrn.palandply = 1; + crtc.e.palandply = 1; } #endif // ---- -#if defined(SUPPORT_TURBOZ) -static void pal4096to64(RGB32 *pal, const UINT16 *map) { - - UINT r; - - r = 64; - do { - pal->d = xmil_pal32[XMILPAL_4096G + (*map++)].d; - pal++; - } while(--r); -} -#endif - - void pal_update1(const UINT8 *rgbp) { UINT i; @@ -290,6 +288,13 @@ void pal_update1(const UINT8 *rgbp) { } } } +#if defined(SUPPORT_16BPP) + if (scrnmng_getbpp() == 16) { + for (i=0; i