VirtualBox

Changeset 108765 in vbox for trunk/src


Ignore:
Timestamp:
Mar 27, 2025 10:59:19 AM (3 weeks ago)
Author:
vboxsync
svn:sync-xref-src-repo-rev:
168192
Message:

VMM/GIC: bugref:10877 GITS work-in-progress.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/VMM/VMMAll/GITSAll.cpp

    r108764 r108765  
    107107DECL_HIDDEN_CALLBACK(VBOXSTRICTRC) gitsMmioReadCtrl(PCGITSDEV pGitsDev, uint16_t offReg, uint32_t *puValue)
    108108{
     109    /*
     110     * GITS_BASER<n>.
     111     */
     112    if (GITS_IS_REG_IN_RANGE(offReg, GITS_CTRL_REG_BASER_OFF_FIRST,  GITS_CTRL_REG_BASER_RANGE_SIZE))
     113    {
     114        uint16_t const cbReg  = sizeof(uint64_t);
     115        uint16_t const idxReg = (offReg - GITS_CTRL_REG_BASER_OFF_FIRST) / cbReg;
     116        if (!(offReg & 7))
     117            *puValue = pGitsDev->aItsTableRegs[idxReg].s.Lo;
     118        else
     119            *puValue = pGitsDev->aItsTableRegs[idxReg].s.Hi;
     120        return VINF_SUCCESS;
     121    }
     122
    109123    VBOXSTRICTRC rcStrict = VINF_SUCCESS;
    110124    switch (offReg)
     
    165179
    166180        default:
    167             AssertReleaseMsgFailed(("offReg=%#x\n", offReg));
     181            AssertReleaseMsgFailed(("offReg=%#x (%s)\n", offReg, gitsGetCtrlRegDescription(offReg)));
    168182            break;
    169183    }
     
    206220
    207221        default:
    208             AssertReleaseMsgFailed(("offReg=%#x uValue=%#RX32\n", offReg, uValue));
     222            AssertReleaseMsgFailed(("offReg=%#x (%s) uValue=%#RX32\n", offReg, gitsGetCtrlRegDescription(offReg), uValue));
    209223            break;
    210224    }
Note: See TracChangeset for help on using the changeset viewer.

© 2025 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette