namco/namcos21_c67.cpp: Tidied up transfer_dsp_data a little.

This commit is contained in:
Vas Crabb 2022-10-02 11:31:19 +11:00
parent c33fcbd66d
commit 7b0dc1f2ae
2 changed files with 63 additions and 64 deletions

View File

@ -34,14 +34,14 @@ namcos21_dsp_c67_device::namcos21_dsp_c67_device(const machine_config &mconfig,
void namcos21_dsp_c67_device::device_start()
{
m_dspram16.resize(0x10000/2); // 0x8000 16-bit words
std::fill(std::begin(m_dspram16), std::end(m_dspram16), 0x0000);
m_dspram16 = std::make_unique<uint16_t []>(0x10000/2); // 0x8000 16-bit words
std::fill_n(m_dspram16.get(), 0x10000/2, 0x0000);
m_yield_hack_cb.resolve_safe();
m_pointram = std::make_unique<uint8_t[]>(PTRAM_SIZE);
m_mpDspState = std::make_unique<dsp_state>();
save_item(NAME(m_dspram16));
save_pointer(NAME(m_dspram16), 0x10000/2);
save_item(NAME(m_mpDspState->masterSourceAddr));
save_item(NAME(m_mpDspState->slaveInputBuffer));
@ -213,15 +213,14 @@ void namcos21_dsp_c67_device::transmit_word_to_slave(uint16_t data)
void namcos21_dsp_c67_device::transfer_dsp_data()
{
uint16_t addr = m_mpDspState->masterSourceAddr;
int mode = addr&0x8000;
bool const mode = BIT(addr, 15);
addr &= 0x7fff;
if (addr)
{
for (;;)
{
int i;
uint16_t old = addr;
uint16_t code = m_dspram16[addr++];
uint16_t const old = addr;
uint16_t const code = m_dspram16[addr++];
if (code == 0xffff)
{
if (mode)
@ -241,13 +240,14 @@ void namcos21_dsp_c67_device::transfer_dsp_data()
return;
}
}
else if( mode==0 )
{ /* direct data transfer */
else if (!mode)
{
// direct data transfer
if (ENABLE_LOGGING) logerror("DATA TFR(0x%x)\n", code);
transmit_word_to_slave(code);
for( i=0; i<code; i++ )
for (int i = 0; i < code; i++)
{
uint16_t data = m_dspram16[addr++];
uint16_t const data = m_dspram16[addr++];
transmit_word_to_slave(data);
}
}
@ -255,18 +255,17 @@ void namcos21_dsp_c67_device::transfer_dsp_data()
{
if (ENABLE_LOGGING) logerror("HEADER TFR(0x%x)\n", code);
transmit_word_to_slave(code + 1);
for( i=0; i<code; i++ )
for (int i = 0; i < code; i++)
{
uint16_t data = m_dspram16[addr++];
uint16_t const data = m_dspram16[addr++];
transmit_word_to_slave(data);
}
}
else
{
int32_t masterAddr = read_pointrom_data(code);
if (ENABLE_LOGGING) logerror("OBJ TFR(0x%x)\n", code);
{
uint16_t len = m_dspram16[addr++];
int32_t masterAddr = read_pointrom_data(code);
uint16_t const len = m_dspram16[addr++];
for (;;)
{
int subAddr = read_pointrom_data(masterAddr++);
@ -276,22 +275,22 @@ void namcos21_dsp_c67_device::transfer_dsp_data()
}
else
{
int primWords = (uint16_t)read_pointrom_data(subAddr++);
int const primWords = (uint16_t)read_pointrom_data(subAddr++);
// TODO: this function causes an IDC overflow in Solvalou, something else failed prior to that?
// In Header TFR when bad parameters happens there's a suspicious 0x000f 0x0003 as first two words,
// maybe it's supposed to have a different length there ...
// cfr: object code 0x17 in service mode
if (primWords > 2)
{
transmit_word_to_slave(0); /* pad1 */
transmit_word_to_slave(0); // pad1
transmit_word_to_slave(len + 1);
for( i=0; i<len; i++ )
{ /* transform */
for (int i = 0; i < len; i++)
{ // transform
transmit_word_to_slave(m_dspram16[addr + i]);
}
transmit_word_to_slave(0); /* pad2 */
transmit_word_to_slave(0); // pad2
transmit_word_to_slave(primWords + 1);
for( i=0; i<primWords; i++ )
for (int i = 0; i < primWords; i++)
{
transmit_word_to_slave((uint16_t)read_pointrom_data(subAddr + i));
}
@ -301,11 +300,10 @@ void namcos21_dsp_c67_device::transfer_dsp_data()
if (ENABLE_LOGGING) logerror("TFR NOP?\n");
}
}
} /* for(;;) */
} // for (;;)
addr += len;
}
}
} /* for(;;) */
} // for(;;)
}
}

View File

@ -1,7 +1,7 @@
// license:BSD-3-Clause
// copyright-holders:David Haywood
#ifndef MAME_VIDEO_NAMCOS21_DSP_C67_H
#define MAME_VIDEO_NAMCOS21_DSP_C67_H
#ifndef MAME_NAMCO_NAMCOS21_DSP_C67_H
#define MAME_NAMCO_NAMCOS21_DSP_C67_H
#pragma once
@ -9,6 +9,7 @@
#include "namcos21_3d.h"
#include <algorithm>
#include <memory>
#define ENABLE_LOGGING 0
@ -81,7 +82,7 @@ private:
required_device<cpu_device> m_c67master;
required_device_array<cpu_device,4> m_c67slave;
required_region_ptr<int32_t> m_ptrom24;
std::vector<uint16_t> m_dspram16;
std::unique_ptr<uint16_t []> m_dspram16;
required_shared_ptr<uint16_t> m_master_dsp_ram;
@ -153,4 +154,4 @@ private:
DECLARE_DEVICE_TYPE(NAMCOS21_DSP_C67, namcos21_dsp_c67_device)
#endif // MAME_VIDEO_NAMCOS21_DSP_C67_H
#endif // MAME_NAMCO_NAMCOS21_DSP_C67_H