(nw) cdc721 : bit of guesswork

This commit is contained in:
Robbbert 2017-11-13 03:43:59 +11:00
parent 9c399e336c
commit b0b77296c9

View File

@ -11,6 +11,7 @@ Control Data Corporation CDC 721 Terminal (Viking)
#include "emu.h"
#include "cpu/z80/z80.h"
#include "video/tms9927.h"
#include "screen.h"
@ -19,30 +20,35 @@ class cdc721_state : public driver_device
public:
cdc721_state(const machine_config &mconfig, device_type type, const char *tag)
: driver_device(mconfig, type, tag)
, m_p_videoram(*this, "videoram")
, m_maincpu(*this, "maincpu")
, m_p_chargen(*this, "chargen")
{
}
, m_p_videoram(*this, "videoram")
{ }
uint32_t screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect);
DECLARE_DRIVER_INIT(init);
DECLARE_PALETTE_INIT(cdc721);
// DECLARE_WRITE8_MEMBER(port70_w) { membank("bankr0")->set_entry(BIT(data, 3)); }
private:
u8 m_flashcnt;
virtual void machine_reset() override;
required_shared_ptr<uint8_t> m_p_videoram;
required_device<cpu_device> m_maincpu;
required_region_ptr<u8> m_p_chargen;
required_shared_ptr<u8> m_p_videoram;
};
static ADDRESS_MAP_START( cdc721_mem, AS_PROGRAM, 8, cdc721_state )
AM_RANGE(0x0000, 0x3fff) AM_ROM AM_REGION("maincpu", 0)
AM_RANGE(0x4000, 0xf097) AM_RAM
AM_RANGE(0xf098, 0xffff) AM_RAM AM_SHARE("videoram")
static ADDRESS_MAP_START( mem_map, AS_PROGRAM, 8, cdc721_state )
AM_RANGE(0x0000, 0x4fff) AM_ROM AM_REGION("maincpu", 0x10000)
// AM_RANGE(0x0000, 0x4fff) AM_READ_BANK("bankr0") AM_WRITE_BANK("bankw0")
AM_RANGE(0x8000, 0xe10f) AM_RAM
AM_RANGE(0xe110, 0xffff) AM_RAM AM_SHARE("videoram")
ADDRESS_MAP_END
static ADDRESS_MAP_START( cdc721_io, AS_IO, 8, cdc721_state )
static ADDRESS_MAP_START( io_map, AS_IO, 8, cdc721_state )
ADDRESS_MAP_GLOBAL_MASK(0xff)
AM_RANGE(0x10, 0x1f) AM_DEVREADWRITE("crtc", tms9927_device, read, write)
// AM_RANGE(0x70, 0x70) AM_WRITE(port70_w)
ADDRESS_MAP_END
static INPUT_PORTS_START( cdc721 )
@ -50,6 +56,17 @@ INPUT_PORTS_END
void cdc721_state::machine_reset()
{
// membank("bankr0")->set_entry(0);
// membank("bankw0")->set_entry(0);
}
DRIVER_INIT_MEMBER( cdc721_state, init )
{
// uint8_t *main = memregion("maincpu")->base();
// membank("bankr0")->configure_entry(1, &main[0x14000]);
// membank("bankr0")->configure_entry(0, &main[0x4000]);
// membank("bankw0")->configure_entry(0, &main[0x4000]);
}
/* F4 Character Displayer */
@ -80,33 +97,45 @@ PALETTE_INIT_MEMBER( cdc721_state, cdc721 )
uint32_t cdc721_state::screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect)
{
uint8_t y,ra,chr,gfx;
uint8_t y,ra,chr,gfx,attr,pen;
uint16_t sy=0,ma=0,x;
m_flashcnt++;
for (y = 0; y < 24; y++)
for (y = 0; y < 30; y++)
{
for (ra = 3; ra < 13; ra++)
for (ra = 0; ra < 16; ra++)
{
uint16_t *p = &bitmap.pix16(sy++);
for (x = 0; x < 160; x+=2)
{
pen = 1;
chr = m_p_videoram[x+ma];
attr = m_p_videoram[x+ma+1];
gfx = m_p_chargen[chr | (ra << 8) ];
if (BIT(attr, 0)) // blank
pen = 0;
if (BIT(attr, 1) && (ra == 14)) // underline
gfx = 0xff;
if (BIT(attr, 4)) // dim
pen = 2;
if (BIT(attr, 2)) // rv
gfx ^= 0xff;
if (BIT(attr, 3) && BIT(m_flashcnt, 6)) // blink
gfx = 0;
/* Display a scanline of a character */
*p++ = BIT(gfx, 0);
*p++ = BIT(gfx, 1);
*p++ = BIT(gfx, 2);
*p++ = BIT(gfx, 3);
*p++ = BIT(gfx, 4);
*p++ = BIT(gfx, 5);
*p++ = BIT(gfx, 6);
*p++ = BIT(gfx, 7);
*p++ = BIT(gfx, 0) ? pen : 0;
*p++ = BIT(gfx, 1) ? pen : 0;
*p++ = BIT(gfx, 2) ? pen : 0;
*p++ = BIT(gfx, 3) ? pen : 0;
*p++ = BIT(gfx, 4) ? pen : 0;
*p++ = BIT(gfx, 5) ? pen : 0;
*p++ = BIT(gfx, 6) ? pen : 0;
*p++ = BIT(gfx, 7) ? pen : 0;
}
}
ma+=160;
ma+=264;
}
return 0;
}
@ -114,31 +143,37 @@ uint32_t cdc721_state::screen_update(screen_device &screen, bitmap_ind16 &bitmap
static MACHINE_CONFIG_START( cdc721 )
// basic machine hardware
MCFG_CPU_ADD("maincpu", Z80, 4000000)
MCFG_CPU_PROGRAM_MAP(cdc721_mem)
MCFG_CPU_IO_MAP(cdc721_io)
MCFG_CPU_PROGRAM_MAP(mem_map)
MCFG_CPU_IO_MAP(io_map)
/* video hardware */
MCFG_SCREEN_ADD("screen", RASTER)
MCFG_SCREEN_REFRESH_RATE(60)
MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(2500)) /* not accurate */
MCFG_SCREEN_UPDATE_DRIVER(cdc721_state, screen_update)
MCFG_SCREEN_SIZE(640, 240)
MCFG_SCREEN_VISIBLE_AREA(0, 639, 0, 239)
MCFG_SCREEN_SIZE(640, 480)
MCFG_SCREEN_VISIBLE_AREA(0, 639, 0, 479)
MCFG_SCREEN_PALETTE("palette")
MCFG_PALETTE_ADD("palette", 3)
MCFG_PALETTE_INIT_OWNER(cdc721_state, cdc721)
MCFG_GFXDECODE_ADD("gfxdecode", "palette", cdc721)
MCFG_DEVICE_ADD("crtc", TMS9927, 2000000) // clock guess
MCFG_TMS9927_CHAR_WIDTH(8)
MACHINE_CONFIG_END
ROM_START( cdc721 )
ROM_REGION( 0x6000, "maincpu", 0 )
ROM_LOAD( "66315359", 0x0000, 0x2000, CRC(20ff3eb4) SHA1(5f15cb14893d75a46dc66d3042356bb054d632c2) )
ROM_LOAD( "66315361", 0x2000, 0x2000, CRC(21d59d09) SHA1(9c087537d68c600ddf1eb9b009cf458231c279f4) )
ROM_LOAD( "66315360", 0x4000, 0x1000, CRC(feaa0fc5) SHA1(f06196553a1f10c07b2f7e495823daf7ea26edee) ) // rom @ 4000
ROM_LOAD( "66307828", 0x5000, 0x1000, CRC(ac97136f) SHA1(0d280e1aa4b9502bd390d260f83af19bf24905cd) ) // keyboard
ROM_REGION( 0x15000, "maincpu", 0 )
ROM_LOAD( "66315359", 0x10000, 0x2000, CRC(20ff3eb4) SHA1(5f15cb14893d75a46dc66d3042356bb054d632c2) )
ROM_LOAD( "66315361", 0x12000, 0x2000, CRC(21d59d09) SHA1(9c087537d68c600ddf1eb9b009cf458231c279f4) )
ROM_LOAD( "66315360", 0x14000, 0x1000, CRC(feaa0fc5) SHA1(f06196553a1f10c07b2f7e495823daf7ea26edee) )
//ROM_FILL(0x14157,1,0xe0)
ROM_REGION( 0x1000, "keyboard", 0 )
ROM_LOAD( "66307828", 0x0000, 0x1000, CRC(ac97136f) SHA1(0d280e1aa4b9502bd390d260f83af19bf24905cd) ) // keyboard lookup
ROM_REGION( 0x1000, "chargen", 0 )
ROM_LOAD( "66315039", 0x0000, 0x1000, CRC(5c9aa968) SHA1(3ec7c5f25562579e6ed3fda7562428ff5e6b9550) ) // chargen
ROM_LOAD( "66315039", 0x0000, 0x1000, CRC(5c9aa968) SHA1(3ec7c5f25562579e6ed3fda7562428ff5e6b9550) )
ROM_END
COMP( 1981, cdc721, 0, 0, cdc721, cdc721, cdc721_state, 0, "Control Data Corporation", "CDC721 Terminal", MACHINE_NOT_WORKING | MACHINE_NO_SOUND_HW )
COMP( 1981, cdc721, 0, 0, cdc721, cdc721, cdc721_state, init, "Control Data Corporation", "CDC721 Terminal", MACHINE_NOT_WORKING | MACHINE_NO_SOUND_HW )