From 04acf120d6cdd0ee2e19a2765948d4c95f751f2e Mon Sep 17 00:00:00 2001 From: Maxim Poliakovski Date: Tue, 19 Sep 2023 14:15:59 +0200 Subject: [PATCH] dbdma: support optinal CommandPtrHi register. It's written with zero in OS X. This dummy implementation is meant to reduce log warnings. --- devices/common/dbdma.cpp | 3 +++ devices/common/dbdma.h | 1 + 2 files changed, 4 insertions(+) diff --git a/devices/common/dbdma.cpp b/devices/common/dbdma.cpp index 08019e1..9b0a7f5 100644 --- a/devices/common/dbdma.cpp +++ b/devices/common/dbdma.cpp @@ -263,6 +263,9 @@ void DMAChannel::reg_write(uint32_t offset, uint32_t value, int size) { break; case DMAReg::CH_STAT: break; // ingore writes to ChannelStatus + case DMAReg::CMD_PTR_HI: // Mac OS X writes this optional register with zero + LOG_F(9, "CommandPtrHi set to 0x%X", value); + break; case DMAReg::CMD_PTR_LO: if (!(this->ch_stat & CH_STAT_RUN) && !(this->ch_stat & CH_STAT_ACTIVE)) { this->cmd_ptr = value; diff --git a/devices/common/dbdma.h b/devices/common/dbdma.h index fc3a405..67dabad 100644 --- a/devices/common/dbdma.h +++ b/devices/common/dbdma.h @@ -39,6 +39,7 @@ along with this program. If not, see . enum DMAReg : uint32_t { CH_CTRL = 0, CH_STAT = 4, + CMD_PTR_HI = 8, CMD_PTR_LO = 12, INT_SELECT = 16, BRANCH_SELECT = 20,