mirror of https://github.com/stella-emu/stella.git
(MovieCart) Avoid unnecessary shuffling of color data during encoding
and decoding, as new kernel does not require it.
This commit is contained in:
parent
fc3a6b2d42
commit
08441d980a
|
@ -666,7 +666,7 @@ class MovieCart
|
||||||
writeROM(addr_title_loop + 0, 0x18);
|
writeROM(addr_title_loop + 0, 0x18);
|
||||||
}
|
}
|
||||||
|
|
||||||
void writeColor(uInt16 address, uInt8 val);
|
void writeColor(uInt16 address);
|
||||||
void writeAudioData(uInt16 address, uInt8 val) {
|
void writeAudioData(uInt16 address, uInt8 val) {
|
||||||
writeROM(address, myVolumeScale[val]);
|
writeROM(address, myVolumeScale[val]);
|
||||||
}
|
}
|
||||||
|
@ -691,9 +691,6 @@ class MovieCart
|
||||||
// data
|
// data
|
||||||
uInt8 myROM[1024];
|
uInt8 myROM[1024];
|
||||||
|
|
||||||
// full line of color
|
|
||||||
uInt8 myColor[10];
|
|
||||||
|
|
||||||
// title screen state
|
// title screen state
|
||||||
int myTitleCycles{0};
|
int myTitleCycles{0};
|
||||||
TitleState myTitleState{TitleState::Display};
|
TitleState myTitleState{TitleState::Display};
|
||||||
|
@ -778,8 +775,10 @@ bool MovieCart::init(const string& path)
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void MovieCart::writeColor(uInt16 address, uInt8 v)
|
void MovieCart::writeColor(uInt16 address)
|
||||||
{
|
{
|
||||||
|
uint8_t v = myStream.readColor();
|
||||||
|
|
||||||
v = (v & 0xf0) | shiftBright[(v & 0x0f) + myBright];
|
v = (v & 0xf0) | shiftBright[(v & 0x0f) + myBright];
|
||||||
|
|
||||||
if(myForceColor)
|
if(myForceColor)
|
||||||
|
@ -996,11 +995,11 @@ void MovieCart::fill_addr_right_line()
|
||||||
writeGraph(addr_set_gdata8 + 1);
|
writeGraph(addr_set_gdata8 + 1);
|
||||||
writeGraph(addr_set_gdata9 + 1);
|
writeGraph(addr_set_gdata9 + 1);
|
||||||
|
|
||||||
writeColor(addr_set_gcol5 + 1, myColor[8]); // col 1/9
|
writeColor(addr_set_gcol5 + 1);
|
||||||
writeColor(addr_set_gcol6 + 1, myColor[9]); // col 3/9
|
writeColor(addr_set_gcol6 + 1);
|
||||||
writeColor(addr_set_gcol7 + 1, myColor[1]); // col 5/9
|
writeColor(addr_set_gcol7 + 1);
|
||||||
writeColor(addr_set_gcol8 + 1, myColor[2]); // col 7/9
|
writeColor(addr_set_gcol8 + 1);
|
||||||
writeColor(addr_set_gcol9 + 1, myColor[0]); // col 9/9
|
writeColor(addr_set_gcol9 + 1);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1015,14 +1014,11 @@ void MovieCart::fill_addr_left_line(bool again)
|
||||||
writeGraph(addr_set_gdata3 + 1);
|
writeGraph(addr_set_gdata3 + 1);
|
||||||
writeGraph(addr_set_gdata4 + 1);
|
writeGraph(addr_set_gdata4 + 1);
|
||||||
|
|
||||||
for(int i = 0; i < 10; ++i)
|
writeColor(addr_set_gcol0 + 1);
|
||||||
myColor[i] = myStream.readColor();
|
writeColor(addr_set_gcol1 + 1);
|
||||||
|
writeColor(addr_set_gcol2 + 1);
|
||||||
writeColor(addr_set_gcol0 + 1, myColor[3]); // col 0/9
|
writeColor(addr_set_gcol3 + 1);
|
||||||
writeColor(addr_set_gcol1 + 1, myColor[4]); // col 2/9
|
writeColor(addr_set_gcol4 + 1);
|
||||||
writeColor(addr_set_gcol2 + 1, myColor[6]); // col 4/9
|
|
||||||
writeColor(addr_set_gcol3 + 1, myColor[7]); // col 6/9
|
|
||||||
writeColor(addr_set_gcol4 + 1, myColor[5]); // col 8/9
|
|
||||||
|
|
||||||
// addr_pick_line_end
|
// addr_pick_line_end
|
||||||
// jmp right_line
|
// jmp right_line
|
||||||
|
|
Binary file not shown.
BIN
test/roms/bankswitching/MVC/output_cronkite.bin → test/roms/bankswitching/MVC/cronkite.bin
Normal file → Executable file
BIN
test/roms/bankswitching/MVC/output_cronkite.bin → test/roms/bankswitching/MVC/cronkite.bin
Normal file → Executable file
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Loading…
Reference in New Issue