From 2ca0530f2a8ddd4f34dce3d0fc3d440260d5fcd8 Mon Sep 17 00:00:00 2001 From: Ty Lamontagne Date: Wed, 27 Nov 2024 14:54:44 -0500 Subject: [PATCH] CDVD | CHD: Account for pre/post gap offsets when filling TOC This will fix discs with tracks with both an INDEX 00 and INDEX 01 --- pcsx2/CDVD/ChdFileReader.cpp | 15 ++++++--------- 1 file changed, 6 insertions(+), 9 deletions(-) diff --git a/pcsx2/CDVD/ChdFileReader.cpp b/pcsx2/CDVD/ChdFileReader.cpp index 112542631ab17d..60d60af2867a09 100644 --- a/pcsx2/CDVD/ChdFileReader.cpp +++ b/pcsx2/CDVD/ChdFileReader.cpp @@ -281,7 +281,7 @@ bool ChdFileReader::ParseTOC(u64* out_frame_count, std::vector& entri { u64 total_frames = 0; int max_found_track = -1; - + u64 total_gap_frames = 0; for (int search_index = 0;; search_index++) { char metadata_str[256]; @@ -327,7 +327,7 @@ bool ChdFileReader::ParseTOC(u64* out_frame_count, std::vector& entri if (track_num != 0) { toc_entry entry{}; - entry.lba = static_cast(total_frames); + entry.lba = static_cast(total_frames) - total_gap_frames; entry.track = static_cast(track_num); entry.adr = 1; entry.control = 0; @@ -338,14 +338,11 @@ bool ChdFileReader::ParseTOC(u64* out_frame_count, std::vector& entri entries.push_back(entry); } - // PCSX2 doesn't currently support multiple tracks for CDs. - /* if (track_num != 1) - { - Console.Warning(fmt::format(" Ignoring track {} in CHD.", track_num, frames)); - continue; - }*/ - total_frames += static_cast(pregap_frames) + static_cast(frames) + static_cast(postgap_frames); + // I have not found a CHD with an audio track with a postgap, consider that untested + total_gap_frames += static_cast(pregap_frames) + static_cast(postgap_frames); + total_frames += total_gap_frames + static_cast(frames); + max_found_track = std::max(max_found_track, track_num); }