VirtualBox

Changeset 11509 in vbox for trunk/src/VBox/VMM


Ignore:
Timestamp:
Aug 20, 2008 10:58:44 AM (16 years ago)
Author:
vboxsync
Message:

Added R0/HC emulation of (lock) cmpxchg. Not activated.

File:
1 edited

Legend:

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

    r11492 r11509  
    14391439 * [LOCK] CMPXCHG emulation.
    14401440 */
    1441 #ifdef IN_GC
     1441#ifndef IN_GC
     1442static int emInterpretCmpXchg(PVM pVM, PDISCPUSTATE pCpu, PCPUMCTXCORE pRegFrame, RTGCPTR pvFault, uint32_t *pcbSize)
     1443{
     1444    OP_PARAMVAL param1, param2;
     1445
     1446#ifdef LOG_ENABLED
     1447    const char *pszInstr;
     1448
     1449    if (pCpu->prefix & PREFIX_LOCK)
     1450        pszInstr = "Lock CmpXchg";
     1451    else
     1452        pszInstr = "CmpXchg";
     1453#endif
     1454
     1455    /* Source to make DISQueryParamVal read the register value - ugly hack */
     1456    int rc = DISQueryParamVal(pRegFrame, pCpu, &pCpu->param1, &param1, PARAM_SOURCE);
     1457    if(VBOX_FAILURE(rc))
     1458        return VERR_EM_INTERPRETER;
     1459
     1460    rc = DISQueryParamVal(pRegFrame, pCpu, &pCpu->param2, &param2, PARAM_SOURCE);
     1461    if(VBOX_FAILURE(rc))
     1462        return VERR_EM_INTERPRETER;
     1463
     1464    RTGCPTR  GCPtrPar1;
     1465    void    *pvParam1;
     1466    uint64_t valpar, eflags;
     1467
     1468    AssertReturn(pCpu->param1.size == pCpu->param2.size, VERR_EM_INTERPRETER);
     1469    switch(param1.type)
     1470    {
     1471    case PARMTYPE_ADDRESS:
     1472        GCPtrPar1 = param1.val.val64;
     1473        GCPtrPar1 = emConvertToFlatAddr(pVM, pRegFrame, pCpu, &pCpu->param1, GCPtrPar1);
     1474
     1475        rc = PGMPhysGCPtr2HCPtr(pVM, GCPtrPar1, &pvParam1);
     1476        if (VBOX_FAILURE(rc))
     1477        {
     1478            AssertRC(rc);
     1479            return VERR_EM_INTERPRETER;
     1480        }
     1481        break;
     1482
     1483    default:
     1484        return VERR_EM_INTERPRETER;
     1485    }
     1486
     1487    switch(param2.type)
     1488    {
     1489    case PARMTYPE_IMMEDIATE: /* register actually */
     1490        valpar = param2.val.val64;
     1491        break;
     1492
     1493    default:
     1494        return VERR_EM_INTERPRETER;
     1495    }
     1496
     1497    LogFlow(("%s %VGv rax=%RX64 %RX64\n", pszInstr, GCPtrPar1, pRegFrame->rax, valpar));
     1498
     1499    if (pCpu->prefix & PREFIX_LOCK)
     1500        eflags = EMEmulateLockCmpXchg(pvParam1, &pRegFrame->rax, valpar, pCpu->param2.size);
     1501    else
     1502        eflags = EMEmulateCmpXchg(pvParam1, &pRegFrame->rax, valpar, pCpu->param2.size);
     1503   
     1504    LogFlow(("%s %VGv rax=%RX64 %RX64 ZF=%d\n", pszInstr, GCPtrPar1, pRegFrame->rax, valpar, !!(eflags & X86_EFL_ZF)));
     1505
     1506    /* Update guest's eflags and finish. */
     1507    pRegFrame->eflags.u32 = (pRegFrame->eflags.u32 & ~(X86_EFL_CF | X86_EFL_PF | X86_EFL_AF | X86_EFL_ZF | X86_EFL_SF | X86_EFL_OF))
     1508                            | (eflags                &  (X86_EFL_CF | X86_EFL_PF | X86_EFL_AF | X86_EFL_ZF | X86_EFL_SF | X86_EFL_OF));
     1509
     1510    *pcbSize = param2.size;
     1511    return VINF_SUCCESS;
     1512}
     1513
     1514#else
    14421515static int emInterpretCmpXchg(PVM pVM, PDISCPUSTATE pCpu, PCPUMCTXCORE pRegFrame, RTGCPTR pvFault, uint32_t *pcbSize)
    14431516{
Note: See TracChangeset for help on using the changeset viewer.

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