From 116dc0e1ed9313a4cba19d63cf68b4a12bcd5237 Mon Sep 17 00:00:00 2001 From: Flyinghead Date: Thu, 25 Jan 2024 12:36:04 +0100 Subject: [PATCH] gdrom: don't rely on Status in libGDR_GetDiscType Status is Busy when disk swapping is in progress so libGDR_GetDiscType always returns NoDisk/Open. Rely on the scheduler instead so that the correct type is returned when disk swapping is finished. Issue #1046 Issue #189 --- core/imgread/common.cpp | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/core/imgread/common.cpp b/core/imgread/common.cpp index bdbb8a72b..1a841372b 100644 --- a/core/imgread/common.cpp +++ b/core/imgread/common.cpp @@ -305,7 +305,8 @@ void libGDR_ReadSubChannel(u8 * buff, u32 len) u32 libGDR_GetDiscType() { - if (SecNumber.Status != GD_BUSY && disc != nullptr) + // Pretend no disk is inserted if a disk swapping is in progress + if (!sh4_sched_is_scheduled(schedId) && disc != nullptr) return disc->type; else return NullDriveDiscType; @@ -319,8 +320,8 @@ static int discSwapCallback(int tag, int sch_cycl, int jitter, void *arg) else // No disc inserted at the time of power-on, reset or hard reset, or TOC cannot be read. sns_asc = 0x29; - sns_ascq = 0x00; - sns_key = 0x6; + sns_ascq = 0; + sns_key = 6; gd_setdisc(); return 0; @@ -342,6 +343,7 @@ bool DiscSwap(const std::string& path) void libGDR_init() { + verify(schedId == -1); schedId = sh4_sched_register(0, discSwapCallback); } void libGDR_term()