add Tandy 4-colour hires mode (0x0a);
fix bios putpixel for modes 0x08, 0x0a (also used by bios write) Imported-from: https://svn.code.sf.net/p/dosbox/code-0/dosbox/trunk@2401
This commit is contained in:
parent
de579c6a89
commit
6ede5e436f
5 changed files with 60 additions and 13 deletions
|
@ -26,6 +26,7 @@ VGA_Type vga;
|
|||
|
||||
Bit32u CGA_2_Table[16];
|
||||
Bit32u CGA_4_Table[256];
|
||||
Bit32u CGA_4_HiRes_Table[256];
|
||||
Bit32u CGA_16_Table[256];
|
||||
Bit32u TXT_Font_Table[16];
|
||||
Bit32u TXT_FG_Table[16];
|
||||
|
@ -132,9 +133,18 @@ void VGA_SetCGA4Table(Bit8u val0,Bit8u val1,Bit8u val2,Bit8u val3) {
|
|||
#else
|
||||
(total[(i >> 6) & 3] << 0 ) | (total[(i >> 4) & 3] << 8 ) |
|
||||
(total[(i >> 2) & 3] << 16 ) | (total[(i >> 0) & 3] << 24 );
|
||||
#endif
|
||||
CGA_4_HiRes_Table[i]=
|
||||
#ifdef WORDS_BIGENDIAN
|
||||
(total[((i >> 0) & 1) | ((i >> 3) & 2)] << 0 ) | (total[((i >> 1) & 1) | ((i >> 4) & 2)] << 8 ) |
|
||||
(total[((i >> 2) & 1) | ((i >> 5) & 2)] << 16 ) | (total[((i >> 3) & 1) | ((i >> 6) & 2)] << 24 );
|
||||
#else
|
||||
(total[((i >> 3) & 1) | ((i >> 6) & 2)] << 0 ) | (total[((i >> 2) & 1) | ((i >> 5) & 2)] << 8 ) |
|
||||
(total[((i >> 1) & 1) | ((i >> 4) & 2)] << 16 ) | (total[((i >> 0) & 1) | ((i >> 3) & 2)] << 24 );
|
||||
#endif
|
||||
}
|
||||
}
|
||||
|
||||
void VGA_Init(Section* sec) {
|
||||
vga.draw.resizing=false;
|
||||
vga.mode=M_ERROR; //For first init
|
||||
|
|
|
@ -58,6 +58,20 @@ static Bit8u * VGA_Draw_2BPP_Line(Bitu vidstart,Bitu panning,Bitu line) {
|
|||
return TempLine;
|
||||
}
|
||||
|
||||
static Bit8u * VGA_Draw_2BPPHiRes_Line(Bitu vidstart,Bitu panning,Bitu line) {
|
||||
line*=8*1024;Bit32u * draw=(Bit32u *)TempLine;
|
||||
for (Bitu x=0;x<(vga.draw.blocks>>1);x++) {
|
||||
Bitu val1=vga.mem.linear[vidstart+line];
|
||||
Bitu val2=vga.mem.linear[vidstart+1+line];
|
||||
vidstart+=2;
|
||||
if((vga.crtc.mode_control & 0x01) == 0) // CGA compatible addressing
|
||||
vidstart &= 0x1dfff;
|
||||
*draw++=CGA_4_HiRes_Table[(val1>>4)|(val2&0xf0)];
|
||||
*draw++=CGA_4_HiRes_Table[(val1&0x0f)|((val2&0x0f)<<4)];
|
||||
}
|
||||
return TempLine;
|
||||
}
|
||||
|
||||
static Bitu temp[643]={0};
|
||||
|
||||
static Bit8u * VGA_Draw_CGA16_Line(Bitu vidstart,Bitu panning,Bitu line) {
|
||||
|
@ -513,9 +527,12 @@ void VGA_SetupDrawing(Bitu val) {
|
|||
doubleheight=true;
|
||||
if (machine==MCH_TANDY) doublewidth=(vga.tandy.mode_control & 0x10)==0;
|
||||
else doublewidth=(vga.tandy.gfx_control & 0x8)==0x00;
|
||||
vga.draw.blocks=width * (doublewidth ? 4:8);
|
||||
// vga.draw.blocks=width * (doublewidth ? 4:8);
|
||||
vga.draw.blocks=width * 4;
|
||||
width=vga.draw.blocks*2;
|
||||
VGA_DrawLine=VGA_Draw_2BPP_Line;
|
||||
if ((machine==MCH_TANDY && (vga.tandy.gfx_control & 0x8)) ||
|
||||
(machine==MCH_PCJR && (vga.tandy.mode_control==0x0b))) VGA_DrawLine=VGA_Draw_2BPPHiRes_Line;
|
||||
else VGA_DrawLine=VGA_Draw_2BPP_Line;
|
||||
break;
|
||||
case M_TANDY16:
|
||||
aspect_ratio=1.2;
|
||||
|
|
|
@ -191,7 +191,8 @@ static void write_color_select(Bit8u val) {
|
|||
break;
|
||||
case M_TANDY4:
|
||||
{
|
||||
if (IS_TANDY_ARCH && (vga.tandy.gfx_control & 0x8)) {
|
||||
if ((machine==MCH_TANDY && (vga.tandy.gfx_control & 0x8)) ||
|
||||
(machine==MCH_PCJR && (vga.tandy.mode_control==0x0b))) {
|
||||
VGA_SetCGA4Table(0,1,2,3);
|
||||
return;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue