mirror of https://github.com/stella-emu/stella.git
Merge remote-tracking branch 'remotes/origin/master' into feature/paddle_options
This commit is contained in:
commit
fb41c41470
|
@ -78,9 +78,11 @@ class StreamReader : public Serializable
|
|||
myColor[colorSize - 2] = 0;
|
||||
myColor[colorSize - 1] = 0;
|
||||
}
|
||||
|
||||
myColorBK[0] = 0;
|
||||
}
|
||||
|
||||
void swapField(bool index) {
|
||||
void swapField(bool index, bool odd) {
|
||||
uInt8* offset = index ? myBuffer1 : myBuffer2;
|
||||
|
||||
myVersion = offset + VERSION_DATA_OFFSET;
|
||||
|
@ -89,6 +91,10 @@ class StreamReader : public Serializable
|
|||
myGraph = offset + GRAPH_DATA_OFFSET;
|
||||
myTimecode = offset + TIMECODE_DATA_OFFSET;
|
||||
myColor = offset + COLOR_DATA_OFFSET;
|
||||
myColorBK = offset + COLORBK_DATA_OFFSET;
|
||||
|
||||
if (!odd)
|
||||
myColorBK++;
|
||||
}
|
||||
|
||||
bool readField(uInt32 fnum, bool index) {
|
||||
|
@ -113,6 +119,7 @@ class StreamReader : public Serializable
|
|||
uInt8 readVersion() { return *myVersion++; }
|
||||
uInt8 readFrame() { return *myFrame++; }
|
||||
uInt8 readColor() { return *myColor++; }
|
||||
uInt8 readColorBK() { return *myColorBK++; }
|
||||
|
||||
uInt8 readGraph() {
|
||||
return myGraphOverride ? *myGraphOverride++ : *myGraph++;
|
||||
|
@ -138,6 +145,7 @@ class StreamReader : public Serializable
|
|||
const uInt8* myGraphOverride
|
||||
const uInt8* myTimecode
|
||||
const uInt8* myColor
|
||||
const uInt8* myColorBK
|
||||
const uInt8* myVersion
|
||||
const uInt8* myFrame
|
||||
#endif
|
||||
|
@ -161,6 +169,7 @@ class StreamReader : public Serializable
|
|||
const uInt8* myGraphOverride
|
||||
const uInt8* myTimecode
|
||||
const uInt8* myColor
|
||||
const uInt8* myColorBK
|
||||
const uInt8* myVersion
|
||||
const uInt8* myFrame
|
||||
#endif
|
||||
|
@ -180,7 +189,8 @@ class StreamReader : public Serializable
|
|||
GRAPH_DATA_OFFSET = 269,
|
||||
TIMECODE_DATA_OFFSET = 1229,
|
||||
COLOR_DATA_OFFSET = 1289,
|
||||
END_DATA_OFFSET = 2249;
|
||||
COLORBK_DATA_OFFSET = 2249,
|
||||
END_DATA_OFFSET = 2441;
|
||||
|
||||
const uInt8* myAudio{nullptr};
|
||||
|
||||
|
@ -189,6 +199,7 @@ class StreamReader : public Serializable
|
|||
|
||||
const uInt8* myTimecode{nullptr};
|
||||
uInt8* myColor{nullptr};
|
||||
uInt8* myColorBK{nullptr};
|
||||
const uInt8* myVersion{nullptr};
|
||||
const uInt8* myFrame{nullptr};
|
||||
|
||||
|
@ -287,56 +298,60 @@ class MovieInputs : public Serializable
|
|||
#define DEFAULT_LEVEL 6
|
||||
#define BLANK_LINE_SIZE (30+3+37-1) // 70-1
|
||||
|
||||
// #define addr_kernel_48 0x800
|
||||
#define addr_right_line 0x946
|
||||
#define addr_set_aud_right 0x94a
|
||||
#define addr_set_gdata9 0x94c
|
||||
#define addr_set_gcol9 0x950
|
||||
#define addr_set_gdata6 0x952
|
||||
|
||||
// Automatically generated
|
||||
// Several not used
|
||||
#define addr_kernel_48 0x800
|
||||
#define addr_transport_direction 0x880
|
||||
#define addr_transport_buttons 0x894
|
||||
#define addr_right_line 0x948
|
||||
#define addr_set_gdata6 0x948
|
||||
#define addr_set_aud_right 0x94e
|
||||
#define addr_set_gdata9 0x950
|
||||
#define addr_set_gcol9 0x954
|
||||
#define addr_set_gcol6 0x956
|
||||
#define addr_set_gdata5 0x95a
|
||||
#define addr_set_gcol5 0x95e
|
||||
#define addr_set_gdata8 0x962
|
||||
#define addr_set_gcol7 0x966
|
||||
#define addr_set_gdata7 0x96a
|
||||
#define addr_set_gcol8 0x96e
|
||||
// #define addr_left_line 0x980
|
||||
#define addr_set_colubk_r 0x966
|
||||
#define addr_set_gcol7 0x96a
|
||||
#define addr_set_gdata7 0x96e
|
||||
#define addr_set_gcol8 0x972
|
||||
#define addr_left_line 0x980
|
||||
#define addr_set_gdata1 0x982
|
||||
#define addr_set_aud_left 0x986
|
||||
#define addr_set_gdata4 0x98a
|
||||
#define addr_set_gcol4 0x98c
|
||||
#define addr_set_gcol1 0x98e
|
||||
#define addr_set_gdata0 0x992
|
||||
#define addr_set_gcol0 0x996
|
||||
#define addr_set_gdata3 0x99a
|
||||
#define addr_set_gcol2 0x99e
|
||||
#define addr_set_gdata2 0x9a2
|
||||
#define addr_set_gcol3 0x9a6
|
||||
#define addr_pick_continue 0x9b4
|
||||
// #define addr_main_start 0xa00
|
||||
// #define addr_aud_bank_setup 0xa0c
|
||||
// #define addr_tg0 0xa24
|
||||
// #define addr_title_again 0xa3b
|
||||
// #define addr_wait_cnt 0xa77
|
||||
#define addr_set_gcol1 0x988
|
||||
#define addr_set_aud_left 0x98c
|
||||
#define addr_set_gdata4 0x990
|
||||
#define addr_set_gcol4 0x992
|
||||
#define addr_set_gdata0 0x994
|
||||
#define addr_set_gcol0 0x998
|
||||
#define addr_set_gdata3 0x99c
|
||||
#define addr_set_colupf_l 0x9a0
|
||||
#define addr_set_gcol2 0x9a4
|
||||
#define addr_set_gdata2 0x9a8
|
||||
#define addr_set_gcol3 0x9ac
|
||||
#define addr_pick_continue 0x9be
|
||||
#define addr_main_start 0xa00
|
||||
#define addr_aud_bank_setup 0xa0c
|
||||
#define addr_tg0 0xa24
|
||||
#define addr_title_again 0xa3b
|
||||
#define addr_wait_cnt 0xa77
|
||||
#define addr_end_lines 0xa80
|
||||
#define addr_set_aud_endlines 0xa8c
|
||||
#define addr_set_overscan_size 0xa90
|
||||
#define addr_set_vblank_size 0xaa6
|
||||
#define addr_pick_extra_lines 0xaaf
|
||||
#define addr_pick_transport 0xab6
|
||||
#define addr_transport_direction 0xab9
|
||||
#define addr_transport_buttons 0xac2
|
||||
// #define addr_transport_done 0xacb
|
||||
// #define addr_wait_lines 0xad0
|
||||
// #define addr_transport_done1 0xae1
|
||||
// #define addr_draw_title 0xb00
|
||||
#define addr_set_aud_endlines 0xa80
|
||||
#define addr_set_overscan_size 0xa9a
|
||||
#define addr_set_vblank_size 0xab0
|
||||
#define addr_pick_extra_lines 0xab9
|
||||
#define addr_pick_transport 0xac6
|
||||
#define addr_wait_lines 0xac9
|
||||
#define addr_transport_done1 0xada
|
||||
#define addr_draw_title 0xb00
|
||||
#define addr_title_loop 0xb50
|
||||
// #define addr_black_bar 0xb52
|
||||
// #define addr_animate_bar1 0xb58
|
||||
// #define addr_animate_bar_again1 0xb5a
|
||||
// #define addr_animate_dex1 0xb65
|
||||
#define addr_black_bar 0xb52
|
||||
#define addr_animate_bar1 0xb58
|
||||
#define addr_animate_bar_again1 0xb5a
|
||||
#define addr_animate_dex1 0xb65
|
||||
#define addr_audio_bank 0xb80
|
||||
// #define addr_reset_loop 0xbfa
|
||||
#define addr_reset_loop 0xbfa
|
||||
|
||||
// scale adjustments, automatically generated
|
||||
static constexpr uInt8 scale0[16] = {
|
||||
|
@ -393,6 +408,9 @@ static constexpr unsigned char kernelROM[] = {
|
|||
192, 97, 99, 102, 102, 198, 198, 198, 248, 198, 248, 0, 193, 32, 48, 24,
|
||||
24, 25, 24, 24, 24, 24, 126, 0, 249, 97, 97, 97, 97, 249, 0, 0,
|
||||
0, 0, 0, 0, 248, 128, 128, 224, 128, 248, 255, 255, 255, 255, 255, 255,
|
||||
173, 128, 2, 74, 74, 74, 133, 129, 234, 133, 128, 133, 128, 133, 128, 133,
|
||||
128, 76, 72, 249, 165, 12, 10, 173, 130, 2, 42, 41, 23, 133, 129, 234,
|
||||
133, 128, 133, 128, 133, 128, 76, 72, 249, 255, 255, 255, 255, 255, 255, 255,
|
||||
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||
|
@ -402,18 +420,15 @@ static constexpr unsigned char kernelROM[] = {
|
|||
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||
255, 255, 255, 255, 255, 255, 133, 2, 133, 42, 169, 0, 162, 223, 133, 25,
|
||||
160, 98, 169, 159, 133, 28, 169, 248, 133, 7, 169, 231, 133, 27, 169, 242,
|
||||
133, 6, 169, 247, 133, 28, 169, 172, 133, 6, 169, 253, 133, 27, 169, 216,
|
||||
133, 7, 134, 27, 132, 6, 133, 43, 133, 128, 133, 128, 133, 128, 133, 42,
|
||||
133, 2, 169, 207, 133, 28, 169, 0, 133, 25, 162, 191, 160, 114, 169, 54,
|
||||
133, 7, 169, 243, 133, 27, 169, 66, 133, 6, 169, 239, 133, 28, 169, 238,
|
||||
133, 6, 169, 251, 133, 27, 169, 182, 133, 7, 134, 27, 132, 6, 169, 128,
|
||||
133, 32, 133, 33, 76, 70, 249, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||
255, 255, 255, 255, 255, 255, 255, 255, 169, 159, 133, 28, 133, 42, 169, 0,
|
||||
162, 223, 133, 25, 160, 98, 169, 248, 133, 7, 169, 231, 133, 27, 169, 242,
|
||||
133, 6, 169, 247, 133, 28, 169, 0, 133, 9, 169, 172, 133, 6, 169, 253,
|
||||
133, 27, 169, 216, 133, 7, 134, 27, 132, 6, 169, 0, 133, 9, 133, 43,
|
||||
169, 0, 169, 207, 133, 42, 133, 28, 169, 54, 133, 7, 169, 0, 133, 25,
|
||||
162, 191, 160, 114, 169, 243, 133, 27, 169, 66, 133, 6, 169, 239, 133, 28,
|
||||
169, 0, 133, 8, 169, 238, 133, 6, 169, 251, 133, 27, 169, 182, 133, 7,
|
||||
134, 27, 132, 6, 169, 0, 133, 8, 169, 128, 133, 32, 133, 33, 76, 72,
|
||||
249, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||
|
@ -425,13 +440,13 @@ static constexpr unsigned char kernelROM[] = {
|
|||
133, 37, 133, 27, 133, 16, 234, 133, 17, 133, 28, 133, 27, 133, 28, 169,
|
||||
6, 133, 4, 169, 2, 133, 5, 169, 1, 133, 38, 169, 0, 133, 32, 169,
|
||||
240, 133, 33, 133, 42, 162, 5, 202, 208, 253, 133, 43, 76, 128, 250, 255,
|
||||
160, 0, 132, 27, 132, 28, 132, 27, 169, 0, 169, 0, 169, 0, 133, 25,
|
||||
162, 29, 32, 208, 250, 169, 2, 133, 0, 162, 3, 32, 208, 250, 169, 0,
|
||||
133, 0, 169, 2, 133, 1, 162, 37, 32, 208, 250, 162, 0, 134, 1, 162,
|
||||
0, 240, 3, 32, 208, 250, 76, 194, 250, 173, 128, 2, 74, 74, 74, 76,
|
||||
203, 250, 165, 12, 10, 173, 130, 2, 42, 41, 23, 133, 129, 76, 70, 249,
|
||||
133, 2, 169, 0, 177, 130, 133, 25, 165, 129, 240, 5, 198, 129, 173, 128,
|
||||
20, 200, 202, 208, 235, 96, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||
169, 0, 162, 0, 160, 0, 132, 27, 132, 28, 133, 25, 132, 27, 169, 207,
|
||||
133, 13, 169, 51, 133, 14, 169, 204, 133, 15, 162, 29, 32, 201, 250, 169,
|
||||
2, 133, 0, 162, 3, 32, 201, 250, 169, 0, 133, 0, 169, 2, 133, 1,
|
||||
162, 37, 32, 201, 250, 162, 0, 134, 1, 162, 0, 240, 9, 32, 201, 250,
|
||||
234, 234, 133, 128, 133, 128, 76, 148, 248, 133, 2, 169, 0, 177, 130, 133,
|
||||
25, 165, 129, 240, 5, 198, 129, 173, 128, 20, 200, 202, 208, 235, 96, 255,
|
||||
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||
162, 30, 32, 82, 251, 169, 2, 133, 0, 162, 3, 32, 82, 251, 169, 0,
|
||||
133, 0, 169, 2, 133, 1, 162, 37, 32, 82, 251, 169, 0, 133, 1, 198,
|
||||
|
@ -465,6 +480,8 @@ static constexpr uInt8 brightLabelEven[] = {
|
|||
0, 49, 48, 12, 96,
|
||||
6, 140, 231, 96, 0,
|
||||
0, 225, 48, 12, 96,
|
||||
0, 0, 0, 0, 0,
|
||||
0, 0, 0, 0, 0
|
||||
};
|
||||
|
||||
static constexpr uInt8 brightLabelOdd[] = {
|
||||
|
@ -479,6 +496,8 @@ static constexpr uInt8 brightLabelOdd[] = {
|
|||
6, 156, 195, 96, 0,
|
||||
0, 113, 48, 12, 96,
|
||||
7, 142, 127, 96, 0,
|
||||
0, 0, 0, 0, 0,
|
||||
0, 0, 0, 0, 0,
|
||||
0, 0, 0, 0, 0
|
||||
};
|
||||
|
||||
|
@ -495,6 +514,8 @@ static constexpr uInt8 volumeLabelEven[] = {
|
|||
0, 12, 192, 15, 192,
|
||||
30, 112, 119, 176, 0,
|
||||
0, 7, 252, 12, 254,
|
||||
0, 0, 0, 0, 0,
|
||||
0, 0, 0, 0, 0
|
||||
};
|
||||
|
||||
static constexpr uInt8 volumeLabelOdd[] = {
|
||||
|
@ -509,6 +530,8 @@ static constexpr uInt8 volumeLabelOdd[] = {
|
|||
30, 112, 99, 176, 0,
|
||||
0, 14, 192, 13, 192,
|
||||
14, 224, 62, 48, 0,
|
||||
0, 0, 0, 0, 0,
|
||||
0, 0, 0, 0, 0,
|
||||
0, 0, 0, 0, 0
|
||||
};
|
||||
|
||||
|
@ -759,7 +782,7 @@ class MovieCart : public Serializable
|
|||
writeROM(addr_title_loop + 0, 0x18);
|
||||
}
|
||||
|
||||
void writeColor(uInt16 address);
|
||||
void writeColor(uInt16 address, uInt8 val);
|
||||
void writeAudioData(uInt16 address, uInt8 val) {
|
||||
writeROM(address, myVolumeScale[val]);
|
||||
}
|
||||
|
@ -861,16 +884,14 @@ bool MovieCart::init(const string& path)
|
|||
if(!myStream.open(path))
|
||||
return false;
|
||||
|
||||
myStream.swapField(true);
|
||||
myStream.swapField(true, myOdd);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void MovieCart::writeColor(uInt16 address)
|
||||
void MovieCart::writeColor(uInt16 address, uInt8 v)
|
||||
{
|
||||
uint8_t v = myStream.readColor();
|
||||
|
||||
v = (v & 0xf0) | shiftBright[(v & 0x0f) + myBright];
|
||||
|
||||
if(myForceColor)
|
||||
|
@ -1079,6 +1100,7 @@ void MovieCart::updateTransport()
|
|||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void MovieCart::fill_addr_right_line()
|
||||
{
|
||||
uint8_t v;
|
||||
writeAudio(addr_set_aud_right + 1);
|
||||
|
||||
writeGraph(addr_set_gdata5 + 1);
|
||||
|
@ -1087,16 +1109,39 @@ void MovieCart::fill_addr_right_line()
|
|||
writeGraph(addr_set_gdata8 + 1);
|
||||
writeGraph(addr_set_gdata9 + 1);
|
||||
|
||||
writeColor(addr_set_gcol5 + 1);
|
||||
writeColor(addr_set_gcol6 + 1);
|
||||
writeColor(addr_set_gcol7 + 1);
|
||||
writeColor(addr_set_gcol8 + 1);
|
||||
writeColor(addr_set_gcol9 + 1);
|
||||
v = myStream.readColor();
|
||||
writeColor(addr_set_gcol5 + 1, v);
|
||||
|
||||
v = myStream.readColor();
|
||||
writeColor(addr_set_gcol6 + 1, v);
|
||||
|
||||
v = myStream.readColor();
|
||||
writeColor(addr_set_gcol7 + 1, v);
|
||||
|
||||
v = myStream.readColor();
|
||||
writeColor(addr_set_gcol8 + 1, v);
|
||||
|
||||
v = myStream.readColor();
|
||||
writeColor(addr_set_gcol9 + 1, v);
|
||||
|
||||
// alternate between background color and playfield color
|
||||
if (myForceColor)
|
||||
{
|
||||
v = 0;
|
||||
writeROM(addr_set_colubk_r + 1, v);
|
||||
}
|
||||
else
|
||||
{
|
||||
v = myStream.readColorBK();
|
||||
writeColor(addr_set_colubk_r + 1, v);
|
||||
}
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void MovieCart::fill_addr_left_line(bool again)
|
||||
{
|
||||
uint8_t v;
|
||||
|
||||
writeAudio(addr_set_aud_left + 1);
|
||||
|
||||
writeGraph(addr_set_gdata0 + 1);
|
||||
|
@ -1105,11 +1150,33 @@ void MovieCart::fill_addr_left_line(bool again)
|
|||
writeGraph(addr_set_gdata3 + 1);
|
||||
writeGraph(addr_set_gdata4 + 1);
|
||||
|
||||
writeColor(addr_set_gcol0 + 1);
|
||||
writeColor(addr_set_gcol1 + 1);
|
||||
writeColor(addr_set_gcol2 + 1);
|
||||
writeColor(addr_set_gcol3 + 1);
|
||||
writeColor(addr_set_gcol4 + 1);
|
||||
v = myStream.readColor();
|
||||
writeColor(addr_set_gcol0 + 1, v);
|
||||
|
||||
v = myStream.readColor();
|
||||
writeColor(addr_set_gcol1 + 1, v);
|
||||
|
||||
v = myStream.readColor();
|
||||
writeColor(addr_set_gcol2 + 1, v);
|
||||
|
||||
v = myStream.readColor();
|
||||
writeColor(addr_set_gcol3 + 1, v);
|
||||
|
||||
v = myStream.readColor();
|
||||
writeColor(addr_set_gcol4 + 1, v);
|
||||
|
||||
|
||||
// alternate between background color and playfield color
|
||||
if (myForceColor)
|
||||
{
|
||||
v = 0;
|
||||
writeROM(addr_set_colupf_l + 1, v);
|
||||
}
|
||||
else
|
||||
{
|
||||
v = myStream.readColorBK();
|
||||
writeColor(addr_set_colupf_l + 1, v);
|
||||
}
|
||||
|
||||
// addr_pick_line_end
|
||||
// jmp right_line
|
||||
|
@ -1300,7 +1367,7 @@ void MovieCart::runStateMachine()
|
|||
fill_addr_left_line(0);
|
||||
fill_addr_end_lines();
|
||||
|
||||
myStream.swapField(myBufferIndex);
|
||||
myStream.swapField(myBufferIndex, myOdd);
|
||||
myStream.blankPartialLines(myOdd);
|
||||
|
||||
myBufferIndex = !myBufferIndex;
|
||||
|
|
Loading…
Reference in New Issue