cdrom_file: classify. Could use more internal work, but it's a step

This commit is contained in:
Olivier Galibert 2022-04-01 11:36:41 +02:00
parent e818533b16
commit e4564eb99a
30 changed files with 2663 additions and 2947 deletions

View File

@ -45,8 +45,6 @@ end
MAME_DIR .. "src/lib/util/cdrom.h",
MAME_DIR .. "src/lib/util/chd.cpp",
MAME_DIR .. "src/lib/util/chd.h",
MAME_DIR .. "src/lib/util/chdcd.cpp",
MAME_DIR .. "src/lib/util/chdcd.h",
MAME_DIR .. "src/lib/util/chdcodec.cpp",
MAME_DIR .. "src/lib/util/chdcodec.h",
MAME_DIR .. "src/lib/util/client_http.hpp",

View File

@ -78,10 +78,10 @@ void mcd_isa_device::device_reset()
bool mcd_isa_device::read_sector(bool first)
{
uint32_t lba = msf_to_lba(m_readmsf);
uint32_t lba = cdrom_file::msf_to_lba(m_readmsf);
if(m_drvmode == DRV_MODE_CDDA)
{
if(cdrom_get_track_type(m_cdrom_handle, cdrom_get_track(m_cdrom_handle, lba)) == CD_TRACK_AUDIO)
if(m_cdrom_handle->get_track_type(m_cdrom_handle->get_track(lba)) == cdrom_file::CD_TRACK_AUDIO)
{
m_cdda->stop_audio();
m_cdda->set_cdrom(m_cdrom_handle);
@ -100,14 +100,14 @@ bool mcd_isa_device::read_sector(bool first)
return false;
}
m_cdda->stop_audio();
cdrom_read_data(m_cdrom_handle, lba - 150, m_buf, m_mode & 0x40 ? CD_TRACK_MODE1_RAW : CD_TRACK_MODE1);
m_cdrom_handle->read_data(lba - 150, m_buf, m_mode & 0x40 ? cdrom_file::CD_TRACK_MODE1_RAW : cdrom_file::CD_TRACK_MODE1);
if(m_mode & 0x40)
{
//correct the header
m_buf[12] = dec_2_bcd((m_readmsf >> 16) & 0xff);
m_buf[13] = dec_2_bcd((m_readmsf >> 8) & 0xff);
}
m_readmsf = lba_to_msf_alt(lba + 1);
m_readmsf = cdrom_file::lba_to_msf_alt(lba + 1);
m_buf_count = m_dmalen + 1;
m_buf_idx = 0;
m_data = true;
@ -272,9 +272,9 @@ void mcd_isa_device::cmd_w(uint8_t data)
case CMD_GET_INFO:
if(m_cdrom_handle)
{
uint32_t first = lba_to_msf(150), last = lba_to_msf(cdrom_get_track_start(m_cdrom_handle, 0xaa));
uint32_t first = cdrom_file::lba_to_msf(150), last = cdrom_file::lba_to_msf(m_cdrom_handle->get_track_start(0xaa));
m_cmdbuf[1] = 1;
m_cmdbuf[2] = dec_2_bcd(cdrom_get_last_track(m_cdrom_handle));
m_cmdbuf[2] = dec_2_bcd(m_cdrom_handle->get_last_track());
m_cmdbuf[3] = (last >> 16) & 0xff;
m_cmdbuf[4] = (last >> 8) & 0xff;
m_cmdbuf[5] = last & 0xff;
@ -294,11 +294,11 @@ void mcd_isa_device::cmd_w(uint8_t data)
case CMD_GET_Q:
if(m_cdrom_handle)
{
int tracks = cdrom_get_last_track(m_cdrom_handle);
uint32_t start = cdrom_get_track_start(m_cdrom_handle, m_curtoctrk);
uint32_t len = lba_to_msf(cdrom_get_track_start(m_cdrom_handle, m_curtoctrk < (tracks - 1) ? m_curtoctrk + 1 : 0xaa) - start);
start = lba_to_msf(start);
m_cmdbuf[1] = (cdrom_get_adr_control(m_cdrom_handle, m_curtoctrk) << 4) & 0xf0;
int tracks = m_cdrom_handle->get_last_track();
uint32_t start = m_cdrom_handle->get_track_start(m_curtoctrk);
uint32_t len = cdrom_file::lba_to_msf(m_cdrom_handle->get_track_start(m_curtoctrk < (tracks - 1) ? m_curtoctrk + 1 : 0xaa) - start);
start = cdrom_file::lba_to_msf(start);
m_cmdbuf[1] = (m_cdrom_handle->get_adr_control(m_curtoctrk) << 4) & 0xf0;
m_cmdbuf[2] = 0; // track num except when reading toc
m_cmdbuf[3] = dec_2_bcd(m_curtoctrk + 1); // index
m_cmdbuf[4] = (len >> 16) & 0xff;

View File

@ -123,7 +123,7 @@ uint8_t nscsi_cdrom_device::scsi_get_data(int id, int pos)
const int extra_pos = (lba * bytes_per_block) % bytes_per_sector;
if(sector != cur_sector) {
cur_sector = sector;
if(!cdrom_read_data(cdrom, sector, sector_buffer, CD_TRACK_MODE1)) {
if(!cdrom->read_data(sector, sector_buffer, cdrom_file::CD_TRACK_MODE1)) {
LOG("CD READ ERROR sector %d!\n", sector);
std::fill_n(sector_buffer, sizeof(sector_buffer), 0);
}
@ -319,7 +319,7 @@ void nscsi_cdrom_device::scsi_command()
LOG("command READ CAPACITY\n");
// get the last used block on the disc
const u32 temp = cdrom_get_track_start(cdrom, 0xaa) * (bytes_per_sector / bytes_per_block) - 1;
const u32 temp = cdrom->get_track_start(0xaa) * (bytes_per_sector / bytes_per_block) - 1;
scsi_cmdbuf[0] = (temp>>24) & 0xff;
scsi_cmdbuf[1] = (temp>>16) & 0xff;
@ -365,7 +365,7 @@ void nscsi_cdrom_device::scsi_command()
scsi_cmdbuf[pos++] = 0x80; // WP, cache
// get the last used block on the disc
const u32 temp = cdrom_get_track_start(cdrom, 0xaa) * (bytes_per_sector / bytes_per_block) - 1;
const u32 temp = cdrom->get_track_start(0xaa) * (bytes_per_sector / bytes_per_block) - 1;
scsi_cmdbuf[pos++] = 0x08; // Block descriptor length
scsi_cmdbuf[pos++] = 0x00; // density code
@ -469,12 +469,12 @@ void nscsi_cdrom_device::scsi_command()
scsi_cmdbuf[3] = 1; // first track
scsi_cmdbuf[4] = 1; // number of sessions (TODO: session support for CHDv6)
scsi_cmdbuf[5] = 1; // first track in last session
scsi_cmdbuf[6] = cdrom_get_last_track(cdrom); // last track in last session
scsi_cmdbuf[6] = cdrom->get_last_track(); // last track in last session
scsi_cmdbuf[8] = 0; // CD-ROM, not XA
// lead in start time in MSF
{
u32 tstart = cdrom_get_track_start(cdrom, 0);
u32 tstart = cdrom->get_track_start(0);
tstart = to_msf(tstart + 150);
scsi_cmdbuf[16] = (tstart >> 24) & 0xff;
@ -483,7 +483,7 @@ void nscsi_cdrom_device::scsi_command()
scsi_cmdbuf[19] = (tstart & 0xff);
// lead-out start time in MSF
tstart = cdrom_get_track_start(cdrom, 0xaa);
tstart = cdrom->get_track_start(0xaa);
tstart = to_msf(tstart + 150);
scsi_cmdbuf[20] = (tstart >> 24) & 0xff;
@ -542,7 +542,7 @@ void nscsi_cdrom_device::scsi_command()
switch (format) {
case 0: {
int start_track = scsi_cmdbuf[6];
int end_track = cdrom_get_last_track(cdrom);
int end_track = cdrom->get_last_track();
int tracks;
if(start_track == 0)
@ -561,7 +561,7 @@ void nscsi_cdrom_device::scsi_command()
scsi_cmdbuf[pos++] = (len>>8) & 0xff;
scsi_cmdbuf[pos++] = (len & 0xff);
scsi_cmdbuf[pos++] = 1;
scsi_cmdbuf[pos++] = cdrom_get_last_track(cdrom);
scsi_cmdbuf[pos++] = cdrom->get_last_track();
if (start_track == 0)
start_track = 1;
@ -575,11 +575,11 @@ void nscsi_cdrom_device::scsi_command()
}
scsi_cmdbuf[pos++] = 0;
scsi_cmdbuf[pos++] = cdrom_get_adr_control(cdrom, cdrom_track);
scsi_cmdbuf[pos++] = cdrom->get_adr_control(cdrom_track);
scsi_cmdbuf[pos++] = track;
scsi_cmdbuf[pos++] = 0;
u32 tstart = cdrom_get_track_start(cdrom, cdrom_track);
u32 tstart = cdrom->get_track_start(cdrom_track);
if(msf)
tstart = to_msf(tstart+150);
@ -601,11 +601,11 @@ void nscsi_cdrom_device::scsi_command()
scsi_cmdbuf[pos++] = 1;
scsi_cmdbuf[pos++] = 0;
scsi_cmdbuf[pos++] = cdrom_get_adr_control(cdrom, 0);
scsi_cmdbuf[pos++] = cdrom->get_adr_control(0);
scsi_cmdbuf[pos++] = 1;
scsi_cmdbuf[pos++] = 0;
u32 tstart = cdrom_get_track_start(cdrom, 0);
u32 tstart = cdrom->get_track_start(0);
if (msf)
tstart = to_msf(tstart+150);

View File

@ -65,7 +65,7 @@ void cdrom_image_device::device_start()
chd_file *chd = machine().rom_load().get_disk_handle(owner()->tag() );
if( chd != nullptr )
{
m_cdrom_handle = cdrom_open( chd );
m_cdrom_handle = new cdrom_file( chd );
}
else
{
@ -76,7 +76,7 @@ void cdrom_image_device::device_start()
void cdrom_image_device::device_stop()
{
if (m_cdrom_handle)
cdrom_close(m_cdrom_handle);
delete m_cdrom_handle;
if( m_self_chd.opened() )
m_self_chd.close();
}
@ -87,7 +87,7 @@ image_init_result cdrom_image_device::call_load()
chd_file *chd = nullptr;
if (m_cdrom_handle)
cdrom_close(m_cdrom_handle);
delete m_cdrom_handle;
if (!loaded_through_softlist()) {
if (is_filetype("chd") && is_loaded()) {
@ -105,9 +105,9 @@ image_init_result cdrom_image_device::call_load()
/* open the CHD file */
if (chd) {
m_cdrom_handle = cdrom_open(chd);
m_cdrom_handle = new cdrom_file(chd);
} else {
m_cdrom_handle = cdrom_open(filename());
m_cdrom_handle = new cdrom_file(filename());
}
if (!m_cdrom_handle)
goto error;
@ -125,7 +125,7 @@ error:
void cdrom_image_device::call_unload()
{
assert(m_cdrom_handle);
cdrom_close(m_cdrom_handle);
delete m_cdrom_handle;
m_cdrom_handle = nullptr;
if( m_self_chd.opened() )
m_self_chd.close();

View File

@ -161,21 +161,21 @@ void akiko_device::device_reset()
else
{
// Arcade case
m_cdrom = cdrom_open(machine().rom_load().get_disk_handle(":cdrom"));
m_cdrom = new cdrom_file(machine().rom_load().get_disk_handle(":cdrom"));
}
/* create the TOC table */
if ( m_cdrom != nullptr && cdrom_get_last_track(m_cdrom) )
if ( m_cdrom != nullptr && m_cdrom->get_last_track() )
{
uint8_t *p;
int i, addrctrl = cdrom_get_adr_control( m_cdrom, 0 );
int i, addrctrl = m_cdrom->get_adr_control( 0 );
uint32_t discend;
discend = cdrom_get_track_start(m_cdrom,cdrom_get_last_track(m_cdrom)-1);
discend += cdrom_get_toc(m_cdrom)->tracks[cdrom_get_last_track(m_cdrom)-1].frames;
discend = lba_to_msf(discend);
discend = m_cdrom->get_track_start(m_cdrom->get_last_track()-1);
discend += m_cdrom->get_toc().tracks[m_cdrom->get_last_track()-1].frames;
discend = cdrom_file::lba_to_msf(discend);
m_cdrom_numtracks = cdrom_get_last_track(m_cdrom)+3;
m_cdrom_numtracks = m_cdrom->get_last_track()+3;
m_cdrom_toc = std::make_unique<uint8_t[]>(13*m_cdrom_numtracks);
memset( m_cdrom_toc.get(), 0, 13*m_cdrom_numtracks);
@ -187,7 +187,7 @@ void akiko_device::device_reset()
p += 13;
p[1] = 0x01;
p[3] = 0xa1; /* last track */
p[8] = cdrom_get_last_track(m_cdrom);
p[8] = m_cdrom->get_last_track();
p += 13;
p[1] = 0x01;
p[3] = 0xa2; /* disc end */
@ -196,12 +196,12 @@ void akiko_device::device_reset()
p[10] = discend & 0xff;
p += 13;
for( i = 0; i < cdrom_get_last_track(m_cdrom); i++ )
for( i = 0; i < m_cdrom->get_last_track(); i++ )
{
uint32_t trackpos = cdrom_get_track_start(m_cdrom,i);
uint32_t trackpos = m_cdrom->get_track_start(i);
trackpos = lba_to_msf(trackpos);
addrctrl = cdrom_get_adr_control( m_cdrom, i );
trackpos = cdrom_file::lba_to_msf(trackpos);
addrctrl = m_cdrom->get_adr_control( i );
p[1] = ((addrctrl & 0x0f) << 4) | ((addrctrl & 0xf0) >> 4);
p[3] = dec_2_bcd( i+1 );
@ -225,8 +225,8 @@ void akiko_device::device_stop()
{
if( m_cdrom )
{
cdrom_close(m_cdrom);
m_cdrom = (cdrom_file *)nullptr;
delete m_cdrom;
m_cdrom = nullptr;
}
}
}
@ -469,11 +469,11 @@ TIMER_CALLBACK_MEMBER(akiko_device::dma_proc)
if ( m_cdrom_readreqmask & ( 1 << index ) )
{
uint32_t track = cdrom_get_track( m_cdrom, m_cdrom_lba_cur );
uint32_t datasize;// = cdrom_get_toc(m_cdrom)->tracks[track].datasize;
uint32_t subsize = cdrom_get_toc( m_cdrom )->tracks[track].subsize;
uint32_t track = m_cdrom->get_track( m_cdrom_lba_cur );
uint32_t datasize;// = m_cdrom->get_toc().tracks[track].datasize;
uint32_t subsize = m_cdrom->get_toc().tracks[track].subsize;
uint32_t curmsf = lba_to_msf( m_cdrom_lba_cur );
uint32_t curmsf = cdrom_file::lba_to_msf( m_cdrom_lba_cur );
memset( buf, 0, 16 );
buf[3] = m_cdrom_lba_cur - m_cdrom_lba_start;
@ -485,7 +485,7 @@ TIMER_CALLBACK_MEMBER(akiko_device::dma_proc)
buf[15] = 0x01; /* mode1 */
datasize = 2048;
if ( !cdrom_read_data( m_cdrom, m_cdrom_lba_cur, &buf[16], CD_TRACK_MODE1 ) )
if ( !m_cdrom->read_data( m_cdrom_lba_cur, &buf[16], cdrom_file::CD_TRACK_MODE1 ) )
{
LOGWARN( "AKIKO: Read error trying to read sector %08x!\n", m_cdrom_lba_cur );
return;
@ -493,7 +493,7 @@ TIMER_CALLBACK_MEMBER(akiko_device::dma_proc)
if ( subsize )
{
if ( !cdrom_read_subcode( m_cdrom, m_cdrom_lba_cur, &buf[16+datasize] ) )
if ( !m_cdrom->read_subcode( m_cdrom_lba_cur, &buf[16+datasize] ) )
{
LOGWARN( "AKIKO: Read error trying to read subcode for sector %08x!\n", m_cdrom_lba_cur );
return;
@ -695,9 +695,9 @@ void akiko_device::update_cdrom()
LOGCD("AKIKO CD: Seek - start lba: %08x - end lba: %08x\n", startpos, endpos );
m_cdrom_track_index = 0;
for( i = 0; i < cdrom_get_last_track(m_cdrom); i++ )
for( i = 0; i < m_cdrom->get_last_track(); i++ )
{
if ( startpos <= cdrom_get_track_start( m_cdrom, i ) )
if ( startpos <= m_cdrom->get_track_start( i ) )
{
/* reset to 0 */
m_cdrom_track_index = i + 2;
@ -733,16 +733,16 @@ void akiko_device::update_cdrom()
uint32_t track;
int addrctrl;
track = cdrom_get_track(m_cdrom, lba);
addrctrl = cdrom_get_adr_control(m_cdrom, track);
track = m_cdrom->get_track(lba);
addrctrl = m_cdrom->get_adr_control(track);
resp[2] = 0x00;
resp[3] = ((addrctrl & 0x0f) << 4) | ((addrctrl & 0xf0) >> 4);
resp[4] = dec_2_bcd(track+1);
resp[5] = 0; /* index */
disk_pos = lba_to_msf(lba);
track_pos = lba_to_msf(lba - cdrom_get_track_start(m_cdrom, track));
disk_pos = cdrom_file::lba_to_msf(lba);
track_pos = cdrom_file::lba_to_msf(lba - m_cdrom->get_track_start(track));
/* track position */
resp[6] = (track_pos >> 16) & 0xff;

View File

@ -109,7 +109,7 @@ void spg290_cdservo_device::device_timer(emu_timer &timer, device_timer_id id, i
if (BIT(m_control0, 15)) // CDDA
{
cdrom_read_data(m_cdrom->get_cdrom_file(), m_cur_sector - 150 - SPG290_LEADIN_LEN, cdbuf, CD_TRACK_AUDIO);
m_cdrom->get_cdrom_file()->read_data(m_cur_sector - 150 - SPG290_LEADIN_LEN, cdbuf, cdrom_file::CD_TRACK_AUDIO);
for (int i=0; i<2352; i++)
{
@ -120,13 +120,13 @@ void spg290_cdservo_device::device_timer(emu_timer &timer, device_timer_id id, i
}
else
{
cdrom_read_data(m_cdrom->get_cdrom_file(), m_cur_sector - 150 - SPG290_LEADIN_LEN, cdbuf, CD_TRACK_MODE1_RAW);
m_cdrom->get_cdrom_file()->read_data(m_cur_sector - 150 - SPG290_LEADIN_LEN, cdbuf, cdrom_file::CD_TRACK_MODE1_RAW);
// FIXME: this is required for load iso images
if (cdrom_get_track_type(m_cdrom->get_cdrom_file(), m_qsub[m_cur_sector * 12 + 1] - 1) == CD_TRACK_MODE1)
if (m_cdrom->get_cdrom_file()->get_track_type(m_qsub[m_cur_sector * 12 + 1] - 1) == cdrom_file::CD_TRACK_MODE1)
{
int lba = (bcd_2_dec(cdbuf[12]) * 60 + bcd_2_dec(cdbuf[13])) * 75 + bcd_2_dec(cdbuf[14]);
uint32_t msf = lba_to_msf(lba + 150);
uint32_t msf = cdrom_file::lba_to_msf(lba + 150);
cdbuf[12] = (msf >> 16) & 0xff;
cdbuf[13] = (msf >> 8) & 0xff;
cdbuf[14] = (msf >> 0) & 0xff;
@ -357,9 +357,9 @@ void spg290_cdservo_device::add_qsub(int sector, uint8_t addrctrl, uint8_t track
void spg290_cdservo_device::generate_qsub(cdrom_file *cdrom)
{
const cdrom_toc *toc = cdrom_get_toc(cdrom);
int numtracks = cdrom_get_last_track(cdrom);
uint32_t total_sectors = cdrom_get_track_start(cdrom, numtracks - 1) + toc->tracks[numtracks - 1].frames + 150;
const cdrom_file::toc &toc = cdrom->get_toc();
int numtracks = cdrom->get_last_track();
uint32_t total_sectors = cdrom->get_track_start(numtracks - 1) + toc.tracks[numtracks - 1].frames + 150;
m_tot_sectors = SPG290_LEADIN_LEN + total_sectors + SPG290_LEADOUT_LEN;
m_qsub = std::make_unique<uint8_t[]>(m_tot_sectors * 12);
@ -369,54 +369,54 @@ void spg290_cdservo_device::generate_qsub(cdrom_file *cdrom)
// 7500 sectors lead-in
for (int s=0; s < SPG290_LEADIN_LEN; s += numtracks + 3)
{
if (lba < SPG290_LEADIN_LEN) add_qsub(lba++, 0x14, 0, 0xa0, lba_to_msf(s + 0), 1 << 16); // first track number
if (lba < SPG290_LEADIN_LEN) add_qsub(lba++, 0x14, 0, 0xa1, lba_to_msf(s + 1), numtracks << 16); // last track number
if (lba < SPG290_LEADIN_LEN) add_qsub(lba++, 0x14, 0, 0xa2, lba_to_msf(s + 2), lba_to_msf(total_sectors)); // start time of lead-out
if (lba < SPG290_LEADIN_LEN) add_qsub(lba++, 0x14, 0, 0xa0, cdrom_file::lba_to_msf(s + 0), 1 << 16); // first track number
if (lba < SPG290_LEADIN_LEN) add_qsub(lba++, 0x14, 0, 0xa1, cdrom_file::lba_to_msf(s + 1), numtracks << 16); // last track number
if (lba < SPG290_LEADIN_LEN) add_qsub(lba++, 0x14, 0, 0xa2, cdrom_file::lba_to_msf(s + 2), cdrom_file::lba_to_msf(total_sectors)); // start time of lead-out
for(int track = 0; track < numtracks; track++)
{
uint32_t track_start = cdrom_get_track_start(cdrom, track) + 150;
uint32_t track_start = cdrom->get_track_start(track) + 150;
if (lba < SPG290_LEADIN_LEN)
add_qsub(lba++, cdrom_get_adr_control(cdrom, track), 0, dec_2_bcd(track + 1), lba_to_msf(s + 3 + track), lba_to_msf(track_start));
add_qsub(lba++, cdrom->get_adr_control(track), 0, dec_2_bcd(track + 1), cdrom_file::lba_to_msf(s + 3 + track), cdrom_file::lba_to_msf(track_start));
}
}
// data tracks
for(int track = 0; track < numtracks; track++)
{
uint32_t control = cdrom_get_adr_control(cdrom, track);
uint32_t track_start = cdrom_get_track_start(cdrom, track);
uint32_t control = cdrom->get_adr_control(track);
uint32_t track_start = cdrom->get_track_start(track);
// pregap
uint32_t pregap = toc->tracks[track].pregap;
uint32_t pregap = toc.tracks[track].pregap;
// first track should have a 150 frames pregap
if (track == 0 && toc->tracks[0].pregap == 0)
if (track == 0 && toc.tracks[0].pregap == 0)
pregap = 150;
else if (track != 0 && toc->tracks[0].pregap == 0)
else if (track != 0 && toc.tracks[0].pregap == 0)
track_start += 150;
for(int s = 0; s < pregap; s++)
add_qsub(lba++, control, dec_2_bcd(track + 1), 0, lba_to_msf(s), lba_to_msf(track_start + s));
add_qsub(lba++, control, dec_2_bcd(track + 1), 0, cdrom_file::lba_to_msf(s), cdrom_file::lba_to_msf(track_start + s));
track_start += pregap;
for(int s = 0; s < toc->tracks[track].frames; s++)
for(int s = 0; s < toc.tracks[track].frames; s++)
{
// TODO: if present use subcode from CHD
add_qsub(lba++, control, dec_2_bcd(track + 1), 1, lba_to_msf(s), lba_to_msf(track_start + s));
add_qsub(lba++, control, dec_2_bcd(track + 1), 1, cdrom_file::lba_to_msf(s), cdrom_file::lba_to_msf(track_start + s));
}
track_start += toc->tracks[track].frames;
track_start += toc.tracks[track].frames;
// postgap
for(int s = 0; s < toc->tracks[track].postgap; s++)
add_qsub(lba++, control, dec_2_bcd(track + 1), 2, lba_to_msf(s), lba_to_msf(track_start + s));
for(int s = 0; s < toc.tracks[track].postgap; s++)
add_qsub(lba++, control, dec_2_bcd(track + 1), 2, cdrom_file::lba_to_msf(s), cdrom_file::lba_to_msf(track_start + s));
track_start += toc->tracks[track].postgap;
track_start += toc.tracks[track].postgap;
}
// 6750 sectors lead-out
for(int s = 0; s < SPG290_LEADOUT_LEN; s++)
add_qsub(lba++, 0x14, 0xaa, 1, lba_to_msf(s), lba_to_msf(total_sectors + s));
add_qsub(lba++, 0x14, 0xaa, 1, cdrom_file::lba_to_msf(s), cdrom_file::lba_to_msf(total_sectors + s));
}

View File

@ -478,12 +478,12 @@ int stvcd_device::get_track_index(uint32_t fad)
uint32_t rel_fad;
uint8_t track;
if(cdrom_get_track_type(cdrom, cdrom_get_track(cdrom, fad)) != CD_TRACK_AUDIO)
if(cdrom->get_track_type(cdrom->get_track(fad)) != cdrom_file::CD_TRACK_AUDIO)
return 1;
track = cdrom_get_track( cdrom, fad );
track = cdrom->get_track( fad );
rel_fad = fad - cdrom_get_track_start( cdrom, track );
rel_fad = fad - cdrom->get_track_start( track );
if(rel_fad < 150)
return 0;
@ -493,7 +493,7 @@ int stvcd_device::get_track_index(uint32_t fad)
int stvcd_device::sega_cdrom_get_adr_control(cdrom_file *file, int track)
{
return bitswap<8>(cdrom_get_adr_control(file, cur_track),3,2,1,0,7,6,5,4);
return bitswap<8>(file->get_adr_control(cur_track),3,2,1,0,7,6,5,4);
}
void stvcd_device::cr_standard_return(uint16_t cur_status)
@ -501,7 +501,7 @@ void stvcd_device::cr_standard_return(uint16_t cur_status)
if ((cd_stat & 0x0f00) == CD_STAT_SEEK)
{
/* During seek state, values returned are from the target position */
uint8_t seek_track = cdrom_get_track(cdrom, cd_fad_seek-150);
uint8_t seek_track = cdrom->get_track(cd_fad_seek-150);
cr1 = cur_status | (playtype << 7) | 0x00 | (cdda_repeat_count & 0xf);
cr2 = (seek_track == 0xff) ? 0xffff : ((sega_cdrom_get_adr_control(cdrom, seek_track)<<8) | seek_track);
@ -511,7 +511,7 @@ void stvcd_device::cr_standard_return(uint16_t cur_status)
else
{
cr1 = cur_status | (playtype << 7) | 0x00 | (cdda_repeat_count & 0xf); //options << 4 | repeat & 0xf
cr2 = (cur_track == 0xff) ? 0xffff : ((sega_cdrom_get_adr_control(cdrom, cur_track)<<8) | (cdrom_get_track(cdrom, cd_curfad-150)+1));
cr2 = (cur_track == 0xff) ? 0xffff : ((sega_cdrom_get_adr_control(cdrom, cur_track)<<8) | (cdrom->get_track(cd_curfad-150)+1));
cr3 = (get_track_index(cd_curfad)<<8) | (cd_curfad>>16); //index & 0xff00
cr4 = cd_curfad;
}
@ -761,7 +761,7 @@ void stvcd_device::cmd_play_disc()
cd_curfad = start_pos & 0xfffff;
logerror("fad mode\n");
cur_track = cdrom_get_track(cdrom, cd_curfad-150);
cur_track = cdrom->get_track(cd_curfad-150);
}
else
{
@ -769,7 +769,7 @@ void stvcd_device::cmd_play_disc()
if(((start_pos)>>8) != 0)
{
cur_track = (start_pos)>>8;
cd_fad_seek = cdrom_get_track_start(cdrom, cur_track-1);
cd_fad_seek = cdrom->get_track_start(cur_track-1);
cd_stat = CD_STAT_SEEK;
m_cdda->pause_audio(0);
}
@ -795,7 +795,7 @@ void stvcd_device::cmd_play_disc()
uint8_t end_track;
end_track = (end_pos)>>8;
fadstoplay = cdrom_get_track_start(cdrom, end_track) - cd_fad_seek;
fadstoplay = cdrom->get_track_start(end_track) - cd_fad_seek;
}
}
else // play until the end of the disc
@ -811,9 +811,9 @@ void stvcd_device::cmd_play_disc()
else
{
if(end_pos == 0)
fadstoplay = (cdrom_get_track_start(cdrom, 0xaa)) - cd_curfad;
fadstoplay = (cdrom->get_track_start(0xaa)) - cd_curfad;
else
fadstoplay = (cdrom_get_track_start(cdrom, (end_pos & 0xff00) >> 8)) - cd_curfad;
fadstoplay = (cdrom->get_track_start((end_pos & 0xff00) >> 8)) - cd_curfad;
}
logerror("track mode %08x %08x\n",cd_curfad,fadstoplay);
}
@ -828,8 +828,8 @@ void stvcd_device::cmd_play_disc()
// be countless possible combinations ...
if(fadstoplay == 0)
{
cd_curfad = cdrom_get_track_start(cdrom, cur_track-1);
fadstoplay = cdrom_get_track_start(cdrom, cur_track) - cd_curfad;
cd_curfad = cdrom->get_track_start(cur_track-1);
fadstoplay = cdrom->get_track_start(cur_track) - cd_curfad;
}
logerror("track resume %08x %08x\n",cd_curfad,fadstoplay);
}
@ -845,7 +845,7 @@ void stvcd_device::cmd_play_disc()
playtype = 0;
// cdda
if(cdrom_get_track_type(cdrom, cdrom_get_track(cdrom, cd_curfad)) == CD_TRACK_AUDIO)
if(cdrom->get_track_type(cdrom->get_track(cd_curfad)) == cdrom_file::CD_TRACK_AUDIO)
{
m_cdda->pause_audio(0);
//m_cdda->start_audio(cd_curfad, fadstoplay);
@ -892,7 +892,7 @@ void stvcd_device::cmd_seek_disc()
{
cd_stat = CD_STAT_PAUSE;
cur_track = cr2>>8;
cd_curfad = cdrom_get_track_start(cdrom, cur_track-1);
cd_curfad = cdrom->get_track_start(cur_track-1);
m_cdda->pause_audio(1);
// (index is cr2 low byte)
}
@ -952,13 +952,13 @@ void stvcd_device::cmd_get_subcode_q_rw_channel()
xxxx xxxx [11] CRCC
*/
msf_abs = lba_to_msf_alt( cd_curfad - 150 );
track = cdrom_get_track( cdrom, cd_curfad );
msf_rel = lba_to_msf_alt( cd_curfad - 150 - cdrom_get_track_start( cdrom, track ) );
msf_abs = cdrom_file::lba_to_msf_alt( cd_curfad - 150 );
track = cdrom->get_track( cd_curfad );
msf_rel = cdrom_file::lba_to_msf_alt( cd_curfad - 150 - cdrom->get_track_start( track ) );
xfertype = XFERTYPE_SUBQ;
xfercount = 0;
subqbuf[0] = 0x01 | ((cdrom_get_track_type(cdrom, cdrom_get_track(cdrom, track+1)) == CD_TRACK_AUDIO) ? 0x00 : 0x40);
subqbuf[0] = 0x01 | ((cdrom->get_track_type(cdrom->get_track(track+1)) == cdrom_file::CD_TRACK_AUDIO) ? 0x00 : 0x40);
subqbuf[1] = dec_2_bcd(track+1);
subqbuf[2] = dec_2_bcd(get_track_index(cd_curfad));
subqbuf[3] = dec_2_bcd((msf_rel >> 16) & 0xff);
@ -2006,7 +2006,7 @@ TIMER_DEVICE_CALLBACK_MEMBER( stvcd_device::stv_sector_cb )
cd_playdata();
if(cdrom_get_track_type(cdrom, cdrom_get_track(cdrom, cd_curfad)) == CD_TRACK_AUDIO)
if(cdrom->get_track_type(cdrom->get_track(cd_curfad)) == cdrom_file::CD_TRACK_AUDIO)
m_sector_timer->adjust(attotime::from_hz(75)); // 75 sectors / second = 150kBytes/second (cdda track ignores cd_speed setting)
else
m_sector_timer->adjust(attotime::from_hz(75*cd_speed)); // 75 / 150 sectors / second = 150 / 300kBytes/second
@ -2069,7 +2069,7 @@ void stvcd_device::device_reset()
for (i = 0; i < MAX_BLOCKS; i++)
{
blocks[i].size = -1;
memset(&blocks[i].data, 0, CD_MAX_SECTOR_DATA);
memset(&blocks[i].data, 0, cdrom_file::MAX_SECTOR_DATA);
}
// open device
@ -2384,7 +2384,7 @@ void stvcd_device::cd_readTOC(void)
if (cdrom)
{
ntrks = cdrom_get_last_track(cdrom);
ntrks = cdrom->get_last_track();
}
else
{
@ -2409,7 +2409,7 @@ void stvcd_device::cd_readTOC(void)
{
//tocbuf[tocptr] = sega_cdrom_get_adr_control(cdrom, i);
//HACK: ddsom does not enter ingame with the line above!
tocbuf[tocptr] = cdrom_get_adr_control(cdrom, i)<<4 | 0x01;
tocbuf[tocptr] = cdrom->get_adr_control(i)<<4 | 0x01;
}
else
{
@ -2418,7 +2418,7 @@ void stvcd_device::cd_readTOC(void)
if (cdrom)
{
fad = cdrom_get_track_start(cdrom, i) + 150;
fad = cdrom->get_track_start(i) + 150;
tocbuf[tocptr+1] = (fad>>16)&0xff;
tocbuf[tocptr+2] = (fad>>8)&0xff;
@ -2459,7 +2459,7 @@ void stvcd_device::cd_readTOC(void)
tocbuf[tocptr+7] = 0;
// get total disc length (start of lead-out)
fad = cdrom_get_track_start(cdrom, 0xaa) + 150;
fad = cdrom->get_track_start(0xaa) + 150;
tocbuf[tocptr+8] = tocbuf[0];
tocbuf[tocptr+9] = (fad>>16)&0xff;
@ -2493,7 +2493,7 @@ stvcd_device::partitionT *stvcd_device::cd_filterdata(filterT *flt, int trktype,
}
}
if ((trktype != CD_TRACK_AUDIO) && (curblock.data[15] == 2))
if ((trktype != cdrom_file::CD_TRACK_AUDIO) && (curblock.data[15] == 2))
{
if (flt->mode & 1) // file number
{
@ -2630,27 +2630,27 @@ stvcd_device::partitionT *stvcd_device::cd_read_filtered_sector(int32_t fad, uin
if ((cddevice != nullptr) && (!buffull))
{
// find out the track's type
trktype = cdrom_get_track_type(cdrom, cdrom_get_track(cdrom, fad-150));
trktype = cdrom->get_track_type(cdrom->get_track(fad-150));
// now get a raw 2352 byte sector - if it's mode 1, get mode1_raw
if ((trktype == CD_TRACK_MODE1) || (trktype == CD_TRACK_MODE1_RAW))
if ((trktype == cdrom_file::CD_TRACK_MODE1) || (trktype == cdrom_file::CD_TRACK_MODE1_RAW))
{
cdrom_read_data(cdrom, fad-150, curblock.data, CD_TRACK_MODE1_RAW);
cdrom->read_data(fad-150, curblock.data, cdrom_file::CD_TRACK_MODE1_RAW);
}
else if (trktype != CD_TRACK_AUDIO) // if not audio it must be mode 2 so get mode2_raw
else if (trktype != cdrom_file::CD_TRACK_AUDIO) // if not audio it must be mode 2 so get mode2_raw
{
cdrom_read_data(cdrom, fad-150, curblock.data, CD_TRACK_MODE2_RAW);
cdrom->read_data(fad-150, curblock.data, cdrom_file::CD_TRACK_MODE2_RAW);
}
else
{
cdrom_read_data(cdrom, fad-150, curblock.data, CD_TRACK_AUDIO);
cdrom->read_data(fad-150, curblock.data, cdrom_file::CD_TRACK_AUDIO);
}
curblock.size = sectlenin;
curblock.FAD = fad;
// if track is Mode 2, get the subheader values
if ((trktype != CD_TRACK_AUDIO) && (curblock.data[15] == 2))
if ((trktype != cdrom_file::CD_TRACK_AUDIO) && (curblock.data[15] == 2))
{
curblock.chan = curblock.data[17];
curblock.fnum = curblock.data[16];
@ -2714,7 +2714,7 @@ void stvcd_device::cd_playdata()
{
uint8_t p_ok;
if(cdrom_get_track_type(cdrom, cdrom_get_track(cdrom, cd_curfad)) != CD_TRACK_AUDIO)
if(cdrom->get_track_type(cdrom->get_track(cd_curfad)) != cdrom_file::CD_TRACK_AUDIO)
{
cd_read_filtered_sector(cd_curfad,&p_ok);
m_cdda->stop_audio(); //stop any pending CD-DA
@ -2752,8 +2752,8 @@ void stvcd_device::cd_playdata()
if(cdda_repeat_count < 0xe)
cdda_repeat_count++;
cd_curfad = cdrom_get_track_start(cdrom, cur_track-1) + 150;
fadstoplay = cdrom_get_track_start(cdrom, cur_track) - cd_curfad;
cd_curfad = cdrom->get_track_start(cur_track-1) + 150;
fadstoplay = cdrom->get_track_start(cur_track) - cd_curfad;
}
}
}
@ -2767,7 +2767,7 @@ void stvcd_device::cd_readblock(uint32_t fad, uint8_t *dat)
{
if (cdrom)
{
cdrom_read_data(cdrom, fad-150, dat, CD_TRACK_MODE1);
cdrom->read_data(fad-150, dat, cdrom_file::CD_TRACK_MODE1);
}
}

View File

@ -82,7 +82,7 @@ private:
{
int32_t size; // size of block
int32_t FAD; // FAD on disc
uint8_t data[CD_MAX_SECTOR_DATA];
uint8_t data[cdrom_file::MAX_SECTOR_DATA];
uint8_t chan; // channel
uint8_t fnum; // file number
uint8_t subm; // subchannel mode

View File

@ -72,7 +72,7 @@ t10mmc::toc_format_t t10mmc::toc_format()
int t10mmc::toc_tracks()
{
int start_track = command[6];
int end_track = cdrom_get_last_track(m_cdrom);
int end_track = m_cdrom->get_last_track();
if (start_track == 0)
{
@ -229,8 +229,8 @@ void t10mmc::ExecCommand()
// A request for LBA 0 will return something different depending on the type of media being played.
// For data and mixed media, LBA 0 is assigned to MSF 00:02:00 (= LBA 150).
// For audio media, LBA 0 is assigned to the actual starting address of track 1.
if (cdrom_get_track_type(m_cdrom, 0) == CD_TRACK_AUDIO)
m_lba = cdrom_get_track_start(m_cdrom, 0);
if (m_cdrom->get_track_type(0) == cdrom_file::CD_TRACK_AUDIO)
m_lba = m_cdrom->get_track_start(0);
else
m_lba = 150;
}
@ -241,9 +241,9 @@ void t10mmc::ExecCommand()
//m_device->logerror("T10MMC: PLAY AUDIO(10) at LBA %x for %x blocks\n", m_lba, m_blocks);
trk = cdrom_get_track(m_cdrom, m_lba);
trk = m_cdrom->get_track(m_lba);
if (cdrom_get_track_type(m_cdrom, trk) == CD_TRACK_AUDIO)
if (m_cdrom->get_track_type(trk) == cdrom_file::CD_TRACK_AUDIO)
{
m_cdda->start_audio(m_lba, m_blocks);
m_audio_sense = SCSI_SENSE_ASC_ASCQ_AUDIO_PLAY_OPERATION_IN_PROGRESS;
@ -265,8 +265,8 @@ void t10mmc::ExecCommand()
if (m_lba == 0)
{
if (cdrom_get_track_type(m_cdrom, 0) == CD_TRACK_AUDIO)
m_lba = cdrom_get_track_start(m_cdrom, 0);
if (m_cdrom->get_track_type(0) == cdrom_file::CD_TRACK_AUDIO)
m_lba = m_cdrom->get_track_start(0);
else
m_lba = 150;
}
@ -278,9 +278,9 @@ void t10mmc::ExecCommand()
//m_device->logerror("T10MMC: PLAY AUDIO MSF at LBA %x for %x blocks (MSF %i:%i:%i - %i:%i:%i)\n",
//m_lba, m_blocks, command[3], command[4], command[5], command[6], command[7], command[8]);
trk = cdrom_get_track(m_cdrom, m_lba);
trk = m_cdrom->get_track(m_lba);
if (cdrom_get_track_type(m_cdrom, trk) == CD_TRACK_AUDIO)
if (m_cdrom->get_track_type(trk) == cdrom_file::CD_TRACK_AUDIO)
{
m_cdda->start_audio(m_lba, m_blocks);
m_audio_sense = SCSI_SENSE_ASC_ASCQ_AUDIO_PLAY_OPERATION_IN_PROGRESS;
@ -308,7 +308,7 @@ void t10mmc::ExecCommand()
// be careful: tracks here are zero-based, but the SCSI command
// uses the real CD track number which is 1-based!
//m_device->logerror("T10MMC: PLAY AUDIO T/I: strk %d idx %d etrk %d idx %d frames %d\n", command[4], command[5], command[7], command[8], m_blocks);
int end_track = cdrom_get_last_track(m_cdrom);
int end_track = m_cdrom->get_last_track();
if (end_track > command[7])
end_track = command[7];
@ -319,11 +319,11 @@ void t10mmc::ExecCommand()
if (m_sotc)
end_track = command[4];
m_lba = cdrom_get_track_start(m_cdrom, command[4] - 1);
m_blocks = cdrom_get_track_start(m_cdrom, end_track) - m_lba;
trk = cdrom_get_track(m_cdrom, m_lba);
m_lba = m_cdrom->get_track_start(command[4] - 1);
m_blocks = m_cdrom->get_track_start(end_track) - m_lba;
trk = m_cdrom->get_track(m_lba);
if (cdrom_get_track_type(m_cdrom, trk) == CD_TRACK_AUDIO)
if (m_cdrom->get_track_type(trk) == cdrom_file::CD_TRACK_AUDIO)
{
m_cdda->start_audio(m_lba, m_blocks);
m_audio_sense = SCSI_SENSE_ASC_ASCQ_AUDIO_PLAY_OPERATION_IN_PROGRESS;
@ -382,8 +382,8 @@ void t10mmc::ExecCommand()
if (m_lba == 0)
{
if (cdrom_get_track_type(m_cdrom, 0) == CD_TRACK_AUDIO)
m_lba = cdrom_get_track_start(m_cdrom, 0);
if (m_cdrom->get_track_type(0) == cdrom_file::CD_TRACK_AUDIO)
m_lba = m_cdrom->get_track_start(0);
else
m_lba = 150;
}
@ -394,9 +394,9 @@ void t10mmc::ExecCommand()
//m_device->logerror("T10MMC: PLAY AUDIO(12) at LBA %x for %x blocks\n", m_lba, m_blocks);
trk = cdrom_get_track(m_cdrom, m_lba);
trk = m_cdrom->get_track(m_lba);
if (cdrom_get_track_type(m_cdrom, trk) == CD_TRACK_AUDIO)
if (m_cdrom->get_track_type(trk) == cdrom_file::CD_TRACK_AUDIO)
{
m_cdda->start_audio(m_lba, m_blocks);
m_audio_sense = SCSI_SENSE_ASC_ASCQ_AUDIO_PLAY_OPERATION_IN_PROGRESS;
@ -476,7 +476,7 @@ void t10mmc::ReadData( uint8_t *data, int dataLength )
case T10SBC_CMD_READ_CAPACITY:
m_device->logerror("T10MMC: READ CAPACITY\n");
temp = cdrom_get_track_start(m_cdrom, 0xaa);
temp = m_cdrom->get_track_start(0xaa);
temp--; // return the last used block on the disc
data[0] = (temp>>24) & 0xff;
@ -496,7 +496,7 @@ void t10mmc::ReadData( uint8_t *data, int dataLength )
{
while (dataLength > 0)
{
if (!cdrom_read_data(m_cdrom, m_lba, tmp_buffer, CD_TRACK_MODE1))
if (!m_cdrom->read_data(m_lba, tmp_buffer, cdrom_file::CD_TRACK_MODE1))
{
m_device->logerror("T10MMC: CD read error!\n");
}
@ -571,7 +571,7 @@ void t10mmc::ReadData( uint8_t *data, int dataLength )
data[3] = 12; // data length
data[4] = 0x01; // sub-channel format code
data[5] = 0x10 | (audio_active ? 0 : 4);
data[6] = cdrom_get_track(m_cdrom, m_last_lba) + 1; // track
data[6] = m_cdrom->get_track(m_last_lba) + 1; // track
data[7] = 0; // index
uint32_t frame = m_last_lba;
@ -586,7 +586,7 @@ void t10mmc::ReadData( uint8_t *data, int dataLength )
data[10] = (frame>>8)&0xff;
data[11] = frame&0xff;
frame = m_last_lba - cdrom_get_track_start(m_cdrom, data[6] - 1);
frame = m_last_lba - m_cdrom->get_track_start(data[6] - 1);
if (msf)
{
@ -634,7 +634,7 @@ void t10mmc::ReadData( uint8_t *data, int dataLength )
data[dptr++] = (len>>8) & 0xff;
data[dptr++] = (len & 0xff);
data[dptr++] = 1;
data[dptr++] = cdrom_get_last_track(m_cdrom);
data[dptr++] = m_cdrom->get_last_track();
int first_track = command[6];
if (first_track == 0)
@ -658,11 +658,11 @@ void t10mmc::ReadData( uint8_t *data, int dataLength )
}
data[dptr++] = 0;
data[dptr++] = cdrom_get_adr_control(m_cdrom, cdrom_track);
data[dptr++] = m_cdrom->get_adr_control(cdrom_track);
data[dptr++] = track;
data[dptr++] = 0;
uint32_t tstart = cdrom_get_track_start(m_cdrom, cdrom_track);
uint32_t tstart = m_cdrom->get_track_start(cdrom_track);
if (msf)
{
@ -688,11 +688,11 @@ void t10mmc::ReadData( uint8_t *data, int dataLength )
data[dptr++] = 1;
data[dptr++] = 0;
data[dptr++] = cdrom_get_adr_control(m_cdrom, 0);
data[dptr++] = m_cdrom->get_adr_control(0);
data[dptr++] = 1;
data[dptr++] = 0;
uint32_t tstart = cdrom_get_track_start(m_cdrom, 0);
uint32_t tstart = m_cdrom->get_track_start(0);
if (msf)
{

View File

@ -29,7 +29,7 @@ void cdda_device::sound_stream_update(sound_stream &stream, std::vector<read_str
void cdda_device::device_start()
{
/* allocate an audio cache */
m_audio_cache = std::make_unique<uint8_t[]>(CD_MAX_SECTOR_DATA * MAX_SECTORS );
m_audio_cache = std::make_unique<uint8_t[]>(cdrom_file::MAX_SECTOR_DATA * MAX_SECTORS );
m_stream = stream_alloc(0, 2, clock());
@ -47,7 +47,7 @@ void cdda_device::device_start()
save_item( NAME(m_audio_ended_normally) );
save_item( NAME(m_audio_lba) );
save_item( NAME(m_audio_length) );
save_pointer( NAME(m_audio_cache), CD_MAX_SECTOR_DATA * MAX_SECTORS );
save_pointer( NAME(m_audio_cache), cdrom_file::MAX_SECTOR_DATA * MAX_SECTORS );
save_item( NAME(m_audio_samples) );
save_item( NAME(m_audio_bptr) );
}
@ -114,7 +114,7 @@ void cdda_device::pause_audio(int pause)
uint32_t cdda_device::get_audio_lba()
{
m_stream->update();
return m_audio_lba - ((m_audio_samples + (CD_MAX_SECTOR_DATA / 4) - 1) / (CD_MAX_SECTOR_DATA / 4));
return m_audio_lba - ((m_audio_samples + (cdrom_file::MAX_SECTOR_DATA / 4) - 1) / (cdrom_file::MAX_SECTOR_DATA / 4));
}
@ -207,12 +207,12 @@ void cdda_device::get_audio_data(write_stream_view &bufL, write_stream_view &buf
for (i = 0; i < sectors; i++)
{
cdrom_read_data(m_disc, m_audio_lba, &m_audio_cache[CD_MAX_SECTOR_DATA*i], CD_TRACK_AUDIO);
m_disc->read_data(m_audio_lba, &m_audio_cache[cdrom_file::MAX_SECTOR_DATA*i], cdrom_file::CD_TRACK_AUDIO);
m_audio_lba++;
}
m_audio_samples = (CD_MAX_SECTOR_DATA*sectors)/4;
m_audio_samples = (cdrom_file::MAX_SECTOR_DATA*sectors)/4;
m_audio_length -= sectors;
/* reset feedout ptr */

File diff suppressed because it is too large Load Diff

View File

@ -1,5 +1,5 @@
// license:BSD-3-Clause
// copyright-holders:Aaron Giles
// copyright-holders:Aaron Giles,R. Belmont
/***************************************************************************
cdrom.h
@ -13,175 +13,253 @@
#pragma once
#include "chd.h"
#include "corefile.h"
#include "osdcore.h"
class cdrom_file {
public:
// tracks are padded to a multiple of this many frames
static constexpr uint32_t TRACK_PADDING = 4;
static constexpr uint32_t MAX_TRACKS = 99; /* AFAIK the theoretical limit */
static constexpr uint32_t MAX_SECTOR_DATA = 2352;
static constexpr uint32_t MAX_SUBCODE_DATA = 96;
static constexpr uint32_t FRAME_SIZE = MAX_SECTOR_DATA + MAX_SUBCODE_DATA;
static constexpr uint32_t FRAMES_PER_HUNK = 8;
static constexpr uint32_t METADATA_WORDS = 1 + MAX_TRACKS * 6;
enum
{
CD_TRACK_MODE1 = 0, /* mode 1 2048 bytes/sector */
CD_TRACK_MODE1_RAW, /* mode 1 2352 bytes/sector */
CD_TRACK_MODE2, /* mode 2 2336 bytes/sector */
CD_TRACK_MODE2_FORM1, /* mode 2 2048 bytes/sector */
CD_TRACK_MODE2_FORM2, /* mode 2 2324 bytes/sector */
CD_TRACK_MODE2_FORM_MIX, /* mode 2 2336 bytes/sector */
CD_TRACK_MODE2_RAW, /* mode 2 2352 bytes / sector */
CD_TRACK_AUDIO, /* redbook audio track 2352 bytes/sector (588 samples) */
CD_TRACK_RAW_DONTCARE /* special flag for cdrom_read_data: just return me whatever is there */
};
enum
{
CD_SUB_NORMAL = 0, /* "cooked" 96 bytes per sector */
CD_SUB_RAW, /* raw uninterleaved 96 bytes per sector */
CD_SUB_NONE /* no subcode data stored */
};
enum
{
CD_FLAG_GDROM = 0x00000001, // disc is a GD-ROM, all tracks should be stored with GD-ROM metadata
CD_FLAG_GDROMLE = 0x00000002 // legacy GD-ROM, with little-endian CDDA data
};
struct track_info
{
/* fields used by CHDMAN and in MAME */
uint32_t trktype; /* track type */
uint32_t subtype; /* subcode data type */
uint32_t datasize; /* size of data in each sector of this track */
uint32_t subsize; /* size of subchannel data in each sector of this track */
uint32_t frames; /* number of frames in this track */
uint32_t extraframes; /* number of "spillage" frames in this track */
uint32_t pregap; /* number of pregap frames */
uint32_t postgap; /* number of postgap frames */
uint32_t pgtype; /* type of sectors in pregap */
uint32_t pgsub; /* type of subchannel data in pregap */
uint32_t pgdatasize; /* size of data in each sector of the pregap */
uint32_t pgsubsize; /* size of subchannel data in each sector of the pregap */
/* fields used in CHDMAN only */
uint32_t padframes; /* number of frames of padding to add to the end of the track; needed for GDI */
uint32_t splitframes; /* number of frames to read from the next file; needed for Redump split-bin GDI */
/* fields used in MAME/MESS only */
uint32_t logframeofs; /* logical frame of actual track data - offset by pregap size if pregap not physically present */
uint32_t physframeofs; /* physical frame of actual track data in CHD data */
uint32_t chdframeofs; /* frame number this track starts at on the CHD */
uint32_t logframes; /* number of frames from logframeofs until end of track data */
/* fields used in multi-cue GDI */
uint32_t multicuearea;
};
/***************************************************************************
CONSTANTS
***************************************************************************/
struct toc
{
uint32_t numtrks; /* number of tracks */
uint32_t flags; /* see FLAG_ above */
track_info tracks[MAX_TRACKS];
};
// tracks are padded to a multiple of this many frames
const uint32_t CD_TRACK_PADDING = 4;
struct track_input_entry
{
track_input_entry() { reset(); }
void reset() { fname.clear(); offset = idx0offs = idx1offs = 0; swap = false; }
#define CD_MAX_TRACKS (99) /* AFAIK the theoretical limit */
#define CD_MAX_SECTOR_DATA (2352)
#define CD_MAX_SUBCODE_DATA (96)
std::string fname; // filename for each track
uint32_t offset; // offset in the data file for each track
bool swap; // data needs to be byte swapped
uint32_t idx0offs;
uint32_t idx1offs;
};
#define CD_FRAME_SIZE (CD_MAX_SECTOR_DATA + CD_MAX_SUBCODE_DATA)
#define CD_FRAMES_PER_HUNK (8)
struct track_input_info
{
void reset() { for (auto & elem : track) elem.reset(); }
#define CD_METADATA_WORDS (1+(CD_MAX_TRACKS * 6))
enum
{
CD_TRACK_MODE1 = 0, /* mode 1 2048 bytes/sector */
CD_TRACK_MODE1_RAW, /* mode 1 2352 bytes/sector */
CD_TRACK_MODE2, /* mode 2 2336 bytes/sector */
CD_TRACK_MODE2_FORM1, /* mode 2 2048 bytes/sector */
CD_TRACK_MODE2_FORM2, /* mode 2 2324 bytes/sector */
CD_TRACK_MODE2_FORM_MIX, /* mode 2 2336 bytes/sector */
CD_TRACK_MODE2_RAW, /* mode 2 2352 bytes / sector */
CD_TRACK_AUDIO, /* redbook audio track 2352 bytes/sector (588 samples) */
CD_TRACK_RAW_DONTCARE /* special flag for cdrom_read_data: just return me whatever is there */
};
enum
{
CD_SUB_NORMAL = 0, /* "cooked" 96 bytes per sector */
CD_SUB_RAW, /* raw uninterleaved 96 bytes per sector */
CD_SUB_NONE /* no subcode data stored */
};
#define CD_FLAG_GDROM 0x00000001 // disc is a GD-ROM, all tracks should be stored with GD-ROM metadata
#define CD_FLAG_GDROMLE 0x00000002 // legacy GD-ROM, with little-endian CDDA data
/***************************************************************************
TYPE DEFINITIONS
***************************************************************************/
struct cdrom_file;
struct cdrom_track_info
{
/* fields used by CHDMAN and in MAME */
uint32_t trktype; /* track type */
uint32_t subtype; /* subcode data type */
uint32_t datasize; /* size of data in each sector of this track */
uint32_t subsize; /* size of subchannel data in each sector of this track */
uint32_t frames; /* number of frames in this track */
uint32_t extraframes; /* number of "spillage" frames in this track */
uint32_t pregap; /* number of pregap frames */
uint32_t postgap; /* number of postgap frames */
uint32_t pgtype; /* type of sectors in pregap */
uint32_t pgsub; /* type of subchannel data in pregap */
uint32_t pgdatasize; /* size of data in each sector of the pregap */
uint32_t pgsubsize; /* size of subchannel data in each sector of the pregap */
/* fields used in CHDMAN only */
uint32_t padframes; /* number of frames of padding to add to the end of the track; needed for GDI */
uint32_t splitframes; /* number of frames to read from the next file; needed for Redump split-bin GDI */
/* fields used in MAME/MESS only */
uint32_t logframeofs; /* logical frame of actual track data - offset by pregap size if pregap not physically present */
uint32_t physframeofs; /* physical frame of actual track data in CHD data */
uint32_t chdframeofs; /* frame number this track starts at on the CHD */
uint32_t logframes; /* number of frames from logframeofs until end of track data */
/* fields used in multi-cue GDI */
uint32_t multicuearea;
};
track_input_entry track[MAX_TRACKS];
};
struct cdrom_toc
{
uint32_t numtrks; /* number of tracks */
uint32_t flags; /* see FLAG_ above */
cdrom_track_info tracks[CD_MAX_TRACKS];
};
cdrom_file(chd_file *chd);
cdrom_file(const char *inputfile);
~cdrom_file();
/* core read access */
bool read_data(uint32_t lbasector, void *buffer, uint32_t datatype, bool phys=false);
bool read_subcode(uint32_t lbasector, void *buffer, bool phys=false);
/* handy utilities */
uint32_t get_track(uint32_t frame) const;
uint32_t get_track_start(uint32_t track) const {return cdtoc.tracks[track == 0xaa ? cdtoc.numtrks : track].logframeofs; }
uint32_t get_track_start_phys(uint32_t track) const { return cdtoc.tracks[track == 0xaa ? cdtoc.numtrks : track].physframeofs; }
chd_file *get_chd() const { return chd; }
/* TOC utilities */
static std::error_condition parse_nero(const char *tocfname, toc &outtoc, track_input_info &outinfo);
static std::error_condition parse_iso(const char *tocfname, toc &outtoc, track_input_info &outinfo);
static std::error_condition parse_gdi(const char *tocfname, toc &outtoc, track_input_info &outinfo);
static std::error_condition parse_cue(const char *tocfname, toc &outtoc, track_input_info &outinfo);
static bool is_gdicue(const char *tocfname);
static std::error_condition parse_gdicue(const char *tocfname, toc &outtoc, track_input_info &outinfo);
static std::error_condition parse_toc(const char *tocfname, toc &outtoc, track_input_info &outinfo);
int get_last_track() const { return cdtoc.numtrks; }
int get_adr_control(int track) const { return track == 0xaa || cdtoc.tracks[track].trktype == CD_TRACK_AUDIO ? 0x10 : 0x14; }
int get_track_type(int track) const { return cdtoc.tracks[track].trktype; }
const toc &get_toc() const { return cdtoc; }
/* extra utilities */
static void convert_type_string_to_track_info(const char *typestring, track_info *info);
static void convert_type_string_to_pregap_info(const char *typestring, track_info *info);
static void convert_subtype_string_to_track_info(const char *typestring, track_info *info);
static void convert_subtype_string_to_pregap_info(const char *typestring, track_info *info);
static const char *get_type_string(uint32_t trktype);
static const char *get_subtype_string(uint32_t subtype);
static std::error_condition parse_metadata(chd_file *chd, toc &toc);
static std::error_condition write_metadata(chd_file *chd, const toc &toc);
// ECC utilities
static bool ecc_verify(const uint8_t *sector);
static void ecc_generate(uint8_t *sector);
static void ecc_clear(uint8_t *sector);
/***************************************************************************
FUNCTION PROTOTYPES
***************************************************************************/
static inline uint32_t msf_to_lba(uint32_t msf)
{
return ( ((msf&0x00ff0000)>>16) * 60 * 75) + (((msf&0x0000ff00)>>8) * 75) + ((msf&0x000000ff)>>0);
}
/* base functionality */
cdrom_file *cdrom_open(chd_file *chd);
void cdrom_close(cdrom_file *file);
static inline uint32_t lba_to_msf(uint32_t lba)
{
uint8_t m, s, f;
cdrom_file *cdrom_open(const char *inputfile);
m = lba / (60 * 75);
lba -= m * (60 * 75);
s = lba / 75;
f = lba % 75;
/* core read access */
uint32_t cdrom_read_data(cdrom_file *file, uint32_t lbasector, void *buffer, uint32_t datatype, bool phys=false);
uint32_t cdrom_read_subcode(cdrom_file *file, uint32_t lbasector, void *buffer, bool phys=false);
/* handy utilities */
uint32_t cdrom_get_track(cdrom_file *file, uint32_t frame);
uint32_t cdrom_get_track_start(cdrom_file *file, uint32_t track);
uint32_t cdrom_get_track_start_phys(cdrom_file *file, uint32_t track);
chd_file *cdrom_get_chd(cdrom_file *file);
/* TOC utilities */
int cdrom_get_last_track(cdrom_file *file);
int cdrom_get_adr_control(cdrom_file *file, int track);
int cdrom_get_track_type(cdrom_file *file, int track);
const cdrom_toc *cdrom_get_toc(cdrom_file *file);
/* extra utilities */
void cdrom_convert_type_string_to_track_info(const char *typestring, cdrom_track_info *info);
void cdrom_convert_type_string_to_pregap_info(const char *typestring, cdrom_track_info *info);
void cdrom_convert_subtype_string_to_track_info(const char *typestring, cdrom_track_info *info);
void cdrom_convert_subtype_string_to_pregap_info(const char *typestring, cdrom_track_info *info);
const char *cdrom_get_type_string(uint32_t trktype);
const char *cdrom_get_subtype_string(uint32_t subtype);
std::error_condition cdrom_parse_metadata(chd_file *chd, cdrom_toc *toc);
std::error_condition cdrom_write_metadata(chd_file *chd, const cdrom_toc *toc);
// ECC utilities
bool ecc_verify(const uint8_t *sector);
void ecc_generate(uint8_t *sector);
void ecc_clear(uint8_t *sector);
/***************************************************************************
INLINE FUNCTIONS
***************************************************************************/
static inline uint32_t msf_to_lba(uint32_t msf)
{
return ( ((msf&0x00ff0000)>>16) * 60 * 75) + (((msf&0x0000ff00)>>8) * 75) + ((msf&0x000000ff)>>0);
}
static inline uint32_t lba_to_msf(uint32_t lba)
{
uint8_t m, s, f;
m = lba / (60 * 75);
lba -= m * (60 * 75);
s = lba / 75;
f = lba % 75;
return ((m / 10) << 20) | ((m % 10) << 16) |
return ((m / 10) << 20) | ((m % 10) << 16) |
((s / 10) << 12) | ((s % 10) << 8) |
((f / 10) << 4) | ((f % 10) << 0);
}
}
// segacd needs it like this.. investigate
// Angelo also says PCE tracks often start playing at the
// wrong address.. related?
static inline uint32_t lba_to_msf_alt(int lba)
{
uint32_t ret = 0;
// segacd needs it like this.. investigate
// Angelo also says PCE tracks often start playing at the
// wrong address.. related?
static inline uint32_t lba_to_msf_alt(int lba)
{
uint32_t ret = 0;
ret |= ((lba / (60 * 75))&0xff)<<16;
ret |= (((lba / 75) % 60)&0xff)<<8;
ret |= ((lba % 75)&0xff)<<0;
return ret;
}
ret |= ((lba / (60 * 75))&0xff)<<16;
ret |= (((lba / 75) % 60)&0xff)<<8;
ret |= ((lba % 75)&0xff)<<0;
private:
enum gdi_area {
SINGLE_DENSITY,
HIGH_DENSITY
};
return ret;
}
enum gdi_pattern {
TYPE_UNKNOWN = 0,
TYPE_I,
TYPE_II,
TYPE_III,
TYPE_III_SPLIT
};
/** @brief offset within sector. */
static constexpr int SYNC_OFFSET = 0x000;
/** @brief 12 bytes. */
static constexpr int SYNC_NUM_BYTES = 12;
/** @brief offset within sector. */
static constexpr int MODE_OFFSET = 0x00f;
/** @brief offset within sector. */
static constexpr int ECC_P_OFFSET = 0x81c;
/** @brief 2 lots of 86. */
static constexpr int ECC_P_NUM_BYTES = 86;
/** @brief 24 bytes each. */
static constexpr int ECC_P_COMP = 24;
/** @brief The ECC q offset. */
static constexpr int ECC_Q_OFFSET = ECC_P_OFFSET + 2 * ECC_P_NUM_BYTES;
/** @brief 2 lots of 52. */
static constexpr int ECC_Q_NUM_BYTES = 52;
/** @brief 43 bytes each. */
static constexpr int ECC_Q_COMP = 43;
// ECC tables
static const uint8_t ecclow[256];
static const uint8_t ecchigh[256];
static const uint16_t poffsets[ECC_P_NUM_BYTES][ECC_P_COMP];
static const uint16_t qoffsets[ECC_Q_NUM_BYTES][ECC_Q_COMP];
/** @brief The chd. */
chd_file * chd; /* CHD file */
/** @brief The cdtoc. */
toc cdtoc; /* TOC for the CD */
/** @brief Information describing the track. */
track_input_info cdtrack_info; /* track info */
/** @brief The fhandle[ CD maximum tracks]. */
util::core_file::ptr fhandle[MAX_TRACKS];/* file handle */
inline uint32_t physical_to_chd_lba(uint32_t physlba, uint32_t &tracknum) const;
inline uint32_t logical_to_chd_lba(uint32_t physlba, uint32_t &tracknum) const;
static void get_info_from_type_string(const char *typestring, uint32_t *trktype, uint32_t *datasize);
static uint8_t ecc_source_byte(const uint8_t *sector, uint32_t offset);
static void ecc_compute_bytes(const uint8_t *sector, const uint16_t *row, int rowlen, uint8_t &val1, uint8_t &val2);
std::error_condition read_partial_sector(void *dest, uint32_t lbasector, uint32_t chdsector, uint32_t tracknum, uint32_t startoffs, uint32_t length, bool phys=false);
static std::string get_file_path(std::string &path);
static uint64_t get_file_size(const char *filename);
static int tokenize( const char *linebuffer, int i, int linebuffersize, char *token, int tokensize );
static int msf_to_frames( char *token );
static uint32_t parse_wav_sample(const char *filename, uint32_t *dataoffs);
static uint16_t read_uint16(FILE *infile);
static uint32_t read_uint32(FILE *infile);
static uint64_t read_uint64(FILE *infile);
};
#endif // MAME_LIB_UTIL_CDROM_H

View File

@ -1743,7 +1743,7 @@ uint32_t chd_file::guess_unitbytes()
!read_metadata(CDROM_TRACK_METADATA2_TAG, 0, metadata) ||
!read_metadata(GDROM_OLD_METADATA_TAG, 0, metadata) ||
!read_metadata(GDROM_TRACK_METADATA_TAG, 0, metadata))
return CD_FRAME_SIZE;
return cdrom_file::FRAME_SIZE;
// otherwise, just map 1:1 with the hunk size
return m_hunkbytes;

File diff suppressed because it is too large Load Diff

View File

@ -1,40 +0,0 @@
// license:BSD-3-Clause
// copyright-holders:R. Belmont
/***************************************************************************
CDRDAO TOC parser for CHD compression frontend
***************************************************************************/
#ifndef MAME_LIB_UTIL_CHDCD_H
#define MAME_LIB_UTIL_CHDCD_H
#pragma once
#include "cdrom.h"
#include <system_error>
struct chdcd_track_input_entry
{
chdcd_track_input_entry() { reset(); }
void reset() { fname.clear(); offset = idx0offs = idx1offs = 0; swap = false; }
std::string fname; // filename for each track
uint32_t offset; // offset in the data file for each track
bool swap; // data needs to be byte swapped
uint32_t idx0offs;
uint32_t idx1offs;
};
struct chdcd_track_input_info
{
void reset() { for (auto & elem : track) elem.reset(); }
chdcd_track_input_entry track[CD_MAX_TRACKS];
};
std::error_condition chdcd_parse_toc(const char *tocfname, cdrom_toc &outtoc, chdcd_track_input_info &outinfo);
#endif // MAME_LIB_UTIL_CHDCD_H

View File

@ -300,12 +300,12 @@ public:
// construction/destruction
chd_cd_compressor(chd_file &chd, uint32_t hunkbytes, bool lossy)
: chd_compressor(chd, hunkbytes, lossy),
m_base_compressor(chd, (hunkbytes / CD_FRAME_SIZE) * CD_MAX_SECTOR_DATA, lossy),
m_subcode_compressor(chd, (hunkbytes / CD_FRAME_SIZE) * CD_MAX_SUBCODE_DATA, lossy),
m_buffer(hunkbytes + (hunkbytes / CD_FRAME_SIZE) * CD_MAX_SUBCODE_DATA)
m_base_compressor(chd, (hunkbytes / cdrom_file::FRAME_SIZE) * cdrom_file::MAX_SECTOR_DATA, lossy),
m_subcode_compressor(chd, (hunkbytes / cdrom_file::FRAME_SIZE) * cdrom_file::MAX_SUBCODE_DATA, lossy),
m_buffer(hunkbytes + (hunkbytes / cdrom_file::FRAME_SIZE) * cdrom_file::MAX_SUBCODE_DATA)
{
// make sure the CHD's hunk size is an even multiple of the frame size
if (hunkbytes % CD_FRAME_SIZE != 0)
if (hunkbytes % cdrom_file::FRAME_SIZE != 0)
throw std::error_condition(chd_file::error::CODEC_ERROR);
}
@ -313,7 +313,7 @@ public:
virtual uint32_t compress(const uint8_t *src, uint32_t srclen, uint8_t *dest) override
{
// determine header bytes
uint32_t frames = srclen / CD_FRAME_SIZE;
uint32_t frames = srclen / cdrom_file::FRAME_SIZE;
uint32_t complen_bytes = (srclen < 65536) ? 2 : 3;
uint32_t ecc_bytes = (frames + 7) / 8;
uint32_t header_bytes = ecc_bytes + complen_bytes;
@ -324,21 +324,21 @@ public:
// copy audio data followed by subcode data
for (uint32_t framenum = 0; framenum < frames; framenum++)
{
memcpy(&m_buffer[framenum * CD_MAX_SECTOR_DATA], &src[framenum * CD_FRAME_SIZE], CD_MAX_SECTOR_DATA);
memcpy(&m_buffer[frames * CD_MAX_SECTOR_DATA + framenum * CD_MAX_SUBCODE_DATA], &src[framenum * CD_FRAME_SIZE + CD_MAX_SECTOR_DATA], CD_MAX_SUBCODE_DATA);
memcpy(&m_buffer[framenum * cdrom_file::MAX_SECTOR_DATA], &src[framenum * cdrom_file::FRAME_SIZE], cdrom_file::MAX_SECTOR_DATA);
memcpy(&m_buffer[frames * cdrom_file::MAX_SECTOR_DATA + framenum * cdrom_file::MAX_SUBCODE_DATA], &src[framenum * cdrom_file::FRAME_SIZE + cdrom_file::MAX_SECTOR_DATA], cdrom_file::MAX_SUBCODE_DATA);
// clear out ECC data if we can
uint8_t *sector = &m_buffer[framenum * CD_MAX_SECTOR_DATA];
if (memcmp(sector, f_cd_sync_header, sizeof(f_cd_sync_header)) == 0 && ecc_verify(sector))
uint8_t *sector = &m_buffer[framenum * cdrom_file::MAX_SECTOR_DATA];
if (memcmp(sector, f_cd_sync_header, sizeof(f_cd_sync_header)) == 0 && cdrom_file::ecc_verify(sector))
{
dest[framenum / 8] |= 1 << (framenum % 8);
memset(sector, 0, sizeof(f_cd_sync_header));
ecc_clear(sector);
cdrom_file::ecc_clear(sector);
}
}
// encode the base portion
uint32_t complen = m_base_compressor.compress(&m_buffer[0], frames * CD_MAX_SECTOR_DATA, &dest[header_bytes]);
uint32_t complen = m_base_compressor.compress(&m_buffer[0], frames * cdrom_file::MAX_SECTOR_DATA, &dest[header_bytes]);
if (complen >= srclen)
throw std::error_condition(chd_file::error::COMPRESSION_ERROR);
@ -349,7 +349,7 @@ public:
dest[ecc_bytes + 2] = complen >> ((complen_bytes - 3) * 8);
// encode the subcode
return header_bytes + complen + m_subcode_compressor.compress(&m_buffer[frames * CD_MAX_SECTOR_DATA], frames * CD_MAX_SUBCODE_DATA, &dest[header_bytes + complen]);
return header_bytes + complen + m_subcode_compressor.compress(&m_buffer[frames * cdrom_file::MAX_SECTOR_DATA], frames * cdrom_file::MAX_SUBCODE_DATA, &dest[header_bytes + complen]);
}
private:
@ -369,12 +369,12 @@ public:
// construction/destruction
chd_cd_decompressor(chd_file &chd, uint32_t hunkbytes, bool lossy)
: chd_decompressor(chd, hunkbytes, lossy),
m_base_decompressor(chd, (hunkbytes / CD_FRAME_SIZE) * CD_MAX_SECTOR_DATA, lossy),
m_subcode_decompressor(chd, (hunkbytes / CD_FRAME_SIZE) * CD_MAX_SUBCODE_DATA, lossy),
m_base_decompressor(chd, (hunkbytes / cdrom_file::FRAME_SIZE) * cdrom_file::MAX_SECTOR_DATA, lossy),
m_subcode_decompressor(chd, (hunkbytes / cdrom_file::FRAME_SIZE) * cdrom_file::MAX_SUBCODE_DATA, lossy),
m_buffer(hunkbytes)
{
// make sure the CHD's hunk size is an even multiple of the frame size
if (hunkbytes % CD_FRAME_SIZE != 0)
if (hunkbytes % cdrom_file::FRAME_SIZE != 0)
throw std::error_condition(chd_file::error::CODEC_ERROR);
}
@ -382,7 +382,7 @@ public:
virtual void decompress(const uint8_t *src, uint32_t complen, uint8_t *dest, uint32_t destlen) override
{
// determine header bytes
uint32_t frames = destlen / CD_FRAME_SIZE;
uint32_t frames = destlen / cdrom_file::FRAME_SIZE;
uint32_t complen_bytes = (destlen < 65536) ? 2 : 3;
uint32_t ecc_bytes = (frames + 7) / 8;
uint32_t header_bytes = ecc_bytes + complen_bytes;
@ -393,21 +393,21 @@ public:
complen_base = (complen_base << 8) | src[ecc_bytes + 2];
// reset and decode
m_base_decompressor.decompress(&src[header_bytes], complen_base, &m_buffer[0], frames * CD_MAX_SECTOR_DATA);
m_subcode_decompressor.decompress(&src[header_bytes + complen_base], complen - complen_base - header_bytes, &m_buffer[frames * CD_MAX_SECTOR_DATA], frames * CD_MAX_SUBCODE_DATA);
m_base_decompressor.decompress(&src[header_bytes], complen_base, &m_buffer[0], frames * cdrom_file::MAX_SECTOR_DATA);
m_subcode_decompressor.decompress(&src[header_bytes + complen_base], complen - complen_base - header_bytes, &m_buffer[frames * cdrom_file::MAX_SECTOR_DATA], frames * cdrom_file::MAX_SUBCODE_DATA);
// reassemble the data
for (uint32_t framenum = 0; framenum < frames; framenum++)
{
memcpy(&dest[framenum * CD_FRAME_SIZE], &m_buffer[framenum * CD_MAX_SECTOR_DATA], CD_MAX_SECTOR_DATA);
memcpy(&dest[framenum * CD_FRAME_SIZE + CD_MAX_SECTOR_DATA], &m_buffer[frames * CD_MAX_SECTOR_DATA + framenum * CD_MAX_SUBCODE_DATA], CD_MAX_SUBCODE_DATA);
memcpy(&dest[framenum * cdrom_file::FRAME_SIZE], &m_buffer[framenum * cdrom_file::MAX_SECTOR_DATA], cdrom_file::MAX_SECTOR_DATA);
memcpy(&dest[framenum * cdrom_file::FRAME_SIZE + cdrom_file::MAX_SECTOR_DATA], &m_buffer[frames * cdrom_file::MAX_SECTOR_DATA + framenum * cdrom_file::MAX_SUBCODE_DATA], cdrom_file::MAX_SUBCODE_DATA);
// reconstitute the ECC data and sync header
uint8_t *sector = &dest[framenum * CD_FRAME_SIZE];
uint8_t *sector = &dest[framenum * cdrom_file::FRAME_SIZE];
if ((src[framenum / 8] & (1 << (framenum % 8))) != 0)
{
memcpy(sector, f_cd_sync_header, sizeof(f_cd_sync_header));
ecc_generate(sector);
cdrom_file::ecc_generate(sector);
}
}
}
@ -1427,7 +1427,7 @@ chd_cd_flac_compressor::chd_cd_flac_compressor(chd_file &chd, uint32_t hunkbytes
m_buffer(hunkbytes)
{
// make sure the CHD's hunk size is an even multiple of the frame size
if (hunkbytes % CD_FRAME_SIZE != 0)
if (hunkbytes % cdrom_file::FRAME_SIZE != 0)
throw std::error_condition(chd_file::error::CODEC_ERROR);
// determine whether we want native or swapped samples
@ -1438,7 +1438,7 @@ chd_cd_flac_compressor::chd_cd_flac_compressor(chd_file &chd, uint32_t hunkbytes
// configure the encoder
m_encoder.set_sample_rate(44100);
m_encoder.set_num_channels(2);
m_encoder.set_block_size(blocksize((hunkbytes / CD_FRAME_SIZE) * CD_MAX_SECTOR_DATA));
m_encoder.set_block_size(blocksize((hunkbytes / cdrom_file::FRAME_SIZE) * cdrom_file::MAX_SECTOR_DATA));
m_encoder.set_strip_metadata(true);
// initialize the deflater
@ -1473,25 +1473,25 @@ chd_cd_flac_compressor::~chd_cd_flac_compressor()
uint32_t chd_cd_flac_compressor::compress(const uint8_t *src, uint32_t srclen, uint8_t *dest)
{
// copy audio data followed by subcode data
uint32_t frames = hunkbytes() / CD_FRAME_SIZE;
uint32_t frames = hunkbytes() / cdrom_file::FRAME_SIZE;
for (uint32_t framenum = 0; framenum < frames; framenum++)
{
memcpy(&m_buffer[framenum * CD_MAX_SECTOR_DATA], &src[framenum * CD_FRAME_SIZE], CD_MAX_SECTOR_DATA);
memcpy(&m_buffer[frames * CD_MAX_SECTOR_DATA + framenum * CD_MAX_SUBCODE_DATA], &src[framenum * CD_FRAME_SIZE + CD_MAX_SECTOR_DATA], CD_MAX_SUBCODE_DATA);
memcpy(&m_buffer[framenum * cdrom_file::MAX_SECTOR_DATA], &src[framenum * cdrom_file::FRAME_SIZE], cdrom_file::MAX_SECTOR_DATA);
memcpy(&m_buffer[frames * cdrom_file::MAX_SECTOR_DATA + framenum * cdrom_file::MAX_SUBCODE_DATA], &src[framenum * cdrom_file::FRAME_SIZE + cdrom_file::MAX_SECTOR_DATA], cdrom_file::MAX_SUBCODE_DATA);
}
// reset and encode the audio portion
m_encoder.reset(dest, hunkbytes());
uint8_t *buffer = &m_buffer[0];
if (!m_encoder.encode_interleaved(reinterpret_cast<int16_t *>(buffer), frames * CD_MAX_SECTOR_DATA/4, m_swap_endian))
if (!m_encoder.encode_interleaved(reinterpret_cast<int16_t *>(buffer), frames * cdrom_file::MAX_SECTOR_DATA/4, m_swap_endian))
throw std::error_condition(chd_file::error::COMPRESSION_ERROR);
// finish up
uint32_t complen = m_encoder.finish();
// deflate the subcode data
m_deflater.next_in = const_cast<Bytef *>(&m_buffer[frames * CD_MAX_SECTOR_DATA]);
m_deflater.avail_in = frames * CD_MAX_SUBCODE_DATA;
m_deflater.next_in = const_cast<Bytef *>(&m_buffer[frames * cdrom_file::MAX_SECTOR_DATA]);
m_deflater.avail_in = frames * cdrom_file::MAX_SUBCODE_DATA;
m_deflater.total_in = 0;
m_deflater.next_out = &dest[complen];
m_deflater.avail_out = hunkbytes() - complen;
@ -1526,7 +1526,7 @@ uint32_t chd_cd_flac_compressor::blocksize(uint32_t bytes)
{
// for CDs it seems that CD_MAX_SECTOR_DATA is the right target
uint32_t blocksize = bytes / 4;
while (blocksize > CD_MAX_SECTOR_DATA)
while (blocksize > cdrom_file::MAX_SECTOR_DATA)
blocksize /= 2;
return blocksize;
}
@ -1556,7 +1556,7 @@ chd_cd_flac_decompressor::chd_cd_flac_decompressor(chd_file &chd, uint32_t hunkb
m_buffer(hunkbytes)
{
// make sure the CHD's hunk size is an even multiple of the frame size
if (hunkbytes % CD_FRAME_SIZE != 0)
if (hunkbytes % cdrom_file::FRAME_SIZE != 0)
throw std::error_condition(chd_file::error::CODEC_ERROR);
// determine whether we want native or swapped samples
@ -1609,11 +1609,11 @@ chd_cd_flac_decompressor::~chd_cd_flac_decompressor()
void chd_cd_flac_decompressor::decompress(const uint8_t *src, uint32_t complen, uint8_t *dest, uint32_t destlen)
{
// reset and decode
uint32_t frames = destlen / CD_FRAME_SIZE;
if (!m_decoder.reset(44100, 2, chd_cd_flac_compressor::blocksize(frames * CD_MAX_SECTOR_DATA), src, complen))
uint32_t frames = destlen / cdrom_file::FRAME_SIZE;
if (!m_decoder.reset(44100, 2, chd_cd_flac_compressor::blocksize(frames * cdrom_file::MAX_SECTOR_DATA), src, complen))
throw std::error_condition(chd_file::error::DECOMPRESSION_ERROR);
uint8_t *buffer = &m_buffer[0];
if (!m_decoder.decode_interleaved(reinterpret_cast<int16_t *>(buffer), frames * CD_MAX_SECTOR_DATA/4, m_swap_endian))
if (!m_decoder.decode_interleaved(reinterpret_cast<int16_t *>(buffer), frames * cdrom_file::MAX_SECTOR_DATA/4, m_swap_endian))
throw std::error_condition(chd_file::error::DECOMPRESSION_ERROR);
// inflate the subcode data
@ -1621,8 +1621,8 @@ void chd_cd_flac_decompressor::decompress(const uint8_t *src, uint32_t complen,
m_inflater.next_in = const_cast<Bytef *>(src + offset);
m_inflater.avail_in = complen - offset;
m_inflater.total_in = 0;
m_inflater.next_out = &m_buffer[frames * CD_MAX_SECTOR_DATA];
m_inflater.avail_out = frames * CD_MAX_SUBCODE_DATA;
m_inflater.next_out = &m_buffer[frames * cdrom_file::MAX_SECTOR_DATA];
m_inflater.avail_out = frames * cdrom_file::MAX_SUBCODE_DATA;
m_inflater.total_out = 0;
int zerr = inflateReset(&m_inflater);
if (zerr != Z_OK)
@ -1632,14 +1632,14 @@ void chd_cd_flac_decompressor::decompress(const uint8_t *src, uint32_t complen,
zerr = inflate(&m_inflater, Z_FINISH);
if (zerr != Z_STREAM_END)
throw std::error_condition(chd_file::error::DECOMPRESSION_ERROR);
if (m_inflater.total_out != frames * CD_MAX_SUBCODE_DATA)
if (m_inflater.total_out != frames * cdrom_file::MAX_SUBCODE_DATA)
throw std::error_condition(chd_file::error::DECOMPRESSION_ERROR);
// reassemble the data
for (uint32_t framenum = 0; framenum < frames; framenum++)
{
memcpy(&dest[framenum * CD_FRAME_SIZE], &m_buffer[framenum * CD_MAX_SECTOR_DATA], CD_MAX_SECTOR_DATA);
memcpy(&dest[framenum * CD_FRAME_SIZE + CD_MAX_SECTOR_DATA], &m_buffer[frames * CD_MAX_SECTOR_DATA + framenum * CD_MAX_SUBCODE_DATA], CD_MAX_SUBCODE_DATA);
memcpy(&dest[framenum * cdrom_file::FRAME_SIZE], &m_buffer[framenum * cdrom_file::MAX_SECTOR_DATA], cdrom_file::MAX_SECTOR_DATA);
memcpy(&dest[framenum * cdrom_file::FRAME_SIZE + cdrom_file::MAX_SECTOR_DATA], &m_buffer[frames * cdrom_file::MAX_SECTOR_DATA + framenum * cdrom_file::MAX_SUBCODE_DATA], cdrom_file::MAX_SUBCODE_DATA);
}
}

View File

@ -1447,7 +1447,7 @@ uint8_t towns_state::towns_cd_get_track()
for(track=1;track<99;track++)
{
if(cdrom_get_track_start(cdrom->get_cdrom_file(),track) > lba)
if(cdrom->get_cdrom_file()->get_track_start(track) > lba)
break;
}
return track;
@ -1495,7 +1495,7 @@ TIMER_CALLBACK_MEMBER(towns_state::towns_cdrom_read_byte)
m_towns_cd.extra_status = 0;
towns_cd_set_status(0x22,0x00,0x00,0x00);
towns_cdrom_set_irq(TOWNS_CD_IRQ_DMA,1);
cdrom_read_data(m_cdrom->get_cdrom_file(),++m_towns_cd.lba_current,m_towns_cd.buffer,CD_TRACK_MODE1);
m_cdrom->get_cdrom_file()->read_data(++m_towns_cd.lba_current,m_towns_cd.buffer,cdrom_file::CD_TRACK_MODE1);
m_towns_cd.read_timer->adjust(attotime::from_hz(300000),1);
m_towns_cd.buffer_ptr = -1;
}
@ -1526,7 +1526,7 @@ uint8_t towns_state::towns_cdrom_read_byte_software()
}
else
{
cdrom_read_data(m_cdrom->get_cdrom_file(),++m_towns_cd.lba_current,m_towns_cd.buffer,CD_TRACK_MODE1);
m_cdrom->get_cdrom_file()->read_data(++m_towns_cd.lba_current,m_towns_cd.buffer,cdrom_file::CD_TRACK_MODE1);
m_towns_cd.extra_status = 0;
towns_cd_set_status(0x21,0x00,0x00,0x00);
towns_cdrom_set_irq(TOWNS_CD_IRQ_DMA,1);
@ -1558,7 +1558,7 @@ void towns_state::towns_cdrom_read(cdrom_image_device* device)
m_towns_cd.lba_current = msf_to_lbafm(lba1);
m_towns_cd.lba_last = msf_to_lbafm(lba2);
track = cdrom_get_track(device->get_cdrom_file(),m_towns_cd.lba_current);
track = device->get_cdrom_file()->get_track(m_towns_cd.lba_current);
// parameter 7 = sector count?
// lemmings 2 sets this to 4 but hates 4 extra sectors being read
@ -1574,7 +1574,7 @@ void towns_state::towns_cdrom_read(cdrom_image_device* device)
}
else
{
cdrom_read_data(device->get_cdrom_file(),m_towns_cd.lba_current,m_towns_cd.buffer,CD_TRACK_MODE1);
device->get_cdrom_file()->read_data(m_towns_cd.lba_current,m_towns_cd.buffer,cdrom_file::CD_TRACK_MODE1);
if(m_towns_cd.software_tx)
{
m_towns_cd.status &= ~0x10; // not a DMA transfer
@ -1816,7 +1816,7 @@ uint8_t towns_state::towns_cdrom_r(offs_t offset)
break;
case 4: // st1 = last track number (BCD)
towns_cd_set_status(0x17,
byte_to_bcd(cdrom_get_last_track(m_cdrom->get_cdrom_file())),
byte_to_bcd(m_cdrom->get_cdrom_file()->get_last_track()),
0x00,0x00);
m_towns_cd.extra_status++;
break;
@ -1825,8 +1825,8 @@ uint8_t towns_state::towns_cdrom_r(offs_t offset)
m_towns_cd.extra_status++;
break;
case 6: // st1/2/3 = address of track 0xaa? (BCD)
addr = cdrom_get_track_start(m_cdrom->get_cdrom_file(),0xaa);
addr = lba_to_msf(addr + 150);
addr = m_cdrom->get_cdrom_file()->get_track_start(0xaa);
addr = cdrom_file::lba_to_msf(addr + 150);
towns_cd_set_status(0x17,
(addr & 0xff0000) >> 16,(addr & 0x00ff00) >> 8,addr & 0x0000ff);
m_towns_cd.extra_status++;
@ -1835,19 +1835,19 @@ uint8_t towns_state::towns_cdrom_r(offs_t offset)
if(m_towns_cd.extra_status & 0x01)
{
towns_cd_set_status(0x16,
((cdrom_get_adr_control(m_cdrom->get_cdrom_file(),(m_towns_cd.extra_status/2)-3) & 0x0f) << 4)
| ((cdrom_get_adr_control(m_cdrom->get_cdrom_file(),(m_towns_cd.extra_status/2)-3) & 0xf0) >> 4),
((m_cdrom->get_cdrom_file()->get_adr_control((m_towns_cd.extra_status/2)-3) & 0x0f) << 4)
| ((m_cdrom->get_cdrom_file()->get_adr_control((m_towns_cd.extra_status/2)-3) & 0xf0) >> 4),
byte_to_bcd((m_towns_cd.extra_status/2)-2),0x00);
m_towns_cd.extra_status++;
}
else
{
int track = (m_towns_cd.extra_status/2)-4;
addr = cdrom_get_track_start(m_cdrom->get_cdrom_file(),track);
addr = lba_to_msf(addr + 150);
addr = m_cdrom->get_cdrom_file()->get_track_start(track);
addr = cdrom_file::lba_to_msf(addr + 150);
towns_cd_set_status(0x17,
(addr & 0xff0000) >> 16,(addr & 0x00ff00) >> 8,addr & 0x0000ff);
if(track >= cdrom_get_last_track(m_cdrom->get_cdrom_file()))
if(track >= m_cdrom->get_cdrom_file()->get_last_track())
{
m_towns_cd.extra_status = 0;
}
@ -1867,21 +1867,21 @@ uint8_t towns_state::towns_cdrom_r(offs_t offset)
break;
case 2: // st0/1/2 = MSF from beginning of current track
addr = m_cdda->get_audio_lba();
addr = lba_to_msf(addr - m_towns_cd.cdda_current);
addr = cdrom_file::lba_to_msf(addr - m_towns_cd.cdda_current);
towns_cd_set_status(0x19,
(addr & 0xff0000) >> 16,(addr & 0x00ff00) >> 8,addr & 0x0000ff);
m_towns_cd.extra_status++;
break;
case 3: // st1/2 = current MSF
addr = m_cdda->get_audio_lba();
addr = lba_to_msf(addr); // this data is incorrect, but will do until exact meaning is found
addr = cdrom_file::lba_to_msf(addr); // this data is incorrect, but will do until exact meaning is found
towns_cd_set_status(0x19,
0x00,(addr & 0xff0000) >> 16,(addr & 0x00ff00) >> 8);
m_towns_cd.extra_status++;
break;
case 4:
addr = m_cdda->get_audio_lba();
addr = lba_to_msf(addr); // this data is incorrect, but will do until exact meaning is found
addr = cdrom_file::lba_to_msf(addr); // this data is incorrect, but will do until exact meaning is found
towns_cd_set_status(0x20,
addr & 0x0000ff,0x00,0x00);
m_towns_cd.extra_status = 0;

View File

@ -1242,12 +1242,12 @@ void jaguarcd_state::butch_regs_w(offs_t offset, uint32_t data, uint32_t mem_mas
return;
}
msf = cdrom_get_track_start(m_cd_file, 0) + 150;
msf = m_cd_file->get_track_start(0) + 150;
/* first track number */
m_butch_cmd_response[0] = 0x2000 | 1;
/* last track number */
m_butch_cmd_response[1] = 0x2100 | cdrom_get_last_track(m_cd_file);
m_butch_cmd_response[1] = 0x2100 | m_cd_file->get_last_track();
/* start of first track minutes */
m_butch_cmd_response[2] = 0x2200 | ((msf / 60) / 60);
@ -1262,11 +1262,11 @@ void jaguarcd_state::butch_regs_w(offs_t offset, uint32_t data, uint32_t mem_mas
case 0x14: // Read Long TOC
{
uint32_t msf;
int ntrks = cdrom_get_last_track(m_cd_file);
int ntrks = m_cd_file->get_last_track();
for(int i=0;i<ntrks;i++)
{
msf = cdrom_get_track_start(m_cd_file, i) + 150;
msf = m_cd_file->get_track_start(i) + 150;
/* track number */
m_butch_cmd_response[i*5+0] = 0x6000 | (i+1);

View File

@ -696,7 +696,7 @@ void konamim2_state::machine_start()
m_ppc1->ppcdrc_add_fastram(m_bda->ram_start(), m_bda->ram_end(), false, m_bda->ram_ptr());
m_ppc2->ppcdrc_add_fastram(m_bda->ram_start(), m_bda->ram_end(), false, m_bda->ram_ptr());
m_available_cdroms = cdrom_open(machine().rom_load().get_disk_handle(":cdrom"));
m_available_cdroms = new cdrom_file(machine().rom_load().get_disk_handle(":cdrom"));
// TODO: REMOVE
m_atapi_timer = machine().scheduler().timer_alloc(timer_expired_delegate(FUNC(konamim2_state::atapi_delay), this));

View File

@ -1107,8 +1107,8 @@ void ksys573_state::driver_start()
m_atapi_timer = machine().scheduler().timer_alloc( timer_expired_delegate( FUNC( ksys573_state::atapi_xfer_end ),this ) );
m_atapi_timer->adjust( attotime::never );
m_available_cdroms[ 0 ] = cdrom_open(machine().rom_load().get_disk_handle(":cdrom0"));
m_available_cdroms[ 1 ] = cdrom_open(machine().rom_load().get_disk_handle(":cdrom1"));
m_available_cdroms[ 0 ] = new cdrom_file(machine().rom_load().get_disk_handle(":cdrom0"));
m_available_cdroms[ 1 ] = new cdrom_file(machine().rom_load().get_disk_handle(":cdrom1"));
save_item( NAME( m_n_security_control ) );
save_item( NAME( m_control ) );

View File

@ -931,7 +931,7 @@ void cdicdic_device::process_disc_sector()
LOGMASKED(LOG_SECTORS, "Disc sector, current LBA: %08x, MSF: %02x %02x %02x\n", real_lba, mins_bcd, secs_bcd, frac_bcd);
uint8_t buffer[2560] = { 0 };
cdrom_read_data(m_cd, m_curr_lba, buffer, CD_TRACK_RAW_DONTCARE);
m_cd->read_data(m_curr_lba, buffer, cdrom_file::CD_TRACK_RAW_DONTCARE);
// Detect (badly) if we're dealing with a byteswapped loose-bin image
if (buffer[0] == 0xff && buffer[1] == 0x00)
@ -1022,23 +1022,23 @@ void cdicdic_device::process_disc_sector()
if (m_disc_mode == DISC_TOC)
{
uint8_t *toc_buffer = buffer;
const cdrom_toc *toc = cdrom_get_toc(m_cd);
const cdrom_file::toc &toc = m_cd->get_toc();
uint32_t entry_count = 0;
// Determine total frame count for data, and total audio track count
uint32_t frames = toc->tracks[0].pregap;
uint32_t frames = toc.tracks[0].pregap;
int audio_tracks = 0;
int other_tracks = 0;
uint32_t audio_starts[CD_MAX_TRACKS];
for (uint32_t i = 0; i < toc->numtrks; i++)
uint32_t audio_starts[cdrom_file::MAX_TRACKS];
for (uint32_t i = 0; i < toc.numtrks; i++)
{
if (toc->tracks[i].trktype != CD_TRACK_AUDIO)
if (toc.tracks[i].trktype != cdrom_file::CD_TRACK_AUDIO)
{
frames += toc->tracks[i].frames + toc->tracks[i].extraframes;
frames += toc.tracks[i].frames + toc.tracks[i].extraframes;
}
else
{
audio_starts[audio_tracks++] = toc->tracks[i].logframeofs;
audio_starts[audio_tracks++] = toc.tracks[i].logframeofs;
}
}
@ -1572,7 +1572,7 @@ void cdicdic_device::device_reset()
else
{
// Arcade case
m_cd = cdrom_open(machine().rom_load().get_disk_handle(":cdrom"));
m_cd = new cdrom_file(machine().rom_load().get_disk_handle(":cdrom"));
}
m_audio_timer->adjust(attotime::from_hz(75), 0, attotime::from_hz(75));

View File

@ -248,7 +248,7 @@ void gdrom_device::ExecCommand()
{
// TODO: is this correct?
int start_trk = command[2];
int end_trk = cdrom_get_last_track(m_cdrom);
int end_trk = m_cdrom->get_last_track();
int length;
int allocation_length = SCSILengthFromUINT16( &command[ 3 ] );
@ -335,7 +335,7 @@ void gdrom_device::ReadData( uint8_t *data, int dataLength )
{
while (dataLength > 0)
{
if (!cdrom_read_data(m_cdrom, m_lba, tmp_buffer, CD_TRACK_MODE1))
if (!m_cdrom->read_data(m_lba, tmp_buffer, cdrom_file::CD_TRACK_MODE1))
{
LOGWARN("CD read error!\n");
}
@ -387,7 +387,7 @@ void gdrom_device::ReadData( uint8_t *data, int dataLength )
start_trk = 1;
}
end_trk = cdrom_get_last_track(m_cdrom);
end_trk = m_cdrom->get_last_track();
len = (end_trk * 8) + 2;
// the returned TOC DATA LENGTH must be the full amount,
@ -419,13 +419,13 @@ void gdrom_device::ReadData( uint8_t *data, int dataLength )
}
data[dptr++] = 0;
data[dptr++] = cdrom_get_adr_control(m_cdrom, cdrom_track);
data[dptr++] = m_cdrom->get_adr_control(cdrom_track);
data[dptr++] = i;
data[dptr++] = 0;
tstart = cdrom_get_track_start(m_cdrom, cdrom_track);
tstart = m_cdrom->get_track_start(cdrom_track);
if ((command[1]&2)>>1)
tstart = lba_to_msf(tstart);
tstart = cdrom_file::lba_to_msf(tstart);
data[dptr++] = (tstart>>24) & 0xff;
data[dptr++] = (tstart>>16) & 0xff;
data[dptr++] = (tstart>>8) & 0xff;
@ -494,7 +494,7 @@ void gdrom_device::SetDevice(void *device)
// try to find if the mounted chd is from an actual gd-rom disc
if (m_cdrom)
if (cdrom_get_toc(m_cdrom)->flags & CD_FLAG_GDROM)
if (m_cdrom->get_toc().flags & cdrom_file::CD_FLAG_GDROM)
is_real_gdrom_disc = true;
}

View File

@ -113,7 +113,7 @@
#define CURRENT_TRACK_IS_DATA \
(segacd.toc->tracks[SCD_CURTRK - 1].trktype != CD_TRACK_AUDIO)
(segacd.toc->tracks[SCD_CURTRK - 1].trktype != cdrom_file::CD_TRACK_AUDIO)
#define CDD_PLAYINGCDDA 0x0100
#define CDD_READY 0x0400
@ -314,7 +314,7 @@ void lc89510_temp_device::CDD_GetPos(void)
if(segacd.cd == nullptr) // no CD is there, bail out
return;
CDD_STATUS |= SCD_STATUS;
msf = lba_to_msf_alt(SCD_CURLBA+150);
msf = cdrom_file::lba_to_msf_alt(SCD_CURLBA+150);
CDD_MIN = to_bcd(((msf & 0x00ff0000)>>16),false);
CDD_SEC = to_bcd(((msf & 0x0000ff00)>>8),false);
CDD_FRAME = to_bcd(((msf & 0x000000ff)>>0),false);
@ -330,8 +330,8 @@ void lc89510_temp_device::CDD_GetTrackPos(void)
if(segacd.cd == nullptr) // no CD is there, bail out
return;
CDD_STATUS |= SCD_STATUS;
elapsedlba = SCD_CURLBA - segacd.toc->tracks[ cdrom_get_track(segacd.cd, SCD_CURLBA) ].logframeofs;
msf = lba_to_msf_alt (elapsedlba);
elapsedlba = SCD_CURLBA - segacd.toc->tracks[ segacd.cd->get_track(SCD_CURLBA) ].logframeofs;
msf = cdrom_file::lba_to_msf_alt (elapsedlba);
//popmessage("%08x %08x",SCD_CURLBA,segacd.toc->tracks[ cdrom_get_track(segacd.cd, SCD_CURLBA) + 1 ].logframeofs);
CDD_MIN = to_bcd(((msf & 0x00ff0000)>>16),false);
CDD_SEC = to_bcd(((msf & 0x0000ff00)>>8),false);
@ -345,7 +345,7 @@ void lc89510_temp_device::CDD_GetTrack(void)
if(segacd.cd == nullptr) // no CD is there, bail out
return;
CDD_STATUS |= SCD_STATUS;
SCD_CURTRK = cdrom_get_track(segacd.cd, SCD_CURLBA)+1;
SCD_CURTRK = segacd.cd->get_track(SCD_CURLBA)+1;
CDD_MIN = to_bcd(SCD_CURTRK, false);
}
@ -357,8 +357,8 @@ void lc89510_temp_device::CDD_Length(void)
return;
CDD_STATUS |= SCD_STATUS;
uint32_t startlba = (segacd.toc->tracks[cdrom_get_last_track(segacd.cd)].logframeofs);
uint32_t startmsf = lba_to_msf_alt( startlba );
uint32_t startlba = (segacd.toc->tracks[segacd.cd->get_last_track()].logframeofs);
uint32_t startmsf = cdrom_file::lba_to_msf_alt( startlba );
CDD_MIN = to_bcd((startmsf&0x00ff0000)>>16,false);
CDD_SEC = to_bcd((startmsf&0x0000ff00)>>8,false);
@ -374,7 +374,7 @@ void lc89510_temp_device::CDD_FirstLast(void)
return;
CDD_STATUS |= SCD_STATUS;
CDD_MIN = 1; // first
CDD_SEC = to_bcd(cdrom_get_last_track(segacd.cd),false); // last
CDD_SEC = to_bcd(segacd.cd->get_last_track(),false); // last
}
void lc89510_temp_device::CDD_GetTrackAdr(void)
@ -382,7 +382,7 @@ void lc89510_temp_device::CDD_GetTrackAdr(void)
CLEAR_CDD_RESULT
int track = (CDD_TX[5] & 0xF) + (CDD_TX[4] & 0xF) * 10;
int last_track = cdrom_get_last_track(segacd.cd);
int last_track = segacd.cd->get_last_track();
CDD_STATUS &= 0xFF;
if(segacd.cd == nullptr) // no CD is there, bail out
@ -396,14 +396,14 @@ void lc89510_temp_device::CDD_GetTrackAdr(void)
track = 1;
uint32_t startlba = (segacd.toc->tracks[track-1].logframeofs);
uint32_t startmsf = lba_to_msf_alt( startlba+150 );
uint32_t startmsf = cdrom_file::lba_to_msf_alt( startlba+150 );
CDD_MIN = to_bcd((startmsf&0x00ff0000)>>16,false);
CDD_SEC = to_bcd((startmsf&0x0000ff00)>>8,false);
CDD_FRAME = to_bcd((startmsf&0x000000ff)>>0,false);
CDD_EXT = track % 10;
if (segacd.toc->tracks[track - 1].trktype != CD_TRACK_AUDIO)
if (segacd.toc->tracks[track - 1].trktype != cdrom_file::CD_TRACK_AUDIO)
CDD_FRAME |= 0x0800;
}
@ -414,7 +414,7 @@ void lc89510_temp_device::CDD_GetTrackType(void)
CLEAR_CDD_RESULT
int track = (CDD_TX[5] & 0xF) + (CDD_TX[4] & 0xF) * 10;
int last_track = cdrom_get_last_track(segacd.cd);
int last_track = segacd.cd->get_last_track();
CDD_STATUS &= 0xFF;
if(segacd.cd == nullptr) // no CD is there, bail out
@ -427,7 +427,7 @@ void lc89510_temp_device::CDD_GetTrackType(void)
if (track < 1)
track = 1;
if (segacd.toc->tracks[track - 1].trktype != CD_TRACK_AUDIO)
if (segacd.toc->tracks[track - 1].trktype != cdrom_file::CD_TRACK_AUDIO)
{
CDD_EXT = 0x08;
CDD_FRAME |= 0x0800;
@ -452,11 +452,11 @@ void lc89510_temp_device::CDD_Play()
{
CLEAR_CDD_RESULT
uint32_t msf = getmsf_from_regs();
SCD_CURLBA = msf_to_lba(msf)-150;
SCD_CURLBA = cdrom_file::msf_to_lba(msf)-150;
if(segacd.cd == nullptr) // no CD is there, bail out
return;
uint32_t track_length = segacd.toc->tracks[ cdrom_get_track(segacd.cd, SCD_CURLBA) ].logframes;
SCD_CURTRK = cdrom_get_track(segacd.cd, SCD_CURLBA)+1;
uint32_t track_length = segacd.toc->tracks[ segacd.cd->get_track(SCD_CURLBA) ].logframes;
SCD_CURTRK = segacd.cd->get_track(SCD_CURLBA)+1;
LC8951UpdateHeader();
SCD_STATUS = CDD_PLAYINGCDDA;
CDD_STATUS = 0x0102;
@ -477,10 +477,10 @@ void lc89510_temp_device::CDD_Seek(void)
{
CLEAR_CDD_RESULT
uint32_t msf = getmsf_from_regs();
SCD_CURLBA = msf_to_lba(msf)-150;
SCD_CURLBA = cdrom_file::msf_to_lba(msf)-150;
if(segacd.cd == nullptr) // no CD is there, bail out
return;
SCD_CURTRK = cdrom_get_track(segacd.cd, SCD_CURLBA)+1;
SCD_CURTRK = segacd.cd->get_track(SCD_CURLBA)+1;
LC8951UpdateHeader();
STOP_CDC_READ
SCD_STATUS = CDD_READY;
@ -513,7 +513,7 @@ void lc89510_temp_device::CDD_Resume()
STOP_CDC_READ
if(segacd.cd == nullptr) // no CD is there, bail out
return;
SCD_CURTRK = cdrom_get_track(segacd.cd, SCD_CURLBA)+1;
SCD_CURTRK = segacd.cd->get_track(SCD_CURLBA)+1;
SCD_STATUS = CDD_PLAYINGCDDA;
CDD_STATUS = 0x0102;
set_data_audio_mode();
@ -1108,7 +1108,7 @@ void lc89510_temp_device::reset_cd(void)
segacd.cd = m_cdrom->get_cdrom_file();
if ( segacd.cd )
{
segacd.toc = cdrom_get_toc( segacd.cd );
segacd.toc = &segacd.cd->get_toc();
m_cdda->set_cdrom(segacd.cd);
m_cdda->stop_audio(); //stop any pending CD-DA
}
@ -1219,7 +1219,7 @@ void lc89510_temp_device::LC8951UpdateHeader() // neocd
} else {
// HEAD registers have header
uint32_t msf = lba_to_msf_alt(SCD_CURLBA+150);
uint32_t msf = cdrom_file::lba_to_msf_alt(SCD_CURLBA+150);
LC8951RegistersR[REG_R_HEAD0] = to_bcd (((msf & 0x00ff0000)>>16), true); // HEAD0
LC8951RegistersR[REG_R_HEAD1] = to_bcd (((msf & 0x0000ff00)>>8), true); // HEAD1
@ -1333,7 +1333,7 @@ int lc89510_temp_device::Read_LBA_To_Buffer()
if (CDD_CONTROL & 0x0100) data_track = true;
if (data_track)
cdrom_read_data(segacd.cd, SCD_CURLBA, SCD_BUFFER, CD_TRACK_MODE1);
segacd.cd->read_data(SCD_CURLBA, SCD_BUFFER, cdrom_file::CD_TRACK_MODE1);
LC8951UpdateHeader();

View File

@ -92,7 +92,7 @@ protected:
struct segacd_t
{
cdrom_file *cd;
const cdrom_toc *toc;
const cdrom_file::toc *toc;
uint32_t current_frame;
};

View File

@ -960,17 +960,17 @@ void naomi_gdrom_board::device_start()
logerror("key is %08x%08x\n", (uint32_t)((key & 0xffffffff00000000ULL)>>32), (uint32_t)(key & 0x00000000ffffffffULL));
uint8_t buffer[2048];
cdrom_file *gdromfile = cdrom_open(machine().rom_load().get_disk_handle(image_tag));
cdrom_file *gdromfile = new cdrom_file(machine().rom_load().get_disk_handle(image_tag));
// primary volume descriptor
// read frame 0xb06e (frame=sector+150)
// dimm board firmware starts straight from this frame
cdrom_read_data(gdromfile, (netpic ? 0 : 45000) + 16, buffer, CD_TRACK_MODE1);
gdromfile->read_data((netpic ? 0 : 45000) + 16, buffer, cdrom_file::CD_TRACK_MODE1);
uint32_t path_table = ((buffer[0x8c+0] << 0) |
(buffer[0x8c+1] << 8) |
(buffer[0x8c+2] << 16) |
(buffer[0x8c+3] << 24));
// path table
cdrom_read_data(gdromfile, path_table, buffer, CD_TRACK_MODE1);
gdromfile->read_data(path_table, buffer, cdrom_file::CD_TRACK_MODE1);
// directory
uint8_t dir_sector[2048]{};
@ -983,12 +983,12 @@ void naomi_gdrom_board::device_start()
(buffer[0x2 + 2] << 16) |
(buffer[0x2 + 3] << 24));
cdrom_read_data(gdromfile, dir, dir_sector, CD_TRACK_MODE1);
gdromfile->read_data(dir, dir_sector, cdrom_file::CD_TRACK_MODE1);
find_file(name, dir_sector, file_start, file_size);
if (file_start && (file_size == 0x100)) {
// read file
cdrom_read_data(gdromfile, file_start, buffer, CD_TRACK_MODE1);
gdromfile->read_data(file_start, buffer, cdrom_file::CD_TRACK_MODE1);
// get "rom" file name
memset(name, '\0', 128);
memcpy(name, buffer + 0xc0, FILENAME_LENGTH - 1);
@ -1004,7 +1004,7 @@ void naomi_gdrom_board::device_start()
(buffer[i + 4] << 16) |
(buffer[i + 5] << 24));
memcpy(name, "ROM.BIN", 7);
cdrom_read_data(gdromfile, dir, dir_sector, CD_TRACK_MODE1);
gdromfile->read_data(dir, dir_sector, cdrom_file::CD_TRACK_MODE1);
break;
}
i += buffer[i] + 8 + (buffer[i] & 1);
@ -1024,7 +1024,7 @@ void naomi_gdrom_board::device_start()
// read encrypted data into dimm_des_data
uint32_t sectors = file_rounded_size / 2048;
for (uint32_t sec = 0; sec != sectors; sec++)
cdrom_read_data(gdromfile, file_start + sec, &dimm_des_data[2048 * sec], CD_TRACK_MODE1);
gdromfile->read_data(file_start + sec, &dimm_des_data[2048 * sec], cdrom_file::CD_TRACK_MODE1);
uint32_t des_subkeys[32];
des_generate_subkeys(rev64(key), des_subkeys);
@ -1034,7 +1034,7 @@ void naomi_gdrom_board::device_start()
write_from_qword(&dimm_data[i], rev64(des_encrypt_decrypt(true, rev64(read_to_qword(&dimm_des_data[i])), des_subkeys)));
}
cdrom_close(gdromfile);
delete gdromfile;
if(!dimm_data)
throw emu_fatalerror("GDROM: Could not find the file to decrypt.");

View File

@ -261,10 +261,10 @@ void pce_cd_device::late_setup()
m_cd_file = m_cdrom->get_cdrom_file();
if (m_cd_file)
{
m_toc = cdrom_get_toc(m_cd_file);
m_toc = &m_cd_file->get_toc();
m_cdda->set_cdrom(m_cd_file);
m_last_frame = cdrom_get_track_start(m_cd_file, cdrom_get_last_track(m_cd_file) - 1);
m_last_frame += m_toc->tracks[cdrom_get_last_track(m_cd_file) - 1].frames;
m_last_frame = m_cd_file->get_track_start(m_cd_file->get_last_track() - 1);
m_last_frame += m_toc->tracks[m_cd_file->get_last_track() - 1].frames;
m_end_frame = m_last_frame;
}
@ -466,7 +466,7 @@ void pce_cd_device::nec_set_audio_start_position()
frame = f + 75 * (s + m * 60);
// PCE tries to be clever here and set (start of track + track pregap size) to skip the pregap
// (I guess it wants the TOC to have the real start sector for data tracks and the start of the pregap for audio?)
frame -= m_toc->tracks[cdrom_get_track(m_cd_file, frame)].pregap;
frame -= m_toc->tracks[m_cd_file->get_track(frame)].pregap;
break;
}
case 0x80:
@ -503,7 +503,7 @@ void pce_cd_device::nec_set_audio_start_position()
else
{
//m_cdda_status = PCE_CD_CDDA_PLAYING;
m_end_frame = m_toc->tracks[ cdrom_get_track(m_cd_file, m_current_frame) ].logframeofs + m_toc->tracks[ cdrom_get_track(m_cd_file, m_current_frame) ].logframes; //get the end of THIS track
m_end_frame = m_toc->tracks[ m_cd_file->get_track(m_current_frame) ].logframeofs + m_toc->tracks[ m_cd_file->get_track(m_current_frame) ].logframes; //get the end of THIS track
m_cdda->start_audio(m_current_frame, m_end_frame - m_current_frame);
m_end_mark = 0;
m_cdda_play_mode = 3;
@ -637,11 +637,11 @@ void pce_cd_device::nec_get_subq()
break;
}
msf_abs = lba_to_msf_alt(frame);
track = cdrom_get_track(m_cd_file, frame);
msf_rel = lba_to_msf_alt(frame - cdrom_get_track_start(m_cd_file, track));
msf_abs = cdrom_file::lba_to_msf_alt(frame);
track = m_cd_file->get_track(frame);
msf_rel = cdrom_file::lba_to_msf_alt(frame - m_cd_file->get_track_start(track));
m_data_buffer[1] = 0x01 | ((cdrom_get_track_type(m_cd_file, cdrom_get_track(m_cd_file, track+1)) == CD_TRACK_AUDIO) ? 0x00 : 0x40);
m_data_buffer[1] = 0x01 | ((m_cd_file->get_track_type(m_cd_file->get_track(track+1)) == cdrom_file::CD_TRACK_AUDIO) ? 0x00 : 0x40);
m_data_buffer[2] = dec_2_bcd(track+1); /* track */
m_data_buffer[3] = 1; /* index */
m_data_buffer[4] = dec_2_bcd((msf_rel >> 16) & 0xFF);/* M (relative) */
@ -662,7 +662,6 @@ void pce_cd_device::nec_get_subq()
void pce_cd_device::nec_get_dir_info()
{
uint32_t frame, msf, track = 0;
const cdrom_toc *toc;
logerror("nec get dir info\n");
if (!m_cd_file)
@ -671,19 +670,19 @@ void pce_cd_device::nec_get_dir_info()
reply_status_byte(SCSI_CHECK_CONDITION);
}
toc = cdrom_get_toc(m_cd_file);
const cdrom_file::toc &toc = m_cd_file->get_toc();
switch (m_command_buffer[1])
{
case 0x00: /* Get first and last track numbers */
m_data_buffer[0] = dec_2_bcd(1);
m_data_buffer[1] = dec_2_bcd(toc->numtrks);
m_data_buffer[1] = dec_2_bcd(toc.numtrks);
m_data_buffer_size = 2;
break;
case 0x01: /* Get total disk size in MSF format */
frame = toc->tracks[toc->numtrks-1].logframeofs;
frame += toc->tracks[toc->numtrks-1].frames;
msf = lba_to_msf(frame + 150);
frame = toc.tracks[toc.numtrks-1].logframeofs;
frame += toc.tracks[toc.numtrks-1].frames;
msf = cdrom_file::lba_to_msf(frame + 150);
m_data_buffer[0] = (msf >> 16) & 0xFF; /* M */
m_data_buffer[1] = (msf >> 8) & 0xFF; /* S */
@ -693,17 +692,17 @@ void pce_cd_device::nec_get_dir_info()
case 0x02: /* Get track information */
if (m_command_buffer[2] == 0xAA)
{
frame = toc->tracks[toc->numtrks-1].logframeofs;
frame += toc->tracks[toc->numtrks-1].frames;
frame = toc.tracks[toc.numtrks-1].logframeofs;
frame += toc.tracks[toc.numtrks-1].frames;
m_data_buffer[3] = 0x04; /* correct? */
} else
{
track = std::max(bcd_2_dec(m_command_buffer[2]), 1U);
frame = toc->tracks[track-1].logframeofs;
m_data_buffer[3] = (toc->tracks[track-1].trktype == CD_TRACK_AUDIO) ? 0x00 : 0x04;
frame = toc.tracks[track-1].logframeofs;
m_data_buffer[3] = (toc.tracks[track-1].trktype == cdrom_file::CD_TRACK_AUDIO) ? 0x00 : 0x04;
}
logerror("track = %d, frame = %d\n", track, frame);
msf = lba_to_msf(frame + 150);
msf = cdrom_file::lba_to_msf(frame + 150);
m_data_buffer[0] = (msf >> 16) & 0xFF; /* M */
m_data_buffer[1] = (msf >> 8) & 0xFF; /* S */
m_data_buffer[2] = msf & 0xFF; /* F */
@ -978,7 +977,7 @@ TIMER_CALLBACK_MEMBER(pce_cd_device::data_timer_callback)
{
/* Read next data sector */
logerror("read sector %d\n", m_current_frame);
if (! cdrom_read_data(m_cd_file, m_current_frame, m_data_buffer.get(), CD_TRACK_MODE1))
if (! m_cd_file->read_data(m_current_frame, m_data_buffer.get(), cdrom_file::CD_TRACK_MODE1))
{
logerror("Mode1 CD read failed for frame #%d\n", m_current_frame);
}

View File

@ -199,7 +199,7 @@ private:
required_device<cdrom_image_device> m_cdrom;
cdrom_file *m_cd_file = nullptr;
const cdrom_toc* m_toc = nullptr;
const cdrom_file::toc* m_toc = nullptr;
emu_timer *m_data_timer = nullptr;
emu_timer *m_adpcm_dma_timer = nullptr;

View File

@ -473,7 +473,7 @@ void psxcd_device::cdcmd_setloc()
void psxcd_device::cdcmd_play()
{
if(cmdbuf[0] && m_param_count)
loc.w = lba_to_msf_ps(cdrom_get_track_start(m_cdrom_handle, bcd_to_decimal(cmdbuf[0]) - 1));
loc.w = lba_to_msf_ps(m_cdrom_handle->get_track_start(bcd_to_decimal(cmdbuf[0]) - 1));
curpos.w = loc.w;
if (!curpos.w)
@ -631,8 +631,8 @@ void psxcd_device::cdcmd_getlocl()
void psxcd_device::cdcmd_getlocp()
{
CDPOS tloc, start;
uint8_t track = cdrom_get_track(m_cdrom_handle, msf_to_lba_ps(loc.w)) + 1;
start.w = (track == 1) ? 0x000200 : lba_to_msf_ps(cdrom_get_track_start(m_cdrom_handle, track - 1));
uint8_t track = m_cdrom_handle->get_track(msf_to_lba_ps(loc.w)) + 1;
start.w = (track == 1) ? 0x000200 : lba_to_msf_ps(m_cdrom_handle->get_track_start(track - 1));
tloc.w = sub_loc(loc, start);
unsigned char data[8]=
@ -664,7 +664,7 @@ void psxcd_device::cdcmd_gettn()
{
status,
decimal_to_bcd(1),
decimal_to_bcd(cdrom_get_last_track(m_cdrom_handle))
decimal_to_bcd(m_cdrom_handle->get_last_track())
};
send_result(intr_complete,data,3);
@ -678,14 +678,14 @@ void psxcd_device::cdcmd_gettn()
void psxcd_device::cdcmd_gettd()
{
uint8_t track = bcd_to_decimal(cmdbuf[0]);
uint8_t last = cdrom_get_last_track(m_cdrom_handle);
uint8_t last = m_cdrom_handle->get_last_track();
if(track <= last)
{
CDPOS trkstart;
if(!track) // length of disk
trkstart.w = lba_to_msf_ps(cdrom_get_track_start(m_cdrom_handle, 0xaa));
trkstart.w = lba_to_msf_ps(m_cdrom_handle->get_track_start(0xaa));
else
trkstart.w = lba_to_msf_ps(cdrom_get_track_start(m_cdrom_handle, track - 1));
trkstart.w = lba_to_msf_ps(m_cdrom_handle->get_track_start(track - 1));
unsigned char data[3]=
{
@ -760,7 +760,7 @@ void psxcd_device::cdcmd_id()
memset(cdid, '\0', 8);
send_result(intr_complete);
if(cdrom_get_track_type(m_cdrom_handle, 0) == CD_TRACK_AUDIO)
if(m_cdrom_handle->get_track_type(0) == cdrom_file::CD_TRACK_AUDIO)
{
irq = intr_diskerror;
cdid[0] = status | status_invalid;
@ -954,7 +954,7 @@ void psxcd_device::read_sector()
bool isend = false;
uint32_t sector = msf_to_lba_ps(curpos.w);
uint8_t *buf = secbuf[sectail];
if (cdrom_read_data(m_cdrom_handle, sector, buf, CD_TRACK_RAW_DONTCARE))
if (m_cdrom_handle->read_data(sector, buf, cdrom_file::CD_TRACK_RAW_DONTCARE))
{
subheader *sub=(subheader *)(buf+16);
memcpy(lastsechdr, buf+12, 8);
@ -1027,14 +1027,14 @@ void psxcd_device::play_sector()
{
uint32_t sector = msf_to_lba_ps(curpos.w);
if(cdrom_read_data(m_cdrom_handle, sector, secbuf[sectail], CD_TRACK_AUDIO))
if(m_cdrom_handle->read_data(sector, secbuf[sectail], cdrom_file::CD_TRACK_AUDIO))
{
if(!m_mute)
m_spu->play_cdda(0, secbuf[sectail]);
}
else
{
if(!cdrom_read_data(m_cdrom_handle, sector, secbuf[sectail], CD_TRACK_RAW_DONTCARE))
if(!m_cdrom_handle->read_data(sector, secbuf[sectail], cdrom_file::CD_TRACK_RAW_DONTCARE))
{
stop_read(); // assume we've reached the end
cmd_complete(prepare_result(intr_dataend));
@ -1074,7 +1074,7 @@ void psxcd_device::play_sector()
if ((mode&mode_report) && !(sector & 15)) // slow the int rate
{
auto res=new command_result;
uint8_t track = cdrom_get_track(m_cdrom_handle, sector) + 1;
uint8_t track = m_cdrom_handle->get_track(sector) + 1;
res->res=intr_dataready;
res->data[0]=status;
@ -1083,7 +1083,7 @@ void psxcd_device::play_sector()
if(sector & 0x10)
{
CDPOS tloc, start;
start.w = (track == 1) ? 0x000200 : lba_to_msf_ps(cdrom_get_track_start(m_cdrom_handle, track - 1));
start.w = (track == 1) ? 0x000200 : lba_to_msf_ps(m_cdrom_handle->get_track_start(track - 1));
tloc.w = sub_loc(loc, start);
res->data[3]=decimal_to_bcd(tloc.b[M]);
res->data[4]=decimal_to_bcd(tloc.b[S]) | 0x80;
@ -1115,7 +1115,7 @@ void psxcd_device::start_read()
assert((status&(status_reading|status_playing))==0);
if(!(mode & mode_cdda) && (cdrom_get_track_type(m_cdrom_handle, cdrom_get_track(m_cdrom_handle, sector + 150)) == CD_TRACK_AUDIO))
if(!(mode & mode_cdda) && (m_cdrom_handle->get_track_type(m_cdrom_handle->get_track(sector + 150)) == cdrom_file::CD_TRACK_AUDIO))
{
stop_read();
cmd_complete(prepare_result(intr_diskerror, nullptr, 0, 0x40));
@ -1139,9 +1139,9 @@ void psxcd_device::start_read()
void psxcd_device::start_play()
{
uint8_t track = cdrom_get_track(m_cdrom_handle, msf_to_lba_ps(curpos.w) + 150);
uint8_t track = m_cdrom_handle->get_track(msf_to_lba_ps(curpos.w) + 150);
if(cdrom_get_track_type(m_cdrom_handle, track) != CD_TRACK_AUDIO)
if(m_cdrom_handle->get_track_type(track) != cdrom_file::CD_TRACK_AUDIO)
verboselog(*this, 0, "psxcd: playing data track\n");
status|=status_playing;
@ -1150,8 +1150,8 @@ void psxcd_device::start_play()
if (mode&mode_autopause)
{
auto toc = cdrom_get_toc(m_cdrom_handle);
autopause_sector = cdrom_get_track_start(m_cdrom_handle, track) + toc->tracks[track].logframes;
const auto &toc = m_cdrom_handle->get_toc();
autopause_sector = m_cdrom_handle->get_track_start(track) + toc.tracks[track].logframes;
// printf("pos=%d auto=%d\n",pos,autopause_sector);
}

View File

@ -103,8 +103,8 @@ private:
uint8_t bcd_to_decimal(const uint8_t bcd) { return ((bcd>>4)*10)+(bcd&0xf); }
uint8_t decimal_to_bcd(const uint8_t dec) { return ((dec/10)<<4)|(dec%10); }
uint32_t msf_to_lba_ps(uint32_t msf) { msf = msf_to_lba(msf); return (msf>150)?(msf-150):msf; }
uint32_t lba_to_msf_ps(uint32_t lba) { return lba_to_msf_alt(lba+150); }
uint32_t msf_to_lba_ps(uint32_t msf) { msf = cdrom_file::msf_to_lba(msf); return (msf>150)?(msf-150):msf; }
uint32_t lba_to_msf_ps(uint32_t lba) { return cdrom_file::lba_to_msf_alt(lba+150); }
static const unsigned int sector_buffer_size=16, default_irq_delay=16000; //480; //8000; //2000<<2;
static const unsigned int raw_sector_size=2352;

View File

@ -11,7 +11,7 @@
#include "avhuff.h"
#include "aviio.h"
#include "bitmap.h"
#include "chdcd.h"
#include "cdrom.h"
#include "corefile.h"
#include "hashing.h"
#include "md5.h"
@ -309,11 +309,11 @@ public:
// if we have TOC - detect audio sectors and swap data
if (m_toc)
{
assert(offset % CD_FRAME_SIZE == 0);
assert(length % CD_FRAME_SIZE == 0);
assert(offset % cdrom_file::FRAME_SIZE == 0);
assert(length % cdrom_file::FRAME_SIZE == 0);
int startlba = offset / CD_FRAME_SIZE;
int lenlba = length / CD_FRAME_SIZE;
int startlba = offset / cdrom_file::FRAME_SIZE;
int lenlba = length / cdrom_file::FRAME_SIZE;
uint8_t *_dest = reinterpret_cast<uint8_t *>(dest);
for (int chdlba = 0; chdlba < lenlba; chdlba++)
@ -327,11 +327,11 @@ public:
break;
}
// is it audio ?
if (m_toc->tracks[tracknum].trktype != CD_TRACK_AUDIO)
if (m_toc->tracks[tracknum].trktype != cdrom_file::CD_TRACK_AUDIO)
continue;
// byteswap if yes
int dataoffset = chdlba * CD_FRAME_SIZE;
for (uint32_t swapindex = dataoffset; swapindex < (dataoffset + CD_MAX_SECTOR_DATA); swapindex += 2)
int dataoffset = chdlba * cdrom_file::FRAME_SIZE;
for (uint32_t swapindex = dataoffset; swapindex < (dataoffset + cdrom_file::MAX_SECTOR_DATA); swapindex += 2)
{
uint8_t temp = _dest[swapindex];
_dest[swapindex] = _dest[swapindex + 1];
@ -343,7 +343,7 @@ public:
return length;
}
const cdrom_toc * m_toc;
const cdrom_file::toc * m_toc;
private:
// internal state
@ -359,7 +359,7 @@ class chd_cd_compressor : public chd_file_compressor
{
public:
// construction/destruction
chd_cd_compressor(cdrom_toc &toc, chdcd_track_input_info &info)
chd_cd_compressor(cdrom_file::toc &toc, cdrom_file::track_input_info &info)
: m_file(),
m_toc(toc),
m_info(info) { }
@ -372,8 +372,8 @@ public:
virtual uint32_t read_data(void *_dest, uint64_t offset, uint32_t length)
{
// verify assumptions made below
assert(offset % CD_FRAME_SIZE == 0);
assert(length % CD_FRAME_SIZE == 0);
assert(offset % cdrom_file::FRAME_SIZE == 0);
assert(length % cdrom_file::FRAME_SIZE == 0);
// initialize destination to 0 so that unused areas are filled
uint8_t *dest = reinterpret_cast<uint8_t *>(_dest);
@ -384,8 +384,8 @@ public:
uint32_t length_remaining = length;
for (int tracknum = 0; tracknum < m_toc.numtrks; tracknum++)
{
const cdrom_track_info &trackinfo = m_toc.tracks[tracknum];
uint64_t endoffs = startoffs + (uint64_t)(trackinfo.frames + trackinfo.extraframes) * CD_FRAME_SIZE;
const cdrom_file::track_info &trackinfo = m_toc.tracks[tracknum];
uint64_t endoffs = startoffs + (uint64_t)(trackinfo.frames + trackinfo.extraframes) * cdrom_file::FRAME_SIZE;
if (offset >= startoffs && offset < endoffs)
{
// if we don't already have this file open, open it now
@ -412,7 +412,7 @@ public:
while (length_remaining != 0 && offset < endoffs)
{
// determine start of current frame
uint64_t src_frame_start = src_track_start + ((offset - startoffs) / CD_FRAME_SIZE) * bytesperframe;
uint64_t src_frame_start = src_track_start + ((offset - startoffs) / cdrom_file::FRAME_SIZE) * bytesperframe;
// auto-advance next track for split-bin read
if (src_frame_start == split_track_start && m_lastfile.compare(m_info.track[tracknum+1].fname)!=0)
@ -456,9 +456,9 @@ public:
}
// advance
offset += CD_FRAME_SIZE;
dest += CD_FRAME_SIZE;
length_remaining -= CD_FRAME_SIZE;
offset += cdrom_file::FRAME_SIZE;
dest += cdrom_file::FRAME_SIZE;
length_remaining -= cdrom_file::FRAME_SIZE;
if (length_remaining == 0)
break;
}
@ -472,10 +472,10 @@ public:
private:
// internal state
std::string m_lastfile;
util::core_file::ptr m_file;
cdrom_toc & m_toc;
chdcd_track_input_info & m_info;
std::string m_lastfile;
util::core_file::ptr m_file;
cdrom_file::toc & m_toc;
cdrom_file::track_input_info &m_info;
};
@ -1290,7 +1290,7 @@ static void compress_common(chd_file_compressor &chd)
// to a CUE file
//-------------------------------------------------
void output_track_metadata(int mode, util::core_file &file, int tracknum, const cdrom_track_info &info, const std::string &filename, uint32_t frameoffs, uint64_t discoffs)
void output_track_metadata(int mode, util::core_file &file, int tracknum, const cdrom_file::track_info &info, const std::string &filename, uint32_t frameoffs, uint64_t discoffs)
{
if (mode == MODE_GDI)
{
@ -1298,42 +1298,42 @@ void output_track_metadata(int mode, util::core_file &file, int tracknum, const
switch (info.trktype)
{
case CD_TRACK_MODE1:
case cdrom_file::CD_TRACK_MODE1:
mode = 4;
size = 2048;
break;
case CD_TRACK_MODE1_RAW:
case cdrom_file::CD_TRACK_MODE1_RAW:
mode = 4;
size = 2352;
break;
case CD_TRACK_MODE2:
case cdrom_file::CD_TRACK_MODE2:
mode = 4;
size = 2336;
break;
case CD_TRACK_MODE2_FORM1:
case cdrom_file::CD_TRACK_MODE2_FORM1:
mode = 4;
size = 2048;
break;
case CD_TRACK_MODE2_FORM2:
case cdrom_file::CD_TRACK_MODE2_FORM2:
mode = 4;
size = 2324;
break;
case CD_TRACK_MODE2_FORM_MIX:
case cdrom_file::CD_TRACK_MODE2_FORM_MIX:
mode = 4;
size = 2336;
break;
case CD_TRACK_MODE2_RAW:
case cdrom_file::CD_TRACK_MODE2_RAW:
mode = 4;
size = 2352;
break;
case CD_TRACK_AUDIO:
case cdrom_file::CD_TRACK_AUDIO:
mode = 0;
size = 2352;
break;
@ -1352,20 +1352,20 @@ void output_track_metadata(int mode, util::core_file &file, int tracknum, const
std::string tempstr;
switch (info.trktype)
{
case CD_TRACK_MODE1:
case CD_TRACK_MODE1_RAW:
case cdrom_file::CD_TRACK_MODE1:
case cdrom_file::CD_TRACK_MODE1_RAW:
tempstr = string_format("MODE1/%04d", info.datasize);
break;
case CD_TRACK_MODE2:
case CD_TRACK_MODE2_FORM1:
case CD_TRACK_MODE2_FORM2:
case CD_TRACK_MODE2_FORM_MIX:
case CD_TRACK_MODE2_RAW:
case cdrom_file::CD_TRACK_MODE2:
case cdrom_file::CD_TRACK_MODE2_FORM1:
case cdrom_file::CD_TRACK_MODE2_FORM2:
case cdrom_file::CD_TRACK_MODE2_FORM_MIX:
case cdrom_file::CD_TRACK_MODE2_RAW:
tempstr = string_format("MODE2/%04d", info.datasize);
break;
case CD_TRACK_AUDIO:
case cdrom_file::CD_TRACK_AUDIO:
tempstr.assign("AUDIO");
break;
}
@ -1405,15 +1405,15 @@ void output_track_metadata(int mode, util::core_file &file, int tracknum, const
// write out the track type
std::string modesubmode;
if (info.subtype != CD_SUB_NONE)
modesubmode = string_format("%s %s", cdrom_get_type_string(info.trktype), cdrom_get_subtype_string(info.subtype));
if (info.subtype != cdrom_file::CD_SUB_NONE)
modesubmode = string_format("%s %s", cdrom_file::get_type_string(info.trktype), cdrom_file::get_subtype_string(info.subtype));
else
modesubmode = string_format("%s", cdrom_get_type_string(info.trktype));
modesubmode = string_format("%s", cdrom_file::get_type_string(info.trktype));
file.printf("TRACK %s\n", modesubmode);
// write out the attributes
file.printf("NO COPY\n");
if (info.trktype == CD_TRACK_AUDIO)
if (info.trktype == cdrom_file::CD_TRACK_AUDIO)
{
file.printf("NO PRE_EMPHASIS\n");
file.printf("TWO_CHANNEL_AUDIO\n");
@ -1982,12 +1982,12 @@ static void do_create_hd(parameters_map &params)
static void do_create_cd(parameters_map &params)
{
// process input file
chdcd_track_input_info track_info;
cdrom_toc toc = { 0 };
cdrom_file::track_input_info track_info;
cdrom_file::toc toc = { 0 };
auto input_file_str = params.find(OPTION_INPUT);
if (input_file_str != params.end())
{
std::error_condition err = chdcd_parse_toc(input_file_str->second->c_str(), toc, track_info);
std::error_condition err = cdrom_file::parse_toc(input_file_str->second->c_str(), toc, track_info);
if (err)
report_error(1, "Error parsing input file (%s: %s)\n", *input_file_str->second, err.message());
}
@ -1997,8 +1997,8 @@ static void do_create_cd(parameters_map &params)
std::string *output_chd_str = parse_output_chd_parameters(params, output_parent);
// process hunk size
uint32_t hunk_size = output_parent.opened() ? output_parent.hunk_bytes() : CD_FRAMES_PER_HUNK * CD_FRAME_SIZE;
parse_hunk_size(params, CD_FRAME_SIZE, hunk_size);
uint32_t hunk_size = output_parent.opened() ? output_parent.hunk_bytes() : cdrom_file::FRAMES_PER_HUNK * cdrom_file::FRAME_SIZE;
parse_hunk_size(params, cdrom_file::FRAME_SIZE, hunk_size);
// process compression
chd_codec_type compression[4];
@ -2013,9 +2013,9 @@ static void do_create_cd(parameters_map &params)
uint32_t totalsectors = 0;
for (int tracknum = 0; tracknum < toc.numtrks; tracknum++)
{
cdrom_track_info &trackinfo = toc.tracks[tracknum];
int padded = (trackinfo.frames + CD_TRACK_PADDING - 1) / CD_TRACK_PADDING;
trackinfo.extraframes = padded * CD_TRACK_PADDING - trackinfo.frames;
cdrom_file::track_info &trackinfo = toc.tracks[tracknum];
int padded = (trackinfo.frames + cdrom_file::TRACK_PADDING - 1) / cdrom_file::TRACK_PADDING;
trackinfo.extraframes = padded * cdrom_file::TRACK_PADDING - trackinfo.frames;
origtotalsectors += trackinfo.frames;
totalsectors += trackinfo.frames + trackinfo.extraframes;
}
@ -2028,7 +2028,7 @@ static void do_create_cd(parameters_map &params)
printf("Input tracks: %d\n", toc.numtrks);
printf("Input length: %s\n", msf_string_from_frames(origtotalsectors).c_str());
printf("Compression: %s\n", compression_string(compression).c_str());
printf("Logical size: %s\n", big_int_string(uint64_t(totalsectors) * CD_FRAME_SIZE).c_str());
printf("Logical size: %s\n", big_int_string(uint64_t(totalsectors) * cdrom_file::FRAME_SIZE).c_str());
// catch errors so we can close & delete the output file
chd_cd_compressor *chd = nullptr;
@ -2038,14 +2038,14 @@ static void do_create_cd(parameters_map &params)
chd = new chd_cd_compressor(toc, track_info);
std::error_condition err;
if (output_parent.opened())
err = chd->create(output_chd_str->c_str(), uint64_t(totalsectors) * uint64_t(CD_FRAME_SIZE), hunk_size, compression, output_parent);
err = chd->create(output_chd_str->c_str(), uint64_t(totalsectors) * uint64_t(cdrom_file::FRAME_SIZE), hunk_size, compression, output_parent);
else
err = chd->create(output_chd_str->c_str(), uint64_t(totalsectors) * uint64_t(CD_FRAME_SIZE), hunk_size, CD_FRAME_SIZE, compression);
err = chd->create(output_chd_str->c_str(), uint64_t(totalsectors) * uint64_t(cdrom_file::FRAME_SIZE), hunk_size, cdrom_file::FRAME_SIZE, compression);
if (err)
report_error(1, "Error creating CHD file (%s): %s", *output_chd_str, err.message());
// add the standard CD metadata; we do this even if we have a parent because it might be different
err = cdrom_write_metadata(chd, &toc);
err = cdrom_file::write_metadata(chd, toc);
if (err)
report_error(1, "Error adding CD metadata: %s", err.message());
@ -2299,15 +2299,13 @@ static void do_copy(parameters_map &params)
// if we need to re-do the CD metadata, do it now
if (redo_cd)
{
cdrom_file *cdrom = cdrom_open(&input_chd);
if (cdrom == nullptr)
report_error(1, "Error upgrading CD metadata");
const cdrom_toc *toc = cdrom_get_toc(cdrom);
err = cdrom_write_metadata(chd, toc);
cdrom_file *cdrom = new cdrom_file(&input_chd);
const cdrom_file::toc &toc = cdrom->get_toc();
err = cdrom_file::write_metadata(chd, toc);
if (err)
report_error(1, "Error writing upgraded CD metadata: %s", err.message());
if (cdda_swap)
chd->m_toc = toc;
chd->m_toc = &toc;
}
// compress it generically
@ -2418,10 +2416,8 @@ static void do_extract_cd(parameters_map &params)
parse_input_chd_parameters(params, input_chd, input_parent_chd);
// further process input file
cdrom_file *cdrom = cdrom_open(&input_chd);
if (cdrom == nullptr)
report_error(1, "Unable to recognize CHD file as a CD");
const cdrom_toc *toc = cdrom_get_toc(cdrom);
cdrom_file *cdrom = new cdrom_file(&input_chd);
const cdrom_file::toc &toc = cdrom->get_toc();
// verify output file doesn't exist
auto output_file_str = params.find(OPTION_OUTPUT);
@ -2481,20 +2477,20 @@ static void do_extract_cd(parameters_map &params)
// determine total frames
uint64_t total_bytes = 0;
for (int tracknum = 0; tracknum < toc->numtrks; tracknum++)
total_bytes += toc->tracks[tracknum].frames * (toc->tracks[tracknum].datasize + toc->tracks[tracknum].subsize);
for (int tracknum = 0; tracknum < toc.numtrks; tracknum++)
total_bytes += toc.tracks[tracknum].frames * (toc.tracks[tracknum].datasize + toc.tracks[tracknum].subsize);
// GDI must start with the # of tracks
if (mode == MODE_GDI)
{
output_toc_file->printf("%d\n", toc->numtrks);
output_toc_file->printf("%d\n", toc.numtrks);
}
// iterate over tracks and copy all data
uint64_t outputoffs = 0;
uint32_t discoffs = 0;
std::vector<uint8_t> buffer;
for (int tracknum = 0; tracknum < toc->numtrks; tracknum++)
for (int tracknum = 0; tracknum < toc.numtrks; tracknum++)
{
std::string trackbin_name(basename);
@ -2503,7 +2499,7 @@ static void do_extract_cd(parameters_map &params)
char temp[11];
sprintf(temp, "%02d", tracknum+1);
trackbin_name.append(temp);
if (toc->tracks[tracknum].trktype == CD_TRACK_AUDIO)
if (toc.tracks[tracknum].trktype == cdrom_file::CD_TRACK_AUDIO)
trackbin_name.append(".raw");
else
trackbin_name.append(".bin");
@ -2518,7 +2514,7 @@ static void do_extract_cd(parameters_map &params)
}
// output the metadata about the track to the TOC file
const cdrom_track_info &trackinfo = toc->tracks[tracknum];
const cdrom_file::track_info &trackinfo = toc.tracks[tracknum];
if (mode == MODE_GDI)
{
output_track_metadata(mode, *output_toc_file, tracknum, trackinfo, std::string(core_filename_extract_base(trackbin_name)), discoffs, outputoffs);
@ -2530,8 +2526,8 @@ static void do_extract_cd(parameters_map &params)
// If this is bin/cue output and the CHD contains subdata, warn the user and don't include
// the subdata size in the buffer calculation.
uint32_t output_frame_size = trackinfo.datasize + ((trackinfo.subtype != CD_SUB_NONE) ? trackinfo.subsize : 0);
if (trackinfo.subtype != CD_SUB_NONE && ((mode == MODE_CUEBIN) || (mode == MODE_GDI)))
uint32_t output_frame_size = trackinfo.datasize + ((trackinfo.subtype != cdrom_file::CD_SUB_NONE) ? trackinfo.subsize : 0);
if (trackinfo.subtype != cdrom_file::CD_SUB_NONE && ((mode == MODE_CUEBIN) || (mode == MODE_GDI)))
{
printf("Warning: Track %d has subcode data. bin/cue and gdi formats cannot contain subcode data and it will be omitted.\n", tracknum+1);
printf(" : This may affect usage of the output image. Use bin/toc output to keep all data.\n");
@ -2549,11 +2545,11 @@ static void do_extract_cd(parameters_map &params)
progress(false, "Extracting, %.1f%% complete... \r", 100.0 * double(outputoffs) / double(total_bytes));
// read the data
cdrom_read_data(cdrom, cdrom_get_track_start_phys(cdrom, tracknum) + frame, &buffer[bufferoffs], trackinfo.trktype, true);
cdrom->read_data(cdrom->get_track_start_phys(tracknum) + frame, &buffer[bufferoffs], trackinfo.trktype, true);
// for CDRWin and GDI audio tracks must be reversed
// in the case of GDI and CHD version < 5 we assuming source CHD image is GDROM so audio tracks is already reversed
if (((mode == MODE_GDI && input_chd.version() > 4) || (mode == MODE_CUEBIN)) && (trackinfo.trktype == CD_TRACK_AUDIO))
if (((mode == MODE_GDI && input_chd.version() > 4) || (mode == MODE_CUEBIN)) && (trackinfo.trktype == cdrom_file::CD_TRACK_AUDIO))
for (int swapindex = 0; swapindex < trackinfo.datasize; swapindex += 2)
{
uint8_t swaptemp = buffer[bufferoffs + swapindex];
@ -2564,9 +2560,9 @@ static void do_extract_cd(parameters_map &params)
discoffs++;
// read the subcode data
if (trackinfo.subtype != CD_SUB_NONE && (mode == MODE_NORMAL))
if (trackinfo.subtype != cdrom_file::CD_SUB_NONE && (mode == MODE_NORMAL))
{
cdrom_read_subcode(cdrom, cdrom_get_track_start_phys(cdrom, tracknum) + frame, &buffer[bufferoffs], true);
cdrom->read_subcode(cdrom->get_track_start_phys(tracknum) + frame, &buffer[bufferoffs], true);
bufferoffs += trackinfo.subsize;
}