Add new files for Prophet-600 (nw)

This commit is contained in:
arbee 2016-01-09 19:12:45 -05:00
parent fcfeae0220
commit 6c18ce2c95
2 changed files with 269 additions and 0 deletions

View File

@ -0,0 +1,234 @@
// license:BSD-3-Clause
// copyright-holders:R. Belmont
/***************************************************************************
prophet600.cpp - Sequential Circuits Prophet-600, designed by Dave Smith
This was the first commercial synthesizer with built-in MIDI.
Skeleton driver by R. Belmont
Hardware:
CPU: Z80 CPU + 8253 PIT + 6850 UART
Memory map:
0x0000-0x1fff: ROM
0x2000-0x27ff: RAM 1
0x3000-0x37ff: RAM 2
0x4000-0x4001: DAC for CV/gate drive
0x6000-0x6001: 6850 writes
0xe000-0xe001: 6850 reads
I/O map:
00-03: 8253 PIT
Info:
- Prophet 600 Technical Manual
- https://github.com/gligli/p600fw - GPLv3 licensed complete replacement firmware
for the Prophet 600, but written in C and runs on an AVR that replaces the original
Z80.
***************************************************************************/
#include "emu.h"
#include "machine/clock.h"
#include "cpu/z80/z80.h"
#include "bus/midi/midi.h"
#include "machine/6850acia.h"
#include "machine/pit8253.h"
#include "prophet600.lh"
#define MAINCPU_TAG "z80"
#define PIT_TAG "pit"
#define UART_TAG "uart"
class prophet600_state : public driver_device
{
public:
prophet600_state(const machine_config &mconfig, device_type type, const char *tag)
: driver_device(mconfig, type, tag),
m_maincpu(*this, MAINCPU_TAG),
m_acia(*this, UART_TAG),
m_dac(0),
m_scanrow(0),
m_comparitor(0)
{ }
required_device<cpu_device> m_maincpu;
required_device<acia6850_device> m_acia;
DECLARE_DRIVER_INIT(prophet600);
DECLARE_WRITE_LINE_MEMBER( pit_tick_w );
DECLARE_WRITE_LINE_MEMBER( acia_irq_w );
DECLARE_WRITE_LINE_MEMBER( acia_clock_w );
DECLARE_WRITE8_MEMBER(dac_w);
DECLARE_WRITE8_MEMBER(scanrow_w);
DECLARE_WRITE8_MEMBER(led_w);
DECLARE_READ8_MEMBER(scan_r);
DECLARE_WRITE8_MEMBER(potmux_w);
DECLARE_READ8_MEMBER(comparitor_r);
DECLARE_WRITE8_MEMBER(mask_w);
DECLARE_WRITE8_MEMBER(cv_w);
DECLARE_WRITE8_MEMBER(gate_w);
private:
UINT16 m_dac;
UINT8 m_scanrow;
UINT8 m_comparitor;
};
WRITE_LINE_MEMBER( prophet600_state::pit_tick_w )
{
m_maincpu->set_input_line(INPUT_LINE_IRQ0, state);
}
WRITE_LINE_MEMBER( prophet600_state::acia_irq_w )
{
}
WRITE_LINE_MEMBER( prophet600_state::acia_clock_w )
{
m_acia->write_txc(state);
m_acia->write_rxc(state);
}
WRITE8_MEMBER( prophet600_state::dac_w )
{
if (offset)
{
m_dac &= 0xff;
m_dac |= (data<<8);
return;
}
m_dac &= 0xff00;
m_dac |= data;
}
// also selects LEDs and keyboard keys to check
WRITE8_MEMBER(prophet600_state::scanrow_w)
{
m_scanrow = data;
}
// scanrow 0x10 = LEDs, 0x20 = 7-segment #1, 0x40 = 7-segment #2
// LEDs in row 0x10 are Seq1=0, Seq2=1, ArpUD=2, ArpAssign=3, Preset=4, Record=5, ToTape=6, FromTape=7
WRITE8_MEMBER(prophet600_state::led_w)
{
if (m_scanrow == 0x10)
{
}
else if (m_scanrow == 0x20)
{
output_set_digit_value(0, data);
}
else if (m_scanrow == 0x40)
{
output_set_digit_value(1, data);
}
}
READ8_MEMBER(prophet600_state::scan_r)
{
return 0;
}
WRITE8_MEMBER(prophet600_state::mask_w)
{
}
/*
CV destinations:
Osc1A=0, Osc2A, Osc3A, Osc4A, Osc5A, Osc6A,
Osc1B, Osc2B, Osc3B, Osc4B, Osc5B, Osc6B,
Fil1, Fil2, Fil3, Fil4, Fil5, Fil6,
Amp1, Amp2, Amp3, Amp4, Amp5, Amp6,
PModOscB=24, VolA, VolB, MVol, APW, ExtFil, Resonance, BPW
*/
WRITE8_MEMBER(prophet600_state::cv_w)
{
}
WRITE8_MEMBER(prophet600_state::gate_w)
{
}
/* Pots: Mixer=0,Cutoff=1,Resonance=2,FilEnvAmt=3,FilRel=4,FilSus=5,
FilDec=6,FilAtt=7,AmpRel=8,AmpSus=9,AmpDec=10,AmpAtt=11,
Glide=12,BPW=13,MVol=14,MTune=15,PitchWheel=16,ModWheel=22,
Speed,APW,PModFilEnv,LFOFreq,PModOscB,LFOAmt,FreqB,FreqA,FreqBFine
*/
WRITE8_MEMBER(prophet600_state::potmux_w)
{
}
READ8_MEMBER(prophet600_state::comparitor_r)
{
m_comparitor ^= 0x04;
return m_comparitor;
}
static ADDRESS_MAP_START( cpu_map, AS_PROGRAM, 8, prophet600_state )
AM_RANGE(0x0000, 0x1fff) AM_ROM AM_REGION(MAINCPU_TAG, 0)
AM_RANGE(0x2000, 0x27ff) AM_RAM
AM_RANGE(0x3000, 0x37ff) AM_RAM
AM_RANGE(0x4000, 0x4001) AM_WRITE(dac_w)
AM_RANGE(0x6000, 0x6000) AM_DEVWRITE(UART_TAG, acia6850_device, control_w)
AM_RANGE(0x6001, 0x6001) AM_DEVWRITE(UART_TAG, acia6850_device, data_w)
AM_RANGE(0xe000, 0xe000) AM_DEVREAD(UART_TAG, acia6850_device, status_r)
AM_RANGE(0xe001, 0xe001) AM_DEVREAD(UART_TAG, acia6850_device, data_r)
ADDRESS_MAP_END
static ADDRESS_MAP_START( io_map, AS_IO, 8, prophet600_state )
AM_RANGE(0x00, 0x03) AM_MIRROR(0xff00) AM_DEVREADWRITE(PIT_TAG, pit8253_device, read, write)
AM_RANGE(0x08, 0x08) AM_MIRROR(0xff00) AM_WRITE(scanrow_w)
AM_RANGE(0x09, 0x09) AM_MIRROR(0xff00) AM_READWRITE(comparitor_r, led_w)
AM_RANGE(0x0a, 0x0a) AM_MIRROR(0xff00) AM_READWRITE(scan_r, potmux_w)
AM_RANGE(0x0b, 0x0b) AM_MIRROR(0xff00) AM_WRITE(gate_w)
AM_RANGE(0x0d, 0x0d) AM_MIRROR(0xff00) AM_WRITE(cv_w)
AM_RANGE(0x0e, 0x0e) AM_MIRROR(0xff00) AM_WRITE(mask_w)
ADDRESS_MAP_END
DRIVER_INIT_MEMBER(prophet600_state, prophet600)
{
}
// master crystal is 8 MHz, all clocks derived from there
static MACHINE_CONFIG_START( prophet600, prophet600_state )
MCFG_CPU_ADD(MAINCPU_TAG, Z80, XTAL_8MHz/2)
MCFG_CPU_PROGRAM_MAP(cpu_map)
MCFG_CPU_IO_MAP(io_map)
MCFG_DEFAULT_LAYOUT( layout_prophet600 )
MCFG_DEVICE_ADD(PIT_TAG, PIT8253, XTAL_8MHz/4)
MCFG_PIT8253_CLK0(XTAL_8MHz/4)
MCFG_PIT8253_OUT0_HANDLER(WRITELINE(prophet600_state, pit_tick_w))
MCFG_DEVICE_ADD(UART_TAG, ACIA6850, 0)
MCFG_ACIA6850_TXD_HANDLER(DEVWRITELINE("mdout", midi_port_device, write_txd))
MCFG_ACIA6850_IRQ_HANDLER(WRITELINE(prophet600_state, acia_irq_w))
MCFG_MIDI_PORT_ADD("mdin", midiin_slot, "midiin")
MCFG_MIDI_RX_HANDLER(DEVWRITELINE(UART_TAG, acia6850_device, write_rxd))
MCFG_MIDI_PORT_ADD("mdout", midiout_slot, "midiout")
MCFG_DEVICE_ADD("acia_clock", CLOCK, XTAL_8MHz/16) // 500kHz = 16 times the MIDI rate
MCFG_CLOCK_SIGNAL_HANDLER(WRITELINE(prophet600_state, acia_clock_w))
MACHINE_CONFIG_END
static INPUT_PORTS_START( prophet600 )
INPUT_PORTS_END
ROM_START( prpht600 )
ROM_REGION(0x2000, MAINCPU_TAG, 0)
ROM_LOAD( "p600.bin", 0x000000, 0x002000, CRC(78e3f048) SHA1(61548b6de3d9b5c0ae76f8e751ece0b57de17118) )
ROM_END
CONS( 1983, prpht600, 0, 0, prophet600, prophet600, prophet600_state, prophet600, "Sequential Circuits", "Prophet-600", MACHINE_NOT_WORKING|MACHINE_NO_SOUND )

View File

@ -0,0 +1,35 @@
<!-- mirage.lay -->
<!-- 2016-01-09: Initial version. [R. Belmont] -->
<mamelayout version="2">
<element name="digit" defstate="0">
<led7seg>
<color red="0.85" green="0.10" blue="0.10" />
</led7seg>
</element>
<element name="background">
<rect>
<bounds left="0" top="0" right="1" bottom="1" />
<color red="0.0" green="0.0" blue="0.0" />
</rect>
</element>
<view name="Default Layout">
<!-- Background -->
<backdrop element="background">
<bounds left="0" top="0" right="42" bottom="28" />
</backdrop>
<!-- LEDs -->
<bezel name="digit0" element="digit">
<bounds left="2" top="0" right="20" bottom="23" />
</bezel>
<bezel name="digit1" element="digit">
<bounds left="22" top="0" right="40" bottom="23" />
</bezel>
</view>
</mamelayout>