From 2e95e59f40260f8985f37c39154cb9a986b4904a Mon Sep 17 00:00:00 2001 From: refractionpcsx2 Date: Thu, 1 Feb 2024 23:38:06 +0000 Subject: [PATCH] DEV9: Fix HDD Response when no HDD is connected --- pcsx2/DEV9/ATA/ATA_State.cpp | 4 ++++ pcsx2/DEV9/DEV9.cpp | 11 +++++++---- 2 files changed, 11 insertions(+), 4 deletions(-) diff --git a/pcsx2/DEV9/ATA/ATA_State.cpp b/pcsx2/DEV9/ATA/ATA_State.cpp index 83b91bdf04..d8288916d8 100644 --- a/pcsx2/DEV9/ATA/ATA_State.cpp +++ b/pcsx2/DEV9/ATA/ATA_State.cpp @@ -381,6 +381,10 @@ u16 ATA::Read16(u32 addr) [[fallthrough]]; case ATA_R_ALT_STATUS: //DevCon.WriteLn("DEV9: *ATA_R_ALT_STATUS 16bit read at address % x, value % x, Active %s", addr, regStatus, (GetSelectedDevice() == 0) ? " True " : " False "); + + if (!EmuConfig.DEV9.HddEnable) + return 0xff7f; // PS2 confirmed response when no HDD is actually connected. The Expansion bay always says HDD support is connected. + //raise IRQ? if (GetSelectedDevice() != 0) return 0; diff --git a/pcsx2/DEV9/DEV9.cpp b/pcsx2/DEV9/DEV9.cpp index fae767104c..7be27825a0 100644 --- a/pcsx2/DEV9/DEV9.cpp +++ b/pcsx2/DEV9/DEV9.cpp @@ -357,6 +357,7 @@ u16 DEV9read16(u32 addr) { return dev9.ata->Read16(addr); } + if (addr >= SMAP_REGBASE && addr < FLASH_REGBASE) { //smap @@ -419,16 +420,18 @@ u16 DEV9read16(u32 addr) return hard; case SPD_R_REV_3: - if (EmuConfig.DEV9.HddEnable) - hard |= SPD_CAPS_ATA; + // The Expansion bay always says HDD and Ethernet are supported, we need to keep HDD enabled and we handle it elsewhere. + // Ethernet we will turn off as not sure on what that would do right now, but no known game cares if it's off. if (EmuConfig.DEV9.EthEnable) hard |= SPD_CAPS_SMAP; - hard |= SPD_CAPS_FLASH; + + // TODO: Do we need flash? my 50003 model doesn't report this, but it does report DVR capable aka (1<<4), was that intended? + hard |= SPD_CAPS_ATA | SPD_CAPS_FLASH; //DevCon.WriteLn("DEV9: SPD_R_REV_3 16bit read %x", hard); return hard; case SPD_R_0e: - hard = 0x0002; //Have HDD inserted + hard = 0x0002; //Have HDD module inserted DevCon.WriteLn("DEV9: SPD_R_0e 16bit read %x", hard); return hard; case SPD_R_XFR_CTRL: