mirror of
https://github.com/holub/mame
synced 2025-04-30 19:57:11 +03:00
Merge pull request #4309 from hp9k/nereid_overlay_support
nereid: add overlay support
This commit is contained in:
commit
36c562dbdf
@ -30,77 +30,158 @@ void nereid_device::device_start()
|
|||||||
save_item(NAME(m_green));
|
save_item(NAME(m_green));
|
||||||
save_item(NAME(m_blue));
|
save_item(NAME(m_blue));
|
||||||
save_item(NAME(m_index));
|
save_item(NAME(m_index));
|
||||||
save_item(NAME(m_palette));
|
save_item(NAME(m_video_palette));
|
||||||
|
save_item(NAME(m_overlay_palette));
|
||||||
save_item(NAME(m_plane_mask));
|
save_item(NAME(m_plane_mask));
|
||||||
|
save_item(NAME(m_overlay_ctl));
|
||||||
|
save_item(NAME(m_overlay_index));
|
||||||
|
save_item(NAME(m_unknown_a0));
|
||||||
}
|
}
|
||||||
|
|
||||||
void nereid_device::device_reset()
|
void nereid_device::device_reset()
|
||||||
{
|
{
|
||||||
memset(&m_palette, 0, sizeof(m_palette));
|
std::fill(m_video_palette.begin(), m_video_palette.end(), 0);
|
||||||
|
std::fill(m_overlay_palette.begin(), m_overlay_palette.end(), 0);
|
||||||
|
|
||||||
|
m_index = 0;
|
||||||
|
m_plane_mask = 0;
|
||||||
|
m_overlay_ctl = 0;
|
||||||
|
m_red = 0;
|
||||||
|
m_green = 0;
|
||||||
|
m_blue = 0;
|
||||||
|
m_unknown_a0 = 0;
|
||||||
|
m_overlay_index = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
READ16_MEMBER(nereid_device::ctrl_r)
|
READ16_MEMBER(nereid_device::ctrl_r)
|
||||||
{
|
{
|
||||||
LOG("NEREID ctrl_r: %02X\n", offset);
|
LOG("NEREID ctrl_r: %02X\n", offset);
|
||||||
|
|
||||||
switch(offset & 0x7f) {
|
switch (offset & 0x7f) {
|
||||||
case NEREID_BUSY:
|
case NEREID_BUSY:
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case NEREID_RED_DATA:
|
case NEREID_RED_DATA:
|
||||||
return 0xff00 | m_red;
|
return 0xff00 | m_red;
|
||||||
|
|
||||||
case NEREID_GREEN_DATA:
|
case NEREID_GREEN_DATA:
|
||||||
return 0xff00 | m_green;
|
return 0xff00 | m_green;
|
||||||
|
|
||||||
case NEREID_BLUE_DATA:
|
case NEREID_BLUE_DATA:
|
||||||
return 0xff00 | m_blue;
|
return 0xff00 | m_blue;
|
||||||
|
|
||||||
case NEREID_INDEX:
|
case NEREID_INDEX:
|
||||||
|
return 0xff00 | ~m_index;
|
||||||
|
|
||||||
|
case NEREID_INDEX0:
|
||||||
return 0xff00 | m_index;
|
return 0xff00 | m_index;
|
||||||
|
|
||||||
|
case NEREID_OVERLAY_CTL:
|
||||||
|
return 0xff00 | m_overlay_ctl;
|
||||||
|
|
||||||
case NEREID_WRITE_STROBE:
|
case NEREID_WRITE_STROBE:
|
||||||
return 0xff00;
|
return 0xff00;
|
||||||
|
|
||||||
case NEREID_PLANE_MASK:
|
case NEREID_PLANE_MASK:
|
||||||
return 0xff00 | m_plane_mask;
|
return 0xff00 | m_plane_mask;
|
||||||
|
|
||||||
|
case NEREID_UNKNOWN_A0:
|
||||||
|
return 0xff00 | m_unknown_a0;
|
||||||
|
|
||||||
|
case NEREID_OVERLAY_INDEX:
|
||||||
|
return 0xff00 | m_overlay_index;
|
||||||
|
|
||||||
|
case NEREID_REV:
|
||||||
|
return 0xff01;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return space.unmap();
|
LOG("NEREID ctrl_r: unknown register %04X\n", offset);
|
||||||
|
return 0xffff;//space.unmap();
|
||||||
}
|
}
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
}
|
}
|
||||||
|
|
||||||
WRITE16_MEMBER(nereid_device::ctrl_w)
|
WRITE16_MEMBER(nereid_device::ctrl_w)
|
||||||
{
|
{
|
||||||
LOG("NEREID: ctrl_w %02X = %02X\n", offset, data);
|
LOG("NEREID: ctrl_w %02X = %02X\n", offset << 1, data);
|
||||||
data &= 0xff;
|
data &= 0xff;
|
||||||
switch(offset & 0x7f) {
|
switch (offset & 0x7f) {
|
||||||
case NEREID_RED_DATA:
|
case NEREID_RED_DATA:
|
||||||
m_red = data;
|
m_red = data;
|
||||||
|
LOG("W NEREID_RED_DATA = %04X\n", m_red);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NEREID_GREEN_DATA:
|
case NEREID_GREEN_DATA:
|
||||||
m_green = data;
|
m_green = data;
|
||||||
|
LOG("W NEREID_GREEN_DATA = %04X\n", m_green);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NEREID_BLUE_DATA:
|
case NEREID_BLUE_DATA:
|
||||||
m_blue = data;
|
m_blue = data;
|
||||||
|
LOG("W NEREID_BLUE_DATA = %04X\n", m_blue);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NEREID_INDEX:
|
case NEREID_INDEX:
|
||||||
m_index = ~data;
|
m_index = ~data;
|
||||||
|
LOG("W NEREID_INDEX = %04X\n", m_index);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case NEREID_INDEX0:
|
||||||
|
m_index =data;
|
||||||
|
LOG("W NEREID_INDEX0 = %04X\n", data);
|
||||||
|
break;
|
||||||
|
|
||||||
case NEREID_WRITE_STROBE:
|
case NEREID_WRITE_STROBE:
|
||||||
LOG("NEREID: set color index %u: rgb_t(%u,%u,%u)\n",
|
if (m_overlay_index & 8) {
|
||||||
|
const int index = (m_overlay_index >> 1) & 0x3;
|
||||||
|
LOG("NEREID: set overlay color index %u: rgb_t(%u,%u,%u)\n",
|
||||||
|
index, m_red, m_green, m_blue);
|
||||||
|
m_overlay_palette[index] = rgb_t(m_red, m_green, m_blue);
|
||||||
|
} else {
|
||||||
|
LOG("NEREID: set video color index %u: rgb_t(%u,%u,%u)\n",
|
||||||
m_index, m_red, m_green, m_blue);
|
m_index, m_red, m_green, m_blue);
|
||||||
m_palette[m_index] = rgb_t(m_red, m_green, m_blue);
|
m_video_palette[m_index] = rgb_t(m_red, m_green, m_blue);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NEREID_READ_STROBE:
|
case NEREID_READ_STROBE:
|
||||||
m_red = m_palette[m_index].r();
|
m_red = m_video_palette[m_index].r();
|
||||||
m_green = m_palette[m_index].g();
|
m_green = m_video_palette[m_index].g();
|
||||||
m_blue = m_palette[m_index].b();
|
m_blue = m_video_palette[m_index].b();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NEREID_PLANE_MASK:
|
case NEREID_PLANE_MASK:
|
||||||
m_plane_mask = data;
|
m_plane_mask = data;
|
||||||
|
LOG("W NEREID_PLANE_MASK = %02x\n", m_plane_mask);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case NEREID_OVERLAY_CTL:
|
||||||
|
m_overlay_ctl = data;
|
||||||
|
LOG("W NEREID_OVERLAY_CTL = %02x\n", m_overlay_ctl);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NEREID_UNKNOWN_A0:
|
||||||
|
m_unknown_a0 = data;
|
||||||
|
LOG("UW A0 = %04x\n", data);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NEREID_OVERLAY_INDEX:
|
||||||
|
m_overlay_index = data;
|
||||||
|
LOG("W OVERLAY_INDEX = %04x\n", data);
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
LOG("nereid::ctrl_w: %X = %04X (mask %04X)\n", offset, data, mem_mask);
|
LOG("nereid::ctrl_w: unknown %X = %04X (mask %04X)\n", offset << 1, data, mem_mask);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
rgb_t nereid_device::map_color(uint8_t input)
|
rgb_t nereid_device::map_color(uint8_t input, uint8_t ovl)
|
||||||
{
|
{
|
||||||
return m_palette[input & m_plane_mask];
|
ovl &= m_overlay_ctl;
|
||||||
|
|
||||||
|
if (ovl == 0)
|
||||||
|
return m_video_palette[input & m_plane_mask];
|
||||||
|
else
|
||||||
|
return m_overlay_palette[ovl & m_plane_mask];
|
||||||
}
|
}
|
||||||
|
@ -13,7 +13,7 @@ public:
|
|||||||
DECLARE_READ16_MEMBER(ctrl_r);
|
DECLARE_READ16_MEMBER(ctrl_r);
|
||||||
DECLARE_WRITE16_MEMBER(ctrl_w);
|
DECLARE_WRITE16_MEMBER(ctrl_w);
|
||||||
|
|
||||||
rgb_t map_color(uint8_t input);
|
rgb_t map_color(uint8_t input, uint8_t ovl = 0);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
nereid_device(const machine_config &mconfig, device_type type, const char *tag, device_t *owner, uint32_t clock);
|
nereid_device(const machine_config &mconfig, device_type type, const char *tag, device_t *owner, uint32_t clock);
|
||||||
@ -22,15 +22,25 @@ protected:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
static constexpr int NEREID_BUSY=1;
|
static constexpr int NEREID_BUSY=1;
|
||||||
|
|
||||||
|
static constexpr int NEREID_BLANK_ALL=0x2e;
|
||||||
|
static constexpr int NEREID_WRITE_STROBE_OVERLAY=0x3c;
|
||||||
|
static constexpr int NEREID_UNKNOWN_A0=0x50;
|
||||||
|
static constexpr int NEREID_OVERLAY_CTL=0x51;
|
||||||
|
static constexpr int NEREID_INDEX0=0x58;
|
||||||
static constexpr int NEREID_RED_DATA=0x59;
|
static constexpr int NEREID_RED_DATA=0x59;
|
||||||
static constexpr int NEREID_GREEN_DATA=0x5a;
|
static constexpr int NEREID_GREEN_DATA=0x5a;
|
||||||
static constexpr int NEREID_BLUE_DATA=0x5b;
|
static constexpr int NEREID_BLUE_DATA=0x5b;
|
||||||
static constexpr int NEREID_INDEX=0x5c;
|
static constexpr int NEREID_INDEX=0x5c;
|
||||||
static constexpr int NEREID_PLANE_MASK=0x5d;
|
static constexpr int NEREID_PLANE_MASK=0x5d;
|
||||||
|
static constexpr int NEREID_OVERLAY_INDEX=0x5e;
|
||||||
|
static constexpr int NEREID_REV=0x5f;
|
||||||
static constexpr int NEREID_WRITE_STROBE=0x78;
|
static constexpr int NEREID_WRITE_STROBE=0x78;
|
||||||
static constexpr int NEREID_READ_STROBE=0x7c;
|
static constexpr int NEREID_READ_STROBE=0x7c;
|
||||||
|
|
||||||
rgb_t m_palette[256];
|
|
||||||
|
std::array<rgb_t, 256> m_video_palette;
|
||||||
|
std::array<rgb_t, 256> m_overlay_palette;
|
||||||
|
|
||||||
/* registers */
|
/* registers */
|
||||||
uint8_t m_red;
|
uint8_t m_red;
|
||||||
@ -38,6 +48,9 @@ private:
|
|||||||
uint8_t m_blue;
|
uint8_t m_blue;
|
||||||
uint8_t m_index;
|
uint8_t m_index;
|
||||||
uint8_t m_plane_mask;
|
uint8_t m_plane_mask;
|
||||||
|
uint8_t m_overlay_ctl;
|
||||||
|
uint8_t m_unknown_a0;
|
||||||
|
uint8_t m_overlay_index;
|
||||||
};
|
};
|
||||||
|
|
||||||
DECLARE_DEVICE_TYPE(NEREID, nereid_device)
|
DECLARE_DEVICE_TYPE(NEREID, nereid_device)
|
||||||
|
Loading…
Reference in New Issue
Block a user