VirtualBox

Changeset 29742 in vbox for trunk/src/VBox/Devices


Ignore:
Timestamp:
May 21, 2010 3:58:56 PM (15 years ago)
Author:
vboxsync
Message:

wddm/2D: more impl (get caps + initialization working)

Location:
trunk/src/VBox/Devices/Graphics
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/Devices/Graphics/DevVGA.h

    r28800 r29742  
    408408    /** Base port in the assigned PCI I/O space. */
    409409    RTIOPORT                    IOPortBase;
     410#ifdef VBOXVDMA
     411    /* specifies guest driver caps, i.e. whether it can handle IRQs from the adapter,
     412     * the way it can handle assync HGSMI command completion, etc. */
     413    uint32_t                    fGuestCaps;
     414#endif
     415
    410416    uint8_t                     Padding7[6];
    411417#endif /* VBOX_WITH_HGSMI */
  • trunk/src/VBox/Devices/Graphics/DevVGA_VBVA.cpp

    r28800 r29742  
    12441244        PVGASTATE pVGAState = PPDMIDISPLAYVBVACALLBACKS_2_PVGASTATE(pInterface);
    12451245        PHGSMIINSTANCE pIns = pVGAState->pHGSMI;
    1246         VBVAHOSTCMD *pHostCmd;
    1247     //    Assert(0);
    1248 
    1249         int32_t iDisplay = pCmd->iDisplay;
     1246
    12501247        Assert(pCmd->Flags & VBOXVHWACMD_FLAG_HG_ASYNCH);
    1251         if(pCmd->Flags & VBOXVHWACMD_FLAG_GH_ASYNCH_EVENT)
    1252         {
    1253             rc = HGSMIHostCommandAlloc (pIns,
    1254                                           (void**)&pHostCmd,
    1255                                           VBVAHOSTCMD_SIZE(sizeof(VBVAHOSTCMDEVENT)),
    1256                                           HGSMI_CH_VBVA,
    1257                                           VBVAHG_EVENT);
     1248#ifdef VBOXVDMA
     1249        if (pVGAState->fGuestCaps & VBVACAPS_COMPLETEGCMD_BY_IOREAD)
     1250        {
     1251            rc = HGSMICompleteGuestCommand(pIns, pCmd, !!(pCmd->Flags & VBOXVHWACMD_FLAG_GH_ASYNCH_IRQ));
    12581252            AssertRC(rc);
    1259             if(RT_SUCCESS(rc))
    1260             {
    1261                 memset(pHostCmd, 0 , VBVAHOSTCMD_SIZE(sizeof(VBVAHOSTCMDEVENT)));
    1262                 pHostCmd->iDstID = pCmd->iDisplay;
    1263                 pHostCmd->customOpCode = 0;
    1264                 VBVAHOSTCMDEVENT *pBody = VBVAHOSTCMD_BODY(pHostCmd, VBVAHOSTCMDEVENT);
    1265                 pBody->pEvent = pCmd->GuestVBVAReserved1;
    1266             }
    12671253        }
    12681254        else
    1269         {
    1270             HGSMIOFFSET offCmd = HGSMIPointerToOffsetHost (pIns, pCmd);
    1271             Assert(offCmd != HGSMIOFFSET_VOID);
    1272             if(offCmd != HGSMIOFFSET_VOID)
     1255#endif
     1256        {
     1257            VBVAHOSTCMD *pHostCmd;
     1258            int32_t iDisplay = pCmd->iDisplay;
     1259
     1260            if(pCmd->Flags & VBOXVHWACMD_FLAG_GH_ASYNCH_EVENT)
    12731261            {
    12741262                rc = HGSMIHostCommandAlloc (pIns,
    1275                                           (void**)&pHostCmd,
    1276                                           VBVAHOSTCMD_SIZE(sizeof(VBVAHOSTCMDVHWACMDCOMPLETE)),
    1277                                           HGSMI_CH_VBVA,
    1278                                           VBVAHG_DISPLAY_CUSTOM);
     1263                                              (void**)&pHostCmd,
     1264                                              VBVAHOSTCMD_SIZE(sizeof(VBVAHOSTCMDEVENT)),
     1265                                              HGSMI_CH_VBVA,
     1266                                              VBVAHG_EVENT);
    12791267                AssertRC(rc);
    12801268                if(RT_SUCCESS(rc))
    12811269                {
    1282                     memset(pHostCmd, 0 , VBVAHOSTCMD_SIZE(sizeof(VBVAHOSTCMDVHWACMDCOMPLETE)));
     1270                    memset(pHostCmd, 0 , VBVAHOSTCMD_SIZE(sizeof(VBVAHOSTCMDEVENT)));
    12831271                    pHostCmd->iDstID = pCmd->iDisplay;
    1284                     pHostCmd->customOpCode = VBVAHG_DCUSTOM_VHWA_CMDCOMPLETE;
    1285                     VBVAHOSTCMDVHWACMDCOMPLETE *pBody = VBVAHOSTCMD_BODY(pHostCmd, VBVAHOSTCMDVHWACMDCOMPLETE);
    1286                     pBody->offCmd = offCmd;
     1272                    pHostCmd->customOpCode = 0;
     1273                    VBVAHOSTCMDEVENT *pBody = VBVAHOSTCMD_BODY(pHostCmd, VBVAHOSTCMDEVENT);
     1274                    pBody->pEvent = pCmd->GuestVBVAReserved1;
    12871275                }
    12881276            }
    12891277            else
    12901278            {
    1291                 rc = VERR_INVALID_PARAMETER;
    1292             }
    1293         }
    1294 
    1295         if(RT_SUCCESS(rc))
    1296         {
    1297             rc = HGSMIHostCommandProcessAndFreeAsynch(pIns, pHostCmd, (pCmd->Flags & VBOXVHWACMD_FLAG_GH_ASYNCH_IRQ) != 0);
    1298             AssertRC(rc);
     1279                HGSMIOFFSET offCmd = HGSMIPointerToOffsetHost (pIns, pCmd);
     1280                Assert(offCmd != HGSMIOFFSET_VOID);
     1281                if(offCmd != HGSMIOFFSET_VOID)
     1282                {
     1283                    rc = HGSMIHostCommandAlloc (pIns,
     1284                                              (void**)&pHostCmd,
     1285                                              VBVAHOSTCMD_SIZE(sizeof(VBVAHOSTCMDVHWACMDCOMPLETE)),
     1286                                              HGSMI_CH_VBVA,
     1287                                              VBVAHG_DISPLAY_CUSTOM);
     1288                    AssertRC(rc);
     1289                    if(RT_SUCCESS(rc))
     1290                    {
     1291                        memset(pHostCmd, 0 , VBVAHOSTCMD_SIZE(sizeof(VBVAHOSTCMDVHWACMDCOMPLETE)));
     1292                        pHostCmd->iDstID = pCmd->iDisplay;
     1293                        pHostCmd->customOpCode = VBVAHG_DCUSTOM_VHWA_CMDCOMPLETE;
     1294                        VBVAHOSTCMDVHWACMDCOMPLETE *pBody = VBVAHOSTCMD_BODY(pHostCmd, VBVAHOSTCMDVHWACMDCOMPLETE);
     1295                        pBody->offCmd = offCmd;
     1296                    }
     1297                }
     1298                else
     1299                {
     1300                    rc = VERR_INVALID_PARAMETER;
     1301                }
     1302            }
     1303
    12991304            if(RT_SUCCESS(rc))
    13001305            {
    1301                 return rc;
    1302             }
    1303             HGSMIHostCommandFree (pIns, pHostCmd);
     1306                rc = HGSMIHostCommandProcessAndFreeAsynch(pIns, pHostCmd, (pCmd->Flags & VBOXVHWACMD_FLAG_GH_ASYNCH_IRQ) != 0);
     1307                AssertRC(rc);
     1308                if(RT_SUCCESS(rc))
     1309                {
     1310                    return rc;
     1311                }
     1312                HGSMIHostCommandFree (pIns, pHostCmd);
     1313            }
    13041314        }
    13051315    }
     
    16211631#endif
    16221632
     1633#ifdef VBOXVDMA
     1634        case VBVA_INFO_CAPS:
     1635        {
     1636            if (cbBuffer < sizeof (VBVACAPS))
     1637            {
     1638                rc = VERR_INVALID_PARAMETER;
     1639                break;
     1640            }
     1641
     1642            VBVACAPS *pCaps = (VBVACAPS*)pvBuffer;
     1643            pVGAState->fGuestCaps = pCaps->fCaps;
     1644            pCaps->rc = VINF_SUCCESS;
     1645        } break;
     1646#endif
    16231647        default:
    16241648            Log(("Unsupported VBVA guest command %d!!!\n",
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