CDImage: Better handle sequential reading into lead-out area

This commit is contained in:
Connor McLaughlin 2020-05-08 17:35:55 +10:00
parent 684e83168e
commit 712168cf45
1 changed files with 6 additions and 5 deletions

View File

@ -233,7 +233,6 @@ bool CDImage::GenerateSubChannelQ(SubChannelQ* subq, LBA lba)
return false; return false;
const u32 index_offset = index->start_lba_on_disc - lba; const u32 index_offset = index->start_lba_on_disc - lba;
;
GenerateSubChannelQ(subq, index, index_offset); GenerateSubChannelQ(subq, index, index_offset);
return true; return true;
} }
@ -241,7 +240,7 @@ bool CDImage::GenerateSubChannelQ(SubChannelQ* subq, LBA lba)
void CDImage::GenerateSubChannelQ(SubChannelQ* subq, const Index* index, u32 index_offset) void CDImage::GenerateSubChannelQ(SubChannelQ* subq, const Index* index, u32 index_offset)
{ {
subq->control.bits = index->control.bits; subq->control.bits = index->control.bits;
subq->track_number_bcd = BinaryToBCD(index->track_number); subq->track_number_bcd = (index->track_number <= m_tracks.size() ? BinaryToBCD(index->track_number) : index->track_number);
subq->index_number_bcd = BinaryToBCD(index->index_number); subq->index_number_bcd = BinaryToBCD(index->index_number);
const Position relative_position = const Position relative_position =
@ -256,13 +255,15 @@ void CDImage::GenerateSubChannelQ(SubChannelQ* subq, const Index* index, u32 ind
void CDImage::AddLeadOutIndex() void CDImage::AddLeadOutIndex()
{ {
Assert(!m_indices.empty());
const Index& last_index = m_indices.back();
Index index = {}; Index index = {};
index.start_lba_on_disc = m_lba_count; index.start_lba_on_disc = last_index.start_lba_on_disc + last_index.length;
index.length = LEAD_OUT_SECTOR_COUNT; index.length = LEAD_OUT_SECTOR_COUNT;
index.track_number = LEAD_OUT_TRACK_NUMBER; index.track_number = LEAD_OUT_TRACK_NUMBER;
index.index_number = 0; index.index_number = 0;
if (!m_indices.empty()) index.control.bits = last_index.control.bits;
index.control.bits = m_indices.back().control.bits;
m_indices.push_back(index); m_indices.push_back(index);
} }