DEV9: Support 8bit reads/writes for most ATA regs

This commit is contained in:
TheLastRar 2024-10-13 16:28:18 +01:00 committed by lightningterror
parent cf157fd2d7
commit 1a95bd3088
3 changed files with 31 additions and 34 deletions

View File

@ -160,8 +160,8 @@ public:
void ATA_HardReset(); void ATA_HardReset();
u16 Read16(u32 addr); u16 Read(u32 addr, int width);
void Write16(u32 addr, u16 value); void Write(u32 addr, u16 value, int width);
void Async(u32 cycles); void Async(u32 cycles);

View File

@ -329,19 +329,23 @@ void ATA::ATA_HardReset()
ResetEnd(true); ResetEnd(true);
} }
u16 ATA::Read16(u32 addr) u16 ATA::Read(u32 addr, int width)
{ {
switch (addr) switch (addr)
{ {
case ATA_R_DATA: case ATA_R_DATA:
if (width == 8)
Console.Error("DEV9:ATA : ATA_R_DATA 8bit read???, Active %s", (GetSelectedDevice() == 0) ? "True" : "False");
//else
// DevCon.WriteLn("DEV9: ATA: ATA_R_DATA %dbit read, Active %s", width, hard, (GetSelectedDevice() == 0) ? "True" : "False");
return ATAreadPIO(); return ATAreadPIO();
case ATA_R_ERROR: case ATA_R_ERROR:
//DevCon.WriteLn("DEV9: *ATA_R_ERROR 16bit read at address %x, value %x, Active %s", addr, regError, (GetSelectedDevice() == 0) ? "True" : "False"); //DevCon.WriteLn("DEV9: ATA: ATA_R_ERROR %dbit read %x, Active %s", width, regError, (GetSelectedDevice() == 0) ? "True" : "False");
if (GetSelectedDevice() != 0) if (GetSelectedDevice() != 0)
return 0; return 0;
return regError; return regError;
case ATA_R_NSECTOR: case ATA_R_NSECTOR:
//DevCon.WriteLn("DEV9: *ATA_R_NSECTOR 16bit read at address %x, value %x, Active %s", addr, nsector, (GetSelectedDevice() == 0) ? "True" : "False"); //DevCon.WriteLn("DEV9: ATA: ATA_R_NSECTOR %dbit read %x, Active %s", width, nsector, (GetSelectedDevice() == 0) ? "True" : "False");
if (GetSelectedDevice() != 0) if (GetSelectedDevice() != 0)
return 0; return 0;
if (!regControlHOBRead) if (!regControlHOBRead)
@ -349,7 +353,7 @@ u16 ATA::Read16(u32 addr)
else else
return regNsectorHOB; return regNsectorHOB;
case ATA_R_SECTOR: case ATA_R_SECTOR:
//DevCon.WriteLn("DEV9: *ATA_R_NSECTOR 16bit read at address %x, value %x, Active %s", addr, regSector, (GetSelectedDevice() == 0) ? "True" : "False"); //DevCon.WriteLn("DEV9: ATA: ATA_R_NSECTOR %dbit read %x, Active %s", width, regSector, (GetSelectedDevice() == 0) ? "True" : "False");
if (GetSelectedDevice() != 0) if (GetSelectedDevice() != 0)
return 0; return 0;
if (!regControlHOBRead) if (!regControlHOBRead)
@ -357,7 +361,7 @@ u16 ATA::Read16(u32 addr)
else else
return regSectorHOB; return regSectorHOB;
case ATA_R_LCYL: case ATA_R_LCYL:
//DevCon.WriteLn("DEV9: *ATA_R_LCYL 16bit read at address %x, value %x, Active %s", addr, regLcyl, (GetSelectedDevice() == 0) ? "True" : "False"); //DevCon.WriteLn("DEV9: ATA: ATA_R_LCYL %dbit read %x, Active %s", width, regLcyl, (GetSelectedDevice() == 0) ? "True" : "False");
if (GetSelectedDevice() != 0) if (GetSelectedDevice() != 0)
return 0; return 0;
if (!regControlHOBRead) if (!regControlHOBRead)
@ -365,7 +369,7 @@ u16 ATA::Read16(u32 addr)
else else
return regLcylHOB; return regLcylHOB;
case ATA_R_HCYL: case ATA_R_HCYL:
//DevCon.WriteLn("DEV9: *ATA_R_HCYL 16bit read at address % x, value % x, Active %s", addr, regHcyl, (GetSelectedDevice() == 0) ? " True " : " False "); //DevCon.WriteLn("DEV9: ATA: ATA_R_HCYL %dbit read %x, Active %s", width, regHcyl, (GetSelectedDevice() == 0) ? " True " : " False ");
if (GetSelectedDevice() != 0) if (GetSelectedDevice() != 0)
return 0; return 0;
if (!regControlHOBRead) if (!regControlHOBRead)
@ -373,30 +377,28 @@ u16 ATA::Read16(u32 addr)
else else
return regHcylHOB; return regHcylHOB;
case ATA_R_SELECT: case ATA_R_SELECT:
//DevCon.WriteLn("DEV9: *ATA_R_SELECT 16bit read at address % x, value % x, Active %s", addr, regSelect, (GetSelectedDevice() == 0) ? " True " : " False "); //DevCon.WriteLn("DEV9: ATA: ATA_R_SELECT %dbit read %x, Active %s", width, regSelect, (GetSelectedDevice() == 0) ? " True " : " False ");
return regSelect; return regSelect;
case ATA_R_STATUS: case ATA_R_STATUS:
//DevCon.WriteLn("DEV9: *ATA_R_STATUS (Fallthough to ATA_R_ALT_STATUS)"); // Clear irqcause
//Clear irqcause
dev9.irqcause &= ~ATA_INTR_INTRQ; dev9.irqcause &= ~ATA_INTR_INTRQ;
[[fallthrough]]; [[fallthrough]];
case ATA_R_ALT_STATUS: 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 "); //DevCon.WriteLn("DEV9: ATA: %s %dbit read %x, Active %s", addr == ATA_R_ALT_STATUS ? "ATA_R_ALT_STATUS" : "ATA_R_STATUS", width, regStatus, (GetSelectedDevice() == 0) ? " True " : " False ");
if (!EmuConfig.DEV9.HddEnable) if (!EmuConfig.DEV9.HddEnable)
return 0xff7f; // PS2 confirmed response when no HDD is actually connected. The Expansion bay always says HDD support is connected. 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) if (GetSelectedDevice() != 0)
return 0; return 0;
return regStatus; return regStatus;
default: default:
Console.Error("DEV9: ATA: Unknown 16bit read at address %x", addr); Console.Error("DEV9: ATA: Unknown %dbit read at address %x", width, addr);
return 0xff; return 0xff;
} }
} }
void ATA::Write16(u32 addr, u16 value) void ATA::Write(u32 addr, u16 value, int width)
{ {
if (addr != ATA_R_CMD && (regStatus & (ATA_STAT_BUSY | ATA_STAT_DRQ)) != 0) if (addr != ATA_R_CMD && (regStatus & (ATA_STAT_BUSY | ATA_STAT_DRQ)) != 0)
{ {
@ -406,47 +408,46 @@ void ATA::Write16(u32 addr, u16 value)
switch (addr) switch (addr)
{ {
case ATA_R_FEATURE: case ATA_R_FEATURE:
//DevCon.WriteLn("DEV9: *ATA_R_FEATURE 16bit write at address %x, value %x", addr, value); //DevCon.WriteLn("DEV9: ATA: ATA_R_FEATURE %dbit write %x", width, value);
ClearHOB(); ClearHOB();
regFeatureHOB = regFeature; regFeatureHOB = regFeature;
regFeature = static_cast<u8>(value); regFeature = static_cast<u8>(value);
break; break;
case ATA_R_NSECTOR: case ATA_R_NSECTOR:
//DevCon.WriteLn("DEV9: *ATA_R_NSECTOR 16bit write at address %x, value %x", addr, value); //DevCon.WriteLn("DEV9: ATA: ATA_R_NSECTOR %dbit write %x", width, value);
ClearHOB(); ClearHOB();
regNsectorHOB = regNsector; regNsectorHOB = regNsector;
regNsector = static_cast<u8>(value); regNsector = static_cast<u8>(value);
break; break;
case ATA_R_SECTOR: case ATA_R_SECTOR:
//DevCon.WriteLn("DEV9: *ATA_R_SECTOR 16bit write at address %x, value %x", addr, value); //DevCon.WriteLn("DEV9: ATA: ATA_R_SECTOR %dbit write %x", width, value);
ClearHOB(); ClearHOB();
regSectorHOB = regSector; regSectorHOB = regSector;
regSector = static_cast<u8>(value); regSector = static_cast<u8>(value);
break; break;
case ATA_R_LCYL: case ATA_R_LCYL:
//DevCon.WriteLn("DEV9: *ATA_R_LCYL 16bit write at address %x, value %x", addr, value); //DevCon.WriteLn("DEV9: ATA: ATA_R_LCYL %dbit write %x", width, value);
ClearHOB(); ClearHOB();
regLcylHOB = regLcyl; regLcylHOB = regLcyl;
regLcyl = static_cast<u8>(value); regLcyl = static_cast<u8>(value);
break; break;
case ATA_R_HCYL: case ATA_R_HCYL:
//DevCon.WriteLn("DEV9: *ATA_R_HCYL 16bit write at address %x, value %x", addr, value); //DevCon.WriteLn("DEV9: ATA: ATA_R_HCYL %dbit write %x", width, value);
ClearHOB(); ClearHOB();
regHcylHOB = regHcyl; regHcylHOB = regHcyl;
regHcyl = static_cast<u8>(value); regHcyl = static_cast<u8>(value);
break; break;
case ATA_R_SELECT: case ATA_R_SELECT:
//DevCon.WriteLn("DEV9: *ATA_R_SELECT 16bit write at address %x, value %x", addr, value); //DevCon.WriteLn("DEV9: ATA: ATA_R_SELECT %dbit write %x", width, value);
regSelect = static_cast<u8>(value); regSelect = static_cast<u8>(value);
//bus->ifs[0].select = (val & ~0x10) | 0xa0; //bus->ifs[0].select = (val & ~0x10) | 0xa0;
//bus->ifs[1].select = (val | 0x10) | 0xa0; //bus->ifs[1].select = (val | 0x10) | 0xa0;
break; break;
case ATA_R_CONTROL: case ATA_R_CONTROL:
//DevCon.WriteLn("DEV9: *ATA_R_CONTROL 16bit write at address %x, value %x", addr, value); //DevCon.WriteLn("DEV9: ATA: ATA_R_CONTROL %dbit write %x", width, value);
//dev9Ru16(ATA_R_CONTROL) = value;
if ((value & 0x2) != 0) if ((value & 0x2) != 0)
{ {
//Supress all IRQ // Suppress all IRQ
dev9.irqcause &= ~ATA_INTR_INTRQ; dev9.irqcause &= ~ATA_INTR_INTRQ;
regControlEnableIRQ = false; regControlEnableIRQ = false;
} }
@ -464,14 +465,14 @@ void ATA::Write16(u32 addr, u16 value)
break; break;
case ATA_R_CMD: case ATA_R_CMD:
//DevCon.WriteLn("DEV9: *ATA_R_CMD 16bit write at address %x, value %x", addr, value); //DevCon.WriteLn("DEV9: ATA: ATA_R_CMD %dbit write %x", width, value);
regCommand = value; regCommand = value;
regControlHOBRead = false; regControlHOBRead = false;
dev9.irqcause &= ~ATA_INTR_INTRQ; dev9.irqcause &= ~ATA_INTR_INTRQ;
IDE_ExecCmd(value); IDE_ExecCmd(value);
break; break;
default: default:
Console.Error("DEV9: ATA: UNKNOWN 16bit write at address %x, value %x", addr, value); Console.Error("DEV9: ATA: Unknown %dbit write at address %x, value %x", width, addr, value);
break; break;
} }
} }

View File

@ -704,8 +704,7 @@ u8 DEV9read8(u32 addr)
if (addr >= ATA_DEV9_HDD_BASE && addr < ATA_DEV9_HDD_END) if (addr >= ATA_DEV9_HDD_BASE && addr < ATA_DEV9_HDD_END)
{ {
Console.Error("DEV9: ATA does not support 8bit reads %lx", addr); return dev9.ata->Read(addr, 8);
return 0;
} }
// Note, ATA regs within range of addresses used by Speed // Note, ATA regs within range of addresses used by Speed
if (addr >= SPD_REGBASE && addr < SMAP_REGBASE) if (addr >= SPD_REGBASE && addr < SMAP_REGBASE)
@ -745,7 +744,7 @@ u16 DEV9read16(u32 addr)
if (addr >= ATA_DEV9_HDD_BASE && addr < ATA_DEV9_HDD_END) if (addr >= ATA_DEV9_HDD_BASE && addr < ATA_DEV9_HDD_END)
{ {
return dev9.ata->Read16(addr); return dev9.ata->Read(addr, 16);
} }
// Note, ATA regs within range of addresses used by Speed // Note, ATA regs within range of addresses used by Speed
if (addr >= SPD_REGBASE && addr < SMAP_REGBASE) if (addr >= SPD_REGBASE && addr < SMAP_REGBASE)
@ -811,10 +810,7 @@ void DEV9write8(u32 addr, u8 value)
if (addr >= ATA_DEV9_HDD_BASE && addr < ATA_DEV9_HDD_END) if (addr >= ATA_DEV9_HDD_BASE && addr < ATA_DEV9_HDD_END)
{ {
#ifdef ENABLE_ATA dev9.ata->Write(addr, value, 8);
ata_write<1>(addr, value);
#endif
Console.Error("DEV9: ATA does not support 8bit writes %lx", addr);
return; return;
} }
// Note, ATA regs within range of addresses used by Speed // Note, ATA regs within range of addresses used by Speed
@ -847,7 +843,7 @@ void DEV9write16(u32 addr, u16 value)
if (addr >= ATA_DEV9_HDD_BASE && addr < ATA_DEV9_HDD_END) if (addr >= ATA_DEV9_HDD_BASE && addr < ATA_DEV9_HDD_END)
{ {
dev9.ata->Write16(addr, value); dev9.ata->Write(addr, value, 16);
return; return;
} }
// Note, ATA regs within range of addresses used by Speed // Note, ATA regs within range of addresses used by Speed