dbox: added 29F800B flash boot device

This commit is contained in:
Joakim Larsson Edstrom 2017-09-04 17:12:20 +02:00
parent 4f56d21643
commit c880308195
3 changed files with 227 additions and 41 deletions

View File

@ -87,6 +87,7 @@ DEFINE_DEVICE_TYPE(AMD_29F040, amd_29f040_device, "amd_29f
DEFINE_DEVICE_TYPE(AMD_29F080, amd_29f080_device, "amd_29f080", "AMD 29F080 Flash")
DEFINE_DEVICE_TYPE(AMD_29F400T, amd_29f400t_device, "amd_29f400t", "AMD 29F400T Flash")
DEFINE_DEVICE_TYPE(AMD_29F800T, amd_29f800t_device, "amd_29f800t", "AMD 29F800T Flash")
DEFINE_DEVICE_TYPE(AMD_29F800B_16BIT, amd_29f800b_16bit_device, "amd_29f800b_16bit", "AMD 29F800B Flash used in 16 bit mode")
DEFINE_DEVICE_TYPE(AMD_29LV200T, amd_29lv200t_device, "amd_29lv200t", "AMD 29LV200T Flash")
DEFINE_DEVICE_TYPE(FUJITSU_29F160T, fujitsu_29f160t_device, "fujitsu_29f160t", "Fujitsu 29F160T Flash")
DEFINE_DEVICE_TYPE(FUJITSU_29F016A, fujitsu_29f016a_device, "fujitsu_29f016a", "Fujitsu 29F016A Flash")
@ -204,6 +205,13 @@ intelfsh_device::intelfsh_device(const machine_config &mconfig, device_type type
m_device_id = 0xda;
m_top_boot_sector = true;
break;
case FLASH_AMD_29F800B_16BIT:
m_bits = 16;
m_size = 0x100000;
m_maker_id = MFG_AMD;
m_device_id = 0x2258;
m_top_boot_sector = false;
break;
case FLASH_AMD_29LV200T:
m_bits = 8;
m_size = 0x40000;
@ -387,6 +395,9 @@ amd_29f400t_device::amd_29f400t_device(const machine_config &mconfig, const char
amd_29f800t_device::amd_29f800t_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock)
: intelfsh8_device(mconfig, AMD_29F800T, tag, owner, clock, FLASH_AMD_29F800T) { }
amd_29f800b_16bit_device::amd_29f800b_16bit_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock)
: intelfsh16_device(mconfig, AMD_29F800B_16BIT, tag, owner, clock, FLASH_AMD_29F800B_16BIT) { }
amd_29lv200t_device::amd_29lv200t_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock)
: intelfsh8_device(mconfig, AMD_29LV200T, tag, owner, clock, FLASH_AMD_29LV200T) { }
@ -638,7 +649,7 @@ uint32_t intelfsh_device::read_full(uint32_t address)
break;
}
//logerror( "intelflash_read( %08x ) %08x\n", address, data );
//if (m_flash_mode != FM_NORMAL) logerror( "intelflash_read( %08x ) %08x\n", address, data );
return data;
}

View File

