MASK_EN support
This commit is contained in:
parent
2f2b792edf
commit
382d9f8898
@ -648,6 +648,7 @@ void GB_reset(GB_gameboy_t *gb)
|
|||||||
if (!gb->sgb) {
|
if (!gb->sgb) {
|
||||||
gb->sgb = malloc(sizeof(*gb->sgb));
|
gb->sgb = malloc(sizeof(*gb->sgb));
|
||||||
}
|
}
|
||||||
|
memset(gb->sgb, 0, sizeof(*gb->sgb));
|
||||||
gb->sgb->player_count = 1;
|
gb->sgb->player_count = 1;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
33
Core/sgb.c
33
Core/sgb.c
@ -2,8 +2,16 @@
|
|||||||
|
|
||||||
enum {
|
enum {
|
||||||
MLT_REQ = 0x11,
|
MLT_REQ = 0x11,
|
||||||
|
MASK_EN = 0x17,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
MASK_DISABLED,
|
||||||
|
MASK_FREEZE,
|
||||||
|
MASK_COLOR_3,
|
||||||
|
MASK_COLOR_0,
|
||||||
|
} mask_mode_t;
|
||||||
|
|
||||||
#define SGB_PACKET_SIZE 16
|
#define SGB_PACKET_SIZE 16
|
||||||
|
|
||||||
static void command_ready(GB_gameboy_t *gb)
|
static void command_ready(GB_gameboy_t *gb)
|
||||||
@ -46,6 +54,9 @@ static void command_ready(GB_gameboy_t *gb)
|
|||||||
gb->sgb->player_count = (uint8_t[]){1, 2, 1, 4}[gb->sgb->command[1] & 3];
|
gb->sgb->player_count = (uint8_t[]){1, 2, 1, 4}[gb->sgb->command[1] & 3];
|
||||||
gb->sgb->current_player = gb->sgb->player_count - 1;
|
gb->sgb->current_player = gb->sgb->player_count - 1;
|
||||||
break;
|
break;
|
||||||
|
case MASK_EN:
|
||||||
|
gb->sgb->mask_mode = gb->sgb->command[1] & 3;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
GB_log(gb, "Unimplemented SGB command %x: ", gb->sgb->command[0] >> 3);
|
GB_log(gb, "Unimplemented SGB command %x: ", gb->sgb->command[0] >> 3);
|
||||||
for (unsigned i = 0; i < gb->sgb->command_write_index / 8; i++) {
|
for (unsigned i = 0; i < gb->sgb->command_write_index / 8; i++) {
|
||||||
@ -144,8 +155,28 @@ void GB_sgb_render(GB_gameboy_t *gb)
|
|||||||
gb->screen[i] = border;
|
gb->screen[i] = border;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
switch ((mask_mode_t) gb->sgb->mask_mode) {
|
||||||
|
case MASK_DISABLED:
|
||||||
|
memcpy(gb->sgb->effective_screen_buffer,
|
||||||
|
gb->sgb->screen_buffer,
|
||||||
|
sizeof(gb->sgb->effective_screen_buffer));
|
||||||
|
break;
|
||||||
|
case MASK_FREEZE:
|
||||||
|
break;
|
||||||
|
|
||||||
|
case MASK_COLOR_3:
|
||||||
|
memset(gb->sgb->effective_screen_buffer,
|
||||||
|
3,
|
||||||
|
sizeof(gb->sgb->effective_screen_buffer));
|
||||||
|
break;
|
||||||
|
case MASK_COLOR_0:
|
||||||
|
memset(gb->sgb->effective_screen_buffer,
|
||||||
|
0,
|
||||||
|
sizeof(gb->sgb->effective_screen_buffer));
|
||||||
|
}
|
||||||
|
|
||||||
uint32_t *output = &gb->screen[48 + 39 * 256];
|
uint32_t *output = &gb->screen[48 + 39 * 256];
|
||||||
uint8_t *input = gb->sgb->screen_buffer;
|
uint8_t *input = gb->sgb->effective_screen_buffer;
|
||||||
for (unsigned y = 0; y < 144; y++) {
|
for (unsigned y = 0; y < 144; y++) {
|
||||||
for (unsigned x = 0; x < 160; x++) {
|
for (unsigned x = 0; x < 160; x++) {
|
||||||
*(output++) = colors[*(input++) & 3];
|
*(output++) = colors[*(input++) & 3];
|
||||||
|
@ -14,9 +14,14 @@ typedef struct {
|
|||||||
bool disable_commands;
|
bool disable_commands;
|
||||||
|
|
||||||
/* Screen buffer */
|
/* Screen buffer */
|
||||||
uint8_t screen_buffer[160 * 144];
|
uint8_t screen_buffer[160 * 144]; // Live image from the Game Boy
|
||||||
|
uint8_t effective_screen_buffer[160 * 144]; // Image actually rendered to the screen
|
||||||
|
|
||||||
/* Multiplayer Input */
|
/* Multiplayer Input */
|
||||||
uint8_t player_count, current_player;
|
uint8_t player_count, current_player;
|
||||||
|
|
||||||
|
/* Mask */
|
||||||
|
uint8_t mask_mode;
|
||||||
} GB_sgb_t;
|
} GB_sgb_t;
|
||||||
|
|
||||||
void GB_sgb_write(GB_gameboy_t *gb, uint8_t value);
|
void GB_sgb_write(GB_gameboy_t *gb, uint8_t value);
|
||||||
|
Loading…
Reference in New Issue
Block a user