@ -44,6 +44,9 @@
#define MCFG_AMD_29F800T_ADD(_tag) \
MCFG_DEVICE_ADD(_tag, AMD_29F800T, 0)
#define MCFG_AMD_29F800B_16BIT_ADD(_tag) \
MCFG_DEVICE_ADD(_tag, AMD_29F800B_16BIT, 0)
#define MCFG_AMD_29LV200T_ADD(_tag) \
MCFG_DEVICE_ADD(_tag, AMD_29LV200T, 0)
@ -130,6 +133,7 @@ public:
FLASH_AMD_29F080,
FLASH_AMD_29F400T,
FLASH_AMD_29F800T,
FLASH_AMD_29F800B_16BIT,
FLASH_AMD_29LV200T,
FLASH_SHARP_LH28F016S,
FLASH_SHARP_LH28F016S_16BIT,
@ -302,6 +306,12 @@ public:
amd_29f800t_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock);
};
class amd_29f800b_16bit_device : public intelfsh16_device
{
public:
amd_29f800b_16bit_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock);
};
class amd_29lv200t_device : public intelfsh8_device
{
public:
@ -434,6 +444,7 @@ DECLARE_DEVICE_TYPE(AMD_29F040, amd_29f040_device)
DECLARE_DEVICE_TYPE(AMD_29F080, amd_29f080_device)
DECLARE_DEVICE_TYPE(AMD_29F400T, amd_29f400t_device)
DECLARE_DEVICE_TYPE(AMD_29F800T, amd_29f800t_device)
DECLARE_DEVICE_TYPE(AMD_29F800B_16BIT, amd_29f800b_16bit_device)
DECLARE_DEVICE_TYPE(AMD_29LV200T, amd_29lv200t_device)
DECLARE_DEVICE_TYPE(FUJITSU_29F160T, fujitsu_29f160t_device)
DECLARE_DEVICE_TYPE(FUJITSU_29F016A, fujitsu_29f016a_device)

View File

@ -9,7 +9,7 @@
* ___ | | ________ ________ |
* | | |_______________| | | | | |
* | | | FLASH | | FLASH | |
* | | | 29F800 | | 29F800 | |
* | | | 29F800B| | 29F800B| |
* | | | | | | |
* | | ____________ | 1Mb | | 1Mb | |
* | | | | | | | | |
@ -48,6 +48,7 @@
*
* Misc links about Nokia Multimedia Division and this board:
* http://www.siliconinvestor.com/readmsg.aspx?msgid=5097482
* http://www.sat-digest.com/SatXpress/Digital/MM/Mediamaster.htm
* http://www.telecompaper.com/news/beta-research-publishes-dbox-specifications--163443
* https://de.wikipedia.org/wiki/D-box
* http://dvb2000.org/dvb2000/
@ -56,7 +57,7 @@
*--------------
* - Serial port on the back runs at 19200 at issues modem commands when attached to terminal
* - It is possible to attach a BDM emulator and retrieve the ROM through it.
* - It is possible to flash new firmware by adding jumper XP06 (under the modem board)
* - It is possible to flash new firmware through BDM by adding jumper XP06 (under the modem board)
* - The bootstrap is based on RTXC 3.2g RTOS
* - The bootstrap jumps to firmware from 0xb82 to RAM at 0x800000
*
@ -72,12 +73,30 @@
* Lucent AV6220A MPEG2 demultiplexer w. crypto interface
* CI Common Interface module
* LSI L2A0371 Tuner
* 2 x 29F800-90 (2Mb FLASH)
* 2 x 29F800B-90 (2Mb FLASH) - schematics shows a 29F400 as second device so firmware checks device ID
* 2 x 42260-60 (1Mb DRAM)
* Siemens SDA5708 dot matrix display, SPI like connection
* - http://arduinotehniq.blogspot.se/2015/07/sda5708-display-8-character-7x5-dot.html
* - charset stored at 0x808404 to 0x808780, 7 bytes per character
*
* Known Nokia Receivers
* -----------------------------
* D-box SCART, built-in Irdeto CAM, modem, SCSI
* 9200 SCART, SCSI
* 9500 SCART, built-in Irdeto CAM, modem, SCSI
* 9600 SCART
* 9602 SCART, modem
* 9610 SCART, modem, SCSI
* 8200 RF, SCSI
* 8500 RF, built-in Irdeto CAM, modem, SCSI
* 8600 RF
*
* Known board revs and changes
* -----------------------------
* Main Board 55 31893-11 DVB 9500 S
* Main Board 55 31893-33 DVB 9500 S - GALs named after functions in schematics
* Main Board 55 31893-46 D-box - OE* IP09 tied to GND, only one flash IP02
* Main Board 55 31893-89 DVB 9500 S - OE* IP09 tied to GND
*
* Address Map
* --------------------------------------------------------------------------
@ -330,7 +349,7 @@
*
* Address map decoding
* --------------------
* IP06 GAL16V8 - DRAM
* IP06 GAL16V8 - DRAM-PS8V0.9
* pin signal connected to
* 1 Q V-FIFO-CLK inverted SCSI_CLK, origin to be found
* 2 I1 SCSI_CLK
@ -341,22 +360,39 @@
* 7 I6 BG 68340 pin 101 IP01
* 8 I7 SIZ0 68340 pin 105 IP01
* 9 I8 R/W 68340 pin 107 IP01
* 11 I9/OE* GND 68340 pin 107 IP01 via an 100R resistor
* 19 O0 FC2 68340 pin 71 IP01
* 18 O1 I8 GAL168V pin 9 IP07 SCSI GAL
* 17 O2 nc
* 16 O3 RAS1 514260 pin 14 IP10-11 512KB DRAM each (IP11 is empty socket)
* 15 O4 LCAS 514260 pin 29 IP09-11 512KB DRAM each (IP11 is empty socket)
* 14 O5 UCAS 514260 pin 28 IP09-11 512KB DRAM each (IP11 is empty socket)
* 13 O6 RAS0 514260 pin 14 IP09 512KB DRAM
* 12 O7 I2 GAL16V8 pin 3 IP07 SCSI GAL (ANDed with !CS1) DMA_REQ
* I1 GAL16V8 pin 2 IP08 LOGC GAL (ANDed with !CS1) DMA_REQ
* G1 74257 pin 1 IP04-05 MUXes
* 11 I9/OE* GND via an 100R resistor
* 12 O0 FC2 68340 pin 71 IP01
* 13 O1 I8 GAL168V pin 9 IP07 SCSI GAL
* 14 O2 nc
* 15 O3 RAS1 514260 pin 14 IP10-11 512KB DRAM each (IP11 is empty socket)
* 16 O4 LCAS 514260 pin 29 IP09-11 512KB DRAM each (IP11 is empty socket)
* 17 O5 UCAS 514260 pin 28 IP09-11 512KB DRAM each (IP11 is empty socket)
* 18 O6 RAS0 514260 pin 14 IP09 512KB DRAM
* 19 O7 I2 GAL16V8 pin 3 IP07 SCSI GAL (ANDed with !CS1) DMA_REQ
* +I1 GAL16V8 pin 2 IP08 LOGC GAL (ANDed with !CS1) DMA_REQ
* +G1 74257 pin 1 IP04-05 MUXes
*
* Identified low level drivers in firmware
* ----------------------------------------
* 800420..80046C : Some PORT A serialisation routine for the
* Siemens SDA5708 dot matrix display
* IP07 GAL16V8 - SCSI-PS8V0.8
* pin signal connected to
* 1 Q V-FIFO-CLK inverted SCSI_CLK, origin to be found
* 2 I1 R/W 68340 pin 107 IP01
* 3 I2 DMA_REQ
* 4 I3 Q 7474 pin 5 IP25
* 5 I4 DACK1 68340 pin 15
* 6 I5 D0 74138 pin 15 IP12
* 7 I6 !BG 7404<-68340 pin 101 IP01 Inverted Bus Grant
* 8 I7 3 7408 pin 3 IP23 OE for IP10
* 9 I8 O1 GAL16V pin 18 IP06 DRAM GAL
* 11 I9/OE* GND via an 100R resistor
* 12 O0 DREQ1 68340 pin 16
* 13 O1 WE 514260 pin 13 IP10 512KB DRAM
* 14 O2 DMA_ACK
* 15 O3 CS_SCSI
* 16 O4 RD_SCSI
* 17 O5 WE 514260 pin 13 IP11 empty socket
* 18 O6 WR_SCSI
* 19 O7 MWE
* +WE 514260 pin 13 IP09 512KB DRAM
*
* Interrupt sources
* ----------------------------------------------------------
@ -368,30 +404,24 @@
* IRQ5 CAM module INT
* IRQ3 Audio/Video INT
*
* ----------------------------------------------------------
*
* DMAC Channel Assignments
* ----------------------------------------------------------
* Channel Device
* ----------------------------------------------------------
* ----------------------------------------------------------
*
* TODO:
* - Dump/understand the address decoder GAL:s IP06-IP08 (3 x 16V8)
* - Setup a working address map
* - Fix debug terminal
* - TBC
* - write demuxer
*
****************************************************************************/
#include "emu.h"
#include "machine/68340.h"
#include "machine/intelfsh.h"
#include "video/sda5708.h"
#include "machine/latch8.h" // IP16
#include "sda5708.lh"
#include "bus/rs232/rs232.h"
//**************************************************************************
// MACROS / CONSTANTS
//**************************************************************************
@ -399,15 +429,17 @@
//#define LOG_GENERAL (1U << 0) // Already defined in logmacro.h
#define LOG_SETUP (1U << 1)
#define LOG_DISPLAY (1U << 2)
#define LOG_FLASH (1U << 3)
//#define VERBOSE (LOG_GENERAL|LOG_SETUP|LOG_DISPLAY)
//#define LOG_OUTPUT_FUNC printf
#define VERBOSE (LOG_FLASH)
#define LOG_OUTPUT_FUNC printf
#include "logmacro.h"
//#define LOG(...) LOGMASKED(LOG_GENERAL, __VA_ARGS__) // Already defined in logmacro.h
#define LOGSETUP(...) LOGMASKED(LOG_SETUP, __VA_ARGS__)
#define LOGDISPLAY(...) LOGMASKED(LOG_DISPLAY, __VA_ARGS__)
#define LOGFLASH(...) LOGMASKED(LOG_FLASH, __VA_ARGS__)
#ifdef _MSC_VER
#define FUNCNAME __func__
@ -415,6 +447,8 @@
#define FUNCNAME __PRETTY_FUNCTION__
#endif
#define LOCALFLASH 0 // 1 = local flash rom implementation 0 = intelflash_device
class dbox_state : public driver_device
{
public:
@ -429,12 +463,35 @@ class dbox_state : public driver_device
required_device<latch8_device> m_ip16_74259;
virtual void machine_reset() override;
virtual void machine_start () override;
DECLARE_DRIVER_INIT(dbox);
DECLARE_WRITE8_MEMBER (sda5708_reset);
DECLARE_WRITE8_MEMBER (sda5708_clk);
DECLARE_WRITE8_MEMBER(sda5708_reset);
DECLARE_WRITE8_MEMBER(sda5708_clk);
DECLARE_WRITE8_MEMBER(write_pa);
#if LOCALFLASH
DECLARE_READ16_MEMBER (sysflash_r);
DECLARE_WRITE16_MEMBER (sysflash_w);
private:
uint16_t *m_sysflash;
uint32_t m_sf_mode;
uint32_t m_sf_state;
#endif
};
void dbox_state::machine_start()
{
LOG("%s\n", FUNCNAME);
#if LOCALFLASH
save_pointer (NAME (m_sysflash), sizeof(m_sysflash));
m_sysflash = (uint16_t*)(memregion ("flash")->base());
m_sf_mode = 0;
m_sf_state = 0;
#endif
}
void dbox_state::machine_reset()
{
LOG("%s\n", FUNCNAME);
@ -458,13 +515,96 @@ WRITE8_MEMBER (dbox_state::write_pa){
m_display->load_w((0x04 & data) == 0 ? ASSERT_LINE : CLEAR_LINE);
}
#if LOCALFLASH
/* Lcoal emulation of the 29F800B 8Mbit flashes if the intelflsh bugs, relies on a complete command cycle is done per device, not in parallell */
/* TODO: Make a flash device of this and support programming per sector and persistance, as settings etc may be stored in a 8Kb sector */
WRITE16_MEMBER (dbox_state::sysflash_w){
LOGFLASH("%s pc:%08x offset:%08x data:%08x mask:%08x\n", FUNCNAME, space.device().safe_pc(), offset, data, mem_mask);
/*Data bits DQ15DQ8 are dont cares for unlock and command cycles.*/
m_sf_state = ((m_sf_state << 8) & 0xffffff00) | (data & 0xff);
switch (m_sf_state)
{
case 0xf0:// Reset command, to get back to reading flash data
m_sf_mode = 0;
m_sf_state = 0;
LOGFLASH("- Reset command\n");
break;
case 0xaa: // Building a multi byte command
m_sf_mode = 1;
break;
case 0xaa55: // Building a multi byte command
case 0xaa55a0: // Program Data
case 0xaa5580: // Erase
case 0xaa5580aa: // Chip or Sector Erase
break;
case 0xaa5590: // Autoselect mode
m_sf_mode = 4;
m_sf_state = 0;
LOGFLASH("- Autoselect Mode\n");
break;
case 0xb0: // Erase Suspend Mode
m_sf_mode = 2;
m_sf_state = 0;
LOGFLASH("- Erase Suspend Mode\n");
break;
case 0x30: // Erase Resume Mode
m_sf_mode = 3;
m_sf_state = 0;
LOGFLASH("- Erase Resume Mode\n");
break;
}
}
READ16_MEMBER (dbox_state::sysflash_r){
if (m_sf_mode == 0)
{
return m_sysflash[offset];
}
else
{
if (m_sf_mode == 4)
{
switch (offset & 0xff)
{
case 0x00: LOGFLASH("- Manufacturer ID\n"); return 01; break; // Manufacturer ID
// case 0x01: LOGFLASH("- Device ID\n"); return 0x22d6; break; // Device ID (Top Boot Block) 29F800TA
case 0x01: LOGFLASH("- Device ID\n"); return 0x2258; break; // Device ID (Bottom Boot Block) 29F800BA
case 0x02: LOGFLASH("- Sector %02x protection: 1 (hardcoded)\n", offset >> 12); return 01; break;
default: LOGFLASH(" - Unhandled Mode:%d State:%08x\n", m_sf_mode, m_sf_state);
}
}
}
return 0;
}
/* End of flash emulation */
#endif
static ADDRESS_MAP_START( dbox_map, AS_PROGRAM, 32, dbox_state )
AM_RANGE(0x000000, 0x0fffff) AM_ROM AM_REGION("maincpu", 0)
AM_RANGE(0x700000, 0x77ffff) AM_RAM // CS2
// AM_RANGE(0x780000, 0x7807ff) AM_RAM // CS3
// CS0 - bootrom
// 008004ee Address mask CS0 00000040, 003ffff5 (ffffffff) - Mask: 003fff00 FCM:0f DD:1 PS: 16-Bit
// 008004f8 Base address CS0 00000044, 0000005b (ffffffff) - Base: 00000000 BFC:05 WP:1 FTE:0 NCS:1 Valid: Yes
#if LOCALFLASH
AM_RANGE(0x000000, 0x3fffff) AM_ROM AM_READ16(sysflash_r, 0xffffffff) AM_REGION("flash", 0)
AM_RANGE(0x000000, 0x3fffff) AM_WRITE16(sysflash_w, 0xffffffff)
#else
AM_RANGE(0x000000, 0x3fffff) AM_DEVREADWRITE16("flash", intelfsh16_device, read, write, 0xffffffff)
#endif
// CS2 - CS demux
// 0000009a Address mask CS2 00000050, 00007fff (ffffffff) - Mask: 00007f00 FCM:0f DD:3 PS: External DSACK response
// 000000a2 Base address CS2 00000054, 00700003 (ffffffff) - Base: 00700000 BFC:00 WP:0 FTE:0 NCS:1 Valid: Yes
//AM_RANGE(0x700000, 0x77ffff)
// CS3 - 8 bit devices
// 000000aa Address mask CS3 00000058, 000007f2 (ffffffff) - Mask: 00000700 FCM:0f DD:0 PS: 8-bit
// 000000b2 Base address CS3 0000005c, 00780003 (ffffffff) - Base: 00780000 BFC:00 WP:0 FTE:0 NCS:1 Valid: Yes
// AM_RANGE(0x780000, 0x7807ff)
AM_RANGE(0x780100, 0x7801ff) AM_WRITE8(sda5708_reset, 0xffffffff)
AM_RANGE(0x780600, 0x7806ff) AM_WRITE8(sda5708_clk, 0xffffffff)
AM_RANGE(0x800000, 0x8fffff) AM_RAM // CS1
// CS1 - RAM area
// 0000008a Address mask CS1 00000048, 003ffff5 (ffffffff) - Mask: 003fff00 FCM:0f DD:1 PS: 16-Bit
// 00000092 Base address CS1 0000004c, 00800003 (ffffffff) - Base: 00800000 BFC:00 WP:0 FTE:0 NCS:1 Valid: Yes
AM_RANGE(0x800000, 0xcfffff) AM_RAM
ADDRESS_MAP_END
/* Input ports */
@ -481,6 +621,22 @@ static MACHINE_CONFIG_START( dbox )
//MCFG_MC68340_TOUT2_OUTPUT_CB(DEVWRITELINE("dcs", descrambler_device, txd_receiver))
//MCFG_MC68340_TGATE2_INPUT_CB(DEVREADLINE("dsc", descrambler_device, rxd_receiver))
#if 0
/* Configure the serial ports */
#define CHA ":rs232"
#define CHB ":modem"
MCFG_DEVICE_MODIFY("maincpu:serial")
MCFG_MC68681_A_TX_CALLBACK(DEVWRITELINE(CHA, rs232_port_device, write_txd))
MCFG_MC68681_B_TX_CALLBACK(DEVWRITELINE(CHB, rs232_port_device, write_txd))
MCFG_RS232_PORT_ADD (CHA, default_rs232_devices, "terminal")
MCFG_RS232_RXD_HANDLER (DEVWRITELINE (":maincpu:serial", m68340_serial, rx_a_w))
MCFG_RS232_PORT_ADD (CHB, default_rs232_devices, "terminal")
MCFG_RS232_RXD_HANDLER (DEVWRITELINE (":maincpu:serial", m68340_serial, rx_b_w))
#endif
/* Add the boot flash */
MCFG_AMD_29F800B_16BIT_ADD("flash")
/* LED Matrix Display */
MCFG_SDA5708_ADD("display")
MCFG_DEFAULT_LAYOUT(layout_sda5708)
@ -496,9 +652,17 @@ DRIVER_INIT_MEMBER(dbox_state, dbox)
// TODO: Figure out correct ROM address map
// TODO: Figure out what DVB2000 is doing
ROM_START( dbox )
ROM_REGION(0x1000000, "maincpu", 0)
// ROM_LOAD16_WORD( "dvb2000.bin", 0x000000, 0x08b742, CRC(5b21c455) SHA1(1e7654c37dfa65d1b8ac2469cdda82f91b47b3c7) )
ROM_LOAD16_WORD( "nokboot.bin", 0x000000, 0x020000, CRC(0ff53e1f) SHA1(52002ee22c032775dac383d408c44abe9244724f) )
ROM_REGION16_BE(0x400000, "flash", ROMREGION_ERASEFF)
ROM_DEFAULT_BIOS("b200uns")
ROM_SYSTEM_BIOS(0, "b200uns", "Nokia Bootloader B200uns")
ROMX_LOAD( "b200uns.bin", 0x000000, 0x020000, CRC(0ff53e1f) SHA1(52002ee22c032775dac383d408c44abe9244724f), ROM_BIOS(1) )
ROM_SYSTEM_BIOS(1, "b210uns", "Nokia Bootloader B210uns")
ROMX_LOAD( "b210uns.bin", 0x000000, 0x020000, CRC(e8de221c) SHA1(db6e20ae73b11e8051f389968803732bd73fc1e4), ROM_BIOS(2) )
ROM_SYSTEM_BIOS(2, "nbc106.bin", "Nokia Bootloader CI v1.06")
ROMX_LOAD( "bootCi106.bin", 0x000000, 0x020000, BAD_DUMP CRC(641762a9) SHA1(7c5233390cc66d3ddf4c730a3418ccfba1dc2905), ROM_BIOS(3) )
ROM_END
COMP( 1996, dbox, 0, 0, dbox, dbox, dbox_state, dbox, "Nokia Multimedia", "D-box 1, Kirsch gruppe", MACHINE_IS_SKELETON )