VirtualBox

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


Ignore:
Timestamp:
Apr 29, 2021 3:51:13 PM (4 years ago)
Author:
vboxsync
Message:

Devices/Graphics: a few DX commands. bugref:9830

Location:
trunk/src/VBox/Devices
Files:
14 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/Devices/Graphics/DevVGA-SVGA-cmd.cpp

    r87028 r88787  
    342342
    343343
    344 #if !defined(VMSVGA3D_DX)
    345 # ifdef VBOX_WITH_VMSVGA3D
    346 /*
    347  * Stub for old backends.
    348  */
    349 int vmsvga3dQueryInterface(PVGASTATECC pThisCC, char const *pszInterfaceName, void *pvInterfaceFuncs, size_t cbInterfaceFuncs)
    350 {
    351     RT_NOREF(pThisCC, pszInterfaceName, pvInterfaceFuncs, cbInterfaceFuncs);
    352     return VERR_NOT_IMPLEMENTED;
    353 }
    354 # endif
    355 #endif
    356 
    357 
    358344/*
    359345 *
     
    599585        pGbo->paDescriptors = paDescriptors;
    600586
     587#if 1 /// @todo PGMHandlerPhysicalRegister asserts deep in PGM code with enmKind of a page being out of range.
     588fWriteProtected = false;
     589#endif
    601590    if (fWriteProtected)
    602591    {
     
    632621}
    633622
     623/** @todo static void vmsvgaR3GboWriteProtect(PVMSVGAR3STATE pSvgaR3State, PVMSVGAGBO pGbo, bool fWriteProtect) */
    634624
    635625typedef enum VMSVGAGboTransferDirection
     
    717707                               VMSVGAGboTransferDirection_Read);
    718708}
     709
     710
     711static void vmsvgaR3GboBackingStoreDelete(PVMSVGAR3STATE pSvgaR3State, PVMSVGAGBO pGbo)
     712{
     713    AssertReturnVoid(pGbo->fGboFlags & VMSVGAGBO_F_HOST_BACKED);
     714    vmsvgaR3GboWrite(pSvgaR3State, pGbo, 0, pGbo->pvHost, pGbo->cbTotal);
     715    RTMemFree(pGbo->pvHost);
     716    pGbo->pvHost = NULL;
     717    pGbo->fGboFlags &= ~VMSVGAGBO_F_HOST_BACKED;
     718}
     719
     720
     721static int vmsvgaR3GboBackingStoreCreate(PVMSVGAR3STATE pSvgaR3State, PVMSVGAGBO pGbo, uint32_t cbValid)
     722{
     723    int rc;
     724
     725    /* Just reread the data if pvHost has been allocated already. */
     726    if (!(pGbo->fGboFlags & VMSVGAGBO_F_HOST_BACKED))
     727        pGbo->pvHost = RTMemAllocZ(pGbo->cbTotal);
     728
     729    if (pGbo->pvHost)
     730    {
     731        rc = vmsvgaR3GboRead(pSvgaR3State, pGbo, 0, pGbo->pvHost, cbValid);
     732    }
     733    else
     734        rc = VERR_NO_MEMORY;
     735
     736    if (RT_SUCCESS(rc))
     737        pGbo->fGboFlags |= VMSVGAGBO_F_HOST_BACKED;
     738    else
     739    {
     740        RTMemFree(pGbo->pvHost);
     741        pGbo->pvHost = NULL;
     742    }
     743    return rc;
     744}
     745
    719746
    720747
     
    831858
    832859
    833 static PVMSVGAMOB vmsvgaR3MobGet(PVMSVGAR3STATE pSvgaR3State, SVGAMobId mobid)
    834 {
     860static PVMSVGAMOB vmsvgaR3MobGet(PVMSVGAR3STATE pSvgaR3State, SVGAMobId RT_UNTRUSTED_GUEST mobid)
     861{
     862    if (mobid == SVGA_ID_INVALID)
     863        return NULL;
     864
    835865    PVMSVGAMOB pMob = (PVMSVGAMOB)RTAvlU32Get(&pSvgaR3State->MOBTree, mobid);
    836866    if (pMob)
     
    840870        RTListPrepend(&pSvgaR3State->MOBLRUList, &pMob->nodeLRU);
    841871    }
     872    else
     873        ASSERT_GUEST_FAILED();
    842874
    843875    return pMob;
    844876}
     877
     878
     879/** Create a host ring-3 pointer to the MOB data.
     880 * Current approach is to allocate a host memory buffer and copy the guest MOB data if necessary.
     881 * @param pMob     The MOB.
     882 * @param cbValid  How many bytes of the guest backing memory contain valid data.
     883 * @return VBox status.
     884 */
     885/** @todo uint32_t cbValid -> uint32_t offStart, uint32_t cbData */
     886int vmsvgaR3MobBackingStoreCreate(PVMSVGAR3STATE pSvgaR3State, PVMSVGAMOB pMob, uint32_t cbValid)
     887{
     888    AssertReturn(pMob, VERR_INVALID_PARAMETER);
     889    return vmsvgaR3GboBackingStoreCreate(pSvgaR3State, &pMob->Gbo, cbValid);
     890}
     891
     892
     893void vmsvgaR3MobBackingStoreDelete(PVMSVGAR3STATE pSvgaR3State, PVMSVGAMOB pMob)
     894{
     895    if (pMob)
     896        vmsvgaR3GboBackingStoreDelete(pSvgaR3State, &pMob->Gbo);
     897}
     898
     899
     900void *vmsvgaR3MobBackingStoreGet(PVMSVGAMOB pMob, uint32_t off)
     901{
     902    if (pMob && (pMob->Gbo.fGboFlags & VMSVGAGBO_F_HOST_BACKED))
     903    {
     904        if (off <= pMob->Gbo.cbTotal)
     905            return (uint8_t *)pMob->Gbo.pvHost + off;
     906    }
     907    return NULL;
     908}
     909
     910
     911#ifdef VBOX_WITH_VMSVGA3D
     912int vmsvgaR3UpdateGBSurface(PVGASTATECC pThisCC, SVGA3dSurfaceImageId const *pImageId, SVGA3dBox const *pBox)
     913{
     914    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     915
     916    SVGAOTableSurfaceEntry entrySurface;
     917    int rc = vmsvgaR3OTableRead(pSvgaR3State, &pSvgaR3State->aGboOTables[SVGA_OTABLE_SURFACE],
     918                                pImageId->sid, SVGA3D_OTABLE_SURFACE_ENTRY_SIZE, &entrySurface, sizeof(entrySurface));
     919    if (RT_SUCCESS(rc))
     920    {
     921        PVMSVGAMOB pMob = vmsvgaR3MobGet(pSvgaR3State, entrySurface.mobid);
     922        if (pMob)
     923        {
     924            VMSVGA3D_MAPPED_SURFACE map;
     925            rc = pSvgaR3State->pFuncsMap->pfnSurfaceMap(pThisCC, pImageId, pBox, VMSVGA3D_SURFACE_MAP_WRITE_DISCARD, &map);
     926            if (RT_SUCCESS(rc))
     927            {
     928                /* Copy MOB -> mapped surface. */
     929                uint32_t offSrc = pBox->x * map.cbPixel
     930                                + pBox->y * entrySurface.size.width * map.cbPixel
     931                                + pBox->z * entrySurface.size.height * entrySurface.size.width * map.cbPixel;
     932                uint8_t *pu8Dst = (uint8_t *)map.pvData;
     933                for (uint32_t z = 0; z < pBox->d; ++z)
     934                {
     935                    for (uint32_t y = 0; y < pBox->h; ++y)
     936                    {
     937                        rc = vmsvgaR3GboRead(pSvgaR3State, &pMob->Gbo, offSrc, pu8Dst, pBox->w * map.cbPixel);
     938                        if (RT_FAILURE(rc))
     939                            break;
     940
     941                        pu8Dst += map.cbRowPitch;
     942                        offSrc += entrySurface.size.width * map.cbPixel;
     943                    }
     944
     945                    pu8Dst += map.cbDepthPitch;
     946                    offSrc += entrySurface.size.height * entrySurface.size.width * map.cbPixel;
     947                }
     948
     949                pSvgaR3State->pFuncsMap->pfnSurfaceUnmap(pThisCC, pImageId, &map, /* fWritten= */ true);
     950            }
     951        }
     952        else
     953            rc = VERR_INVALID_STATE;
     954    }
     955
     956    return rc;
     957}
     958
     959
     960int vmsvgaR3UpdateGBSurfaceEx(PVGASTATECC pThisCC, SVGA3dSurfaceImageId const *pImageId, SVGA3dBox const *pBoxDst, SVGA3dPoint const *pPtSrc)
     961{
     962    /* pPtSrc must be verified by the caller. */
     963    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     964
     965    SVGAOTableSurfaceEntry entrySurface;
     966    int rc = vmsvgaR3OTableRead(pSvgaR3State, &pSvgaR3State->aGboOTables[SVGA_OTABLE_SURFACE],
     967                                pImageId->sid, SVGA3D_OTABLE_SURFACE_ENTRY_SIZE, &entrySurface, sizeof(entrySurface));
     968    if (RT_SUCCESS(rc))
     969    {
     970        PVMSVGAMOB pMob = vmsvgaR3MobGet(pSvgaR3State, entrySurface.mobid);
     971        if (pMob)
     972        {
     973            VMSVGA3D_MAPPED_SURFACE map;
     974            rc = pSvgaR3State->pFuncsMap->pfnSurfaceMap(pThisCC, pImageId, pBoxDst, VMSVGA3D_SURFACE_MAP_WRITE_DISCARD, &map);
     975            if (RT_SUCCESS(rc))
     976            {
     977                /* Copy MOB -> mapped surface. */
     978                uint32_t offSrc = pPtSrc->x * map.cbPixel
     979                                + pPtSrc->y * entrySurface.size.width * map.cbPixel
     980                                + pPtSrc->z * entrySurface.size.height * entrySurface.size.width * map.cbPixel;
     981                uint8_t *pu8Dst = (uint8_t *)map.pvData;
     982                for (uint32_t z = 0; z < pBoxDst->d; ++z)
     983                {
     984                    for (uint32_t y = 0; y < pBoxDst->h; ++y)
     985                    {
     986                        rc = vmsvgaR3GboRead(pSvgaR3State, &pMob->Gbo, offSrc, pu8Dst, pBoxDst->w * map.cbPixel);
     987                        if (RT_FAILURE(rc))
     988                            break;
     989
     990                        pu8Dst += map.cbRowPitch;
     991                        offSrc += entrySurface.size.width * map.cbPixel;
     992                    }
     993
     994                    pu8Dst += map.cbDepthPitch;
     995                    offSrc += entrySurface.size.height * entrySurface.size.width * map.cbPixel;
     996                }
     997
     998                pSvgaR3State->pFuncsMap->pfnSurfaceUnmap(pThisCC, pImageId, &map, /* fWritten= */ true);
     999            }
     1000        }
     1001        else
     1002            rc = VERR_INVALID_STATE;
     1003    }
     1004
     1005    return rc;
     1006}
     1007#endif /* VBOX_WITH_VMSVGA3D */
     1008
    8451009
    8461010/*
     
    11851349//     ASMBreakpoint();
    11861350    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1187     RT_NOREF(pCmd, pSvgaR3State);
    11881351
    11891352    /* Assign the mobid to the surface. */
     
    13251488
    13261489
     1490/* SVGA_3D_CMD_INVALIDATE_GB_IMAGE 1105 */
     1491static void vmsvga3dCmdInvalidateGBImage(PVGASTATECC pThisCC, SVGA3dCmdInvalidateGBImage const *pCmd)
     1492{
     1493// ASMBreakpoint();
     1494    vmsvga3dSurfaceInvalidate(pThisCC, pCmd->image.sid, pCmd->image.face, pCmd->image.mipmap);
     1495}
     1496
     1497
    13271498/* SVGA_3D_CMD_INVALIDATE_GB_SURFACE 1106 */
    13281499static void vmsvga3dCmdInvalidateGBSurface(PVGASTATECC pThisCC, SVGA3dCmdInvalidateGBSurface const *pCmd)
    13291500{
    1330 //     ASMBreakpoint();
    1331     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1332     RT_NOREF(pSvgaR3State, pCmd);
    1333     /** @todo Implement. */
     1501// ASMBreakpoint();
     1502    vmsvga3dSurfaceInvalidate(pThisCC, pCmd->sid, SVGA_ID_INVALID, SVGA_ID_INVALID);
    13341503}
    13351504
     
    13821551    // entry.image.face = 0;
    13831552    // entry.image.mipmap = 0;
    1384     entry.width = pCmd->width;
    1385     entry.height = pCmd->height;
    1386     entry.xRoot = pCmd->xRoot;
    1387     entry.yRoot = pCmd->yRoot;
    1388     entry.flags = pCmd->flags;
    1389     entry.dpi = pCmd->dpi;
     1553    entry.width     = pCmd->width;
     1554    entry.height    = pCmd->height;
     1555    entry.xRoot     = pCmd->xRoot;
     1556    entry.yRoot     = pCmd->yRoot;
     1557    entry.flags     = pCmd->flags;
     1558    entry.dpi       = pCmd->dpi;
     1559
    13901560    int rc = vmsvgaR3OTableWrite(pSvgaR3State, &pSvgaR3State->aGboOTables[SVGA_OTABLE_SCREENTARGET],
    13911561                                 pCmd->stid, SVGA3D_OTABLE_SCREEN_TARGET_ENTRY_SIZE, &entry, sizeof(entry));
     
    14051575        pScreen->cWidth  = pCmd->width;
    14061576        pScreen->cHeight = pCmd->height;
    1407         pScreen->offVRAM = 0; /* Always for screen targets, they use either a separate memory buffer or a host window. */
     1577        pScreen->offVRAM = 0; /* Not applicable for screen targets, they use either a separate memory buffer or a host window. */
    14081578        pScreen->cbPitch = pCmd->width * 4;
    14091579        pScreen->cBpp    = 32;
     
    15691739
    15701740
     1741/* SVGA_3D_CMD_DEFINE_GB_SURFACE_V2 1134 */
     1742static void vmsvga3dCmdDefineGBSurface_v2(PVGASTATECC pThisCC, SVGA3dCmdDefineGBSurface_v2 const *pCmd)
     1743{
     1744    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     1745
     1746    /* Update the entry in the pSvgaR3State->pGboOTableSurface. */
     1747    SVGAOTableSurfaceEntry entry;
     1748    RT_ZERO(entry);
     1749    entry.format = pCmd->format;
     1750    entry.surface1Flags = pCmd->surfaceFlags;
     1751    entry.numMipLevels = pCmd->numMipLevels;
     1752    entry.multisampleCount = pCmd->multisampleCount;
     1753    entry.autogenFilter = pCmd->autogenFilter;
     1754    entry.size = pCmd->size;
     1755    entry.mobid = SVGA_ID_INVALID;
     1756    entry.arraySize = pCmd->arraySize;
     1757    // entry.mobPitch = 0;
     1758    int rc = vmsvgaR3OTableWrite(pSvgaR3State, &pSvgaR3State->aGboOTables[SVGA_OTABLE_SURFACE],
     1759                                 pCmd->sid, SVGA3D_OTABLE_SURFACE_ENTRY_SIZE, &entry, sizeof(entry));
     1760    if (RT_SUCCESS(rc))
     1761    {
     1762        /* Create the host surface. */
     1763        /** @todo fGBO = true flag. */
     1764        vmsvga3dSurfaceDefine(pThisCC, pCmd->sid, pCmd->surfaceFlags, pCmd->format,
     1765                              pCmd->multisampleCount, pCmd->autogenFilter,
     1766                              pCmd->numMipLevels, &pCmd->size);
     1767    }
     1768}
     1769
     1770
    15711771/* SVGA_3D_CMD_DEFINE_GB_MOB64 1135 */
    15721772static void vmsvga3dCmdDefineGBMob64(PVGASTATECC pThisCC, SVGA3dCmdDefineGBMob64 const *pCmd)
     
    15931793
    15941794/* SVGA_3D_CMD_DX_DEFINE_CONTEXT 1143 */
    1595 static void vmsvga3dCmdDXDefineContext(PVGASTATECC pThisCC, SVGA3dCmdDXDefineContext const *pCmd)
    1596 {
    1597 ASMBreakpoint();
    1598     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1599     if (pSvgaR3State->pFuncsDX)
    1600     {
    1601         RT_NOREF(pCmd);
    1602         pSvgaR3State->pFuncsDX->pfnDXDefineContext(pThisCC->svga.p3dState);
    1603     }
     1795static int vmsvga3dCmdDXDefineContext(PVGASTATECC pThisCC, SVGA3dCmdDXDefineContext const *pCmd, uint32_t cbCmd)
     1796{
     1797#ifdef VMSVGA3D_DX
     1798//ASMBreakpoint();
     1799    RT_NOREF(cbCmd);
     1800
     1801    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     1802
     1803    /* Update the entry in the pSvgaR3State->pGboOTable[SVGA_OTABLE_DXCONTEXT]. */
     1804    SVGAOTableDXContextEntry entry;
     1805    RT_ZERO(entry);
     1806    entry.cid = pCmd->cid;
     1807    entry.mobid = SVGA_ID_INVALID;
     1808    int rc = vmsvgaR3OTableWrite(pSvgaR3State, &pSvgaR3State->aGboOTables[SVGA_OTABLE_DXCONTEXT],
     1809                                 pCmd->cid, sizeof(SVGAOTableDXContextEntry), &entry, sizeof(entry));
     1810    if (RT_SUCCESS(rc))
     1811    {
     1812        /* Create the host context. */
     1813        rc = vmsvga3dDXDefineContext(pThisCC, pCmd->cid);
     1814    }
     1815
     1816    return rc;
     1817#else
     1818    RT_NOREF(pThisCC, pCmd, cbCmd);
     1819    return VERR_NOT_SUPPORTED;
     1820#endif
    16041821}
    16051822
    16061823
    16071824/* SVGA_3D_CMD_DX_DESTROY_CONTEXT 1144 */
    1608 static void vmsvga3dCmdDXDestroyContext(PVGASTATECC pThisCC, SVGA3dCmdDXDestroyContext const *pCmd)
    1609 {
    1610 ASMBreakpoint();
    1611     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1612     if (pSvgaR3State->pFuncsDX)
    1613     {
    1614         RT_NOREF(pCmd);
    1615         pSvgaR3State->pFuncsDX->pfnDXDestroyContext(pThisCC->svga.p3dState);
    1616     }
     1825static int vmsvga3dCmdDXDestroyContext(PVGASTATECC pThisCC, SVGA3dCmdDXDestroyContext const *pCmd, uint32_t cbCmd)
     1826{
     1827#ifdef VMSVGA3D_DX
     1828//ASMBreakpoint();
     1829    RT_NOREF(cbCmd);
     1830
     1831    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     1832
     1833    /* Update the entry in the pSvgaR3State->pGboOTable[SVGA_OTABLE_DXCONTEXT]. */
     1834    SVGAOTableDXContextEntry entry;
     1835    RT_ZERO(entry);
     1836    vmsvgaR3OTableWrite(pSvgaR3State, &pSvgaR3State->aGboOTables[SVGA_OTABLE_DXCONTEXT],
     1837                        pCmd->cid, sizeof(SVGAOTableDXContextEntry), &entry, sizeof(entry));
     1838
     1839    return vmsvga3dDXDestroyContext(pThisCC, pCmd->cid);
     1840#else
     1841    RT_NOREF(pThisCC, pCmd, cbCmd);
     1842    return VERR_NOT_SUPPORTED;
     1843#endif
    16171844}
    16181845
    16191846
    16201847/* SVGA_3D_CMD_DX_BIND_CONTEXT 1145 */
    1621 static void vmsvga3dCmdDXBindContext(PVGASTATECC pThisCC, SVGA3dCmdDXBindContext const *pCmd)
    1622 {
    1623 ASMBreakpoint();
    1624     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1625     if (pSvgaR3State->pFuncsDX)
    1626     {
    1627         RT_NOREF(pCmd);
    1628         pSvgaR3State->pFuncsDX->pfnDXBindContext(pThisCC->svga.p3dState);
    1629     }
     1848static int vmsvga3dCmdDXBindContext(PVGASTATECC pThisCC, SVGA3dCmdDXBindContext const *pCmd, uint32_t cbCmd)
     1849{
     1850#ifdef VMSVGA3D_DX
     1851//ASMBreakpoint();
     1852    RT_NOREF(cbCmd);
     1853
     1854    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     1855
     1856    /* Assign a mobid to a cid. */
     1857    int rc = VINF_SUCCESS;
     1858    if (pCmd->mobid != SVGA_ID_INVALID)
     1859        rc = vmsvgaR3OTableVerifyIndex(pSvgaR3State, &pSvgaR3State->aGboOTables[SVGA_OTABLE_MOB],
     1860                                       pCmd->mobid, SVGA3D_OTABLE_MOB_ENTRY_SIZE);
     1861    if (RT_SUCCESS(rc))
     1862    {
     1863        SVGAOTableDXContextEntry entry;
     1864        rc = vmsvgaR3OTableRead(pSvgaR3State, &pSvgaR3State->aGboOTables[SVGA_OTABLE_DXCONTEXT],
     1865                                pCmd->cid, sizeof(SVGAOTableDXContextEntry), &entry, sizeof(entry));
     1866        if (RT_SUCCESS(rc))
     1867        {
     1868            SVGADXContextMobFormat *pSvgaDXContext = NULL;
     1869            if (pCmd->mobid != entry.mobid && entry.mobid != SVGA_ID_INVALID)
     1870            {
     1871                /* Unbind notification to the DX backend. Copy the context data to the guest backing memory. */
     1872                pSvgaDXContext = (SVGADXContextMobFormat *)RTMemAlloc(sizeof(SVGADXContextMobFormat));
     1873                if (pSvgaDXContext)
     1874                {
     1875                    rc = vmsvga3dDXUnbindContext(pThisCC, pCmd->cid, pSvgaDXContext);
     1876                    if (RT_SUCCESS(rc))
     1877                    {
     1878                        PVMSVGAMOB pMob = vmsvgaR3MobGet(pSvgaR3State, entry.mobid);
     1879                        if (pMob)
     1880                        {
     1881                            rc = vmsvgaR3GboWrite(pSvgaR3State, &pMob->Gbo, 0, pSvgaDXContext, sizeof(SVGADXContextMobFormat));
     1882                        }
     1883                    }
     1884
     1885                    RTMemFree(pSvgaDXContext);
     1886                    pSvgaDXContext = NULL;
     1887                }
     1888            }
     1889
     1890            if (pCmd->mobid != SVGA_ID_INVALID)
     1891            {
     1892                /* Bind a new context. Copy existing data from the guyest backing memory. */
     1893                if (pCmd->validContents)
     1894                {
     1895                    PVMSVGAMOB pMob = vmsvgaR3MobGet(pSvgaR3State, pCmd->mobid);
     1896                    if (pMob)
     1897                    {
     1898                        pSvgaDXContext = (SVGADXContextMobFormat *)RTMemAlloc(sizeof(SVGADXContextMobFormat));
     1899                        if (pSvgaDXContext)
     1900                        {
     1901                            rc = vmsvgaR3GboRead(pSvgaR3State, &pMob->Gbo, 0, pSvgaDXContext, sizeof(SVGADXContextMobFormat));
     1902                            if (RT_FAILURE(rc))
     1903                            {
     1904                                RTMemFree(pSvgaDXContext);
     1905                                pSvgaDXContext = NULL;
     1906                            }
     1907                        }
     1908                    }
     1909                }
     1910
     1911                rc = vmsvga3dDXBindContext(pThisCC, pCmd->cid, pSvgaDXContext);
     1912
     1913                RTMemFree(pSvgaDXContext);
     1914            }
     1915
     1916            /* Update the object table. */
     1917            entry.mobid = pCmd->mobid;
     1918            rc = vmsvgaR3OTableWrite(pSvgaR3State, &pSvgaR3State->aGboOTables[SVGA_OTABLE_DXCONTEXT],
     1919                                     pCmd->cid, sizeof(SVGAOTableDXContextEntry), &entry, sizeof(entry));
     1920        }
     1921    }
     1922
     1923    return rc;
     1924#else
     1925    RT_NOREF(pThisCC, pCmd, cbCmd);
     1926    return VERR_NOT_SUPPORTED;
     1927#endif
    16301928}
    16311929
    16321930
    16331931/* SVGA_3D_CMD_DX_READBACK_CONTEXT 1146 */
    1634 static void vmsvga3dCmdDXReadbackContext(PVGASTATECC pThisCC, SVGA3dCmdDXReadbackContext const *pCmd)
    1635 {
    1636 ASMBreakpoint();
    1637     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1638     if (pSvgaR3State->pFuncsDX)
    1639     {
    1640         RT_NOREF(pCmd);
    1641         pSvgaR3State->pFuncsDX->pfnDXReadbackContext(pThisCC->svga.p3dState);
    1642     }
     1932static int vmsvga3dCmdDXReadbackContext(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXReadbackContext const *pCmd, uint32_t cbCmd)
     1933{
     1934#ifdef VMSVGA3D_DX
     1935ASMBreakpoint();
     1936    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     1937    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     1938    return vmsvga3dDXReadbackContext(pThisCC, idDXContext);
     1939#else
     1940    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     1941    return VERR_NOT_SUPPORTED;
     1942#endif
    16431943}
    16441944
    16451945
    16461946/* SVGA_3D_CMD_DX_INVALIDATE_CONTEXT 1147 */
    1647 static void vmsvga3dCmdDXInvalidateContext(PVGASTATECC pThisCC, SVGA3dCmdDXInvalidateContext const *pCmd)
    1648 {
    1649 ASMBreakpoint();
    1650     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1651     if (pSvgaR3State->pFuncsDX)
    1652     {
    1653         RT_NOREF(pCmd);
    1654         pSvgaR3State->pFuncsDX->pfnDXInvalidateContext(pThisCC->svga.p3dState);
    1655     }
     1947static int vmsvga3dCmdDXInvalidateContext(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXInvalidateContext const *pCmd, uint32_t cbCmd)
     1948{
     1949#ifdef VMSVGA3D_DX
     1950ASMBreakpoint();
     1951    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     1952    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     1953    return vmsvga3dDXInvalidateContext(pThisCC, idDXContext);
     1954#else
     1955    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     1956    return VERR_NOT_SUPPORTED;
     1957#endif
    16561958}
    16571959
    16581960
    16591961/* SVGA_3D_CMD_DX_SET_SINGLE_CONSTANT_BUFFER 1148 */
    1660 static void vmsvga3dCmdDXSetSingleConstantBuffer(PVGASTATECC pThisCC, SVGA3dCmdDXSetSingleConstantBuffer const *pCmd)
    1661 {
    1662 ASMBreakpoint();
    1663     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1664     if (pSvgaR3State->pFuncsDX)
    1665     {
    1666         RT_NOREF(pCmd);
    1667         pSvgaR3State->pFuncsDX->pfnDXSetSingleConstantBuffer(pThisCC->svga.p3dState);
    1668     }
     1962static int vmsvga3dCmdDXSetSingleConstantBuffer(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetSingleConstantBuffer const *pCmd, uint32_t cbCmd)
     1963{
     1964#ifdef VMSVGA3D_DX
     1965//ASMBreakpoint();
     1966    RT_NOREF(cbCmd);
     1967    return vmsvga3dDXSetSingleConstantBuffer(pThisCC, idDXContext, pCmd);
     1968#else
     1969    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     1970    return VERR_NOT_SUPPORTED;
     1971#endif
    16691972}
    16701973
    16711974
    16721975/* SVGA_3D_CMD_DX_SET_SHADER_RESOURCES 1149 */
    1673 static void vmsvga3dCmdDXSetShaderResources(PVGASTATECC pThisCC, SVGA3dCmdDXSetShaderResources const *pCmd)
    1674 {
    1675 ASMBreakpoint();
    1676     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1677     if (pSvgaR3State->pFuncsDX)
    1678     {
    1679         RT_NOREF(pCmd);
    1680         pSvgaR3State->pFuncsDX->pfnDXSetShaderResources(pThisCC->svga.p3dState);
    1681     }
     1976static int vmsvga3dCmdDXSetShaderResources(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetShaderResources const *pCmd, uint32_t cbCmd)
     1977{
     1978#ifdef VMSVGA3D_DX
     1979ASMBreakpoint();
     1980    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     1981    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     1982    return vmsvga3dDXSetShaderResources(pThisCC, idDXContext);
     1983#else
     1984    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     1985    return VERR_NOT_SUPPORTED;
     1986#endif
    16821987}
    16831988
    16841989
    16851990/* SVGA_3D_CMD_DX_SET_SHADER 1150 */
    1686 static void vmsvga3dCmdDXSetShader(PVGASTATECC pThisCC, SVGA3dCmdDXSetShader const *pCmd)
    1687 {
    1688 ASMBreakpoint();
    1689     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1690     if (pSvgaR3State->pFuncsDX)
    1691     {
    1692         RT_NOREF(pCmd);
    1693         pSvgaR3State->pFuncsDX->pfnDXSetShader(pThisCC->svga.p3dState);
    1694     }
     1991static int vmsvga3dCmdDXSetShader(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetShader const *pCmd, uint32_t cbCmd)
     1992{
     1993#ifdef VMSVGA3D_DX
     1994//ASMBreakpoint();
     1995    RT_NOREF(cbCmd);
     1996    return vmsvga3dDXSetShader(pThisCC, idDXContext, pCmd);
     1997#else
     1998    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     1999    return VERR_NOT_SUPPORTED;
     2000#endif
    16952001}
    16962002
    16972003
    16982004/* SVGA_3D_CMD_DX_SET_SAMPLERS 1151 */
    1699 static void vmsvga3dCmdDXSetSamplers(PVGASTATECC pThisCC, SVGA3dCmdDXSetSamplers const *pCmd)
    1700 {
    1701 ASMBreakpoint();
    1702     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1703     if (pSvgaR3State->pFuncsDX)
    1704     {
    1705         RT_NOREF(pCmd);
    1706         pSvgaR3State->pFuncsDX->pfnDXSetSamplers(pThisCC->svga.p3dState);
    1707     }
     2005static int vmsvga3dCmdDXSetSamplers(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetSamplers const *pCmd, uint32_t cbCmd)
     2006{
     2007#ifdef VMSVGA3D_DX
     2008//ASMBreakpoint();
     2009    SVGA3dSamplerId const *paSamplerId = (SVGA3dSamplerId *)&pCmd[1];
     2010    uint32_t const cSamplerId = (cbCmd - sizeof(*pCmd)) / sizeof(SVGA3dSamplerId);
     2011    return vmsvga3dDXSetSamplers(pThisCC, idDXContext, pCmd->startSampler, pCmd->type, cSamplerId, paSamplerId);
     2012#else
     2013    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2014    return VERR_NOT_SUPPORTED;
     2015#endif
    17082016}
    17092017
    17102018
    17112019/* SVGA_3D_CMD_DX_DRAW 1152 */
    1712 static void vmsvga3dCmdDXDraw(PVGASTATECC pThisCC, SVGA3dCmdDXDraw const *pCmd)
    1713 {
    1714 ASMBreakpoint();
    1715     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1716     if (pSvgaR3State->pFuncsDX)
    1717     {
    1718         RT_NOREF(pCmd);
    1719         pSvgaR3State->pFuncsDX->pfnDXDraw(pThisCC->svga.p3dState);
    1720     }
     2020static int vmsvga3dCmdDXDraw(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDraw const *pCmd, uint32_t cbCmd)
     2021{
     2022#ifdef VMSVGA3D_DX
     2023//ASMBreakpoint();
     2024    RT_NOREF(cbCmd);
     2025    return vmsvga3dDXDraw(pThisCC, idDXContext, pCmd);
     2026#else
     2027    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2028    return VERR_NOT_SUPPORTED;
     2029#endif
    17212030}
    17222031
    17232032
    17242033/* SVGA_3D_CMD_DX_DRAW_INDEXED 1153 */
    1725 static void vmsvga3dCmdDXDrawIndexed(PVGASTATECC pThisCC, SVGA3dCmdDXDrawIndexed const *pCmd)
    1726 {
    1727 ASMBreakpoint();
    1728     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1729     if (pSvgaR3State->pFuncsDX)
    1730     {
    1731         RT_NOREF(pCmd);
    1732         pSvgaR3State->pFuncsDX->pfnDXDrawIndexed(pThisCC->svga.p3dState);
    1733     }
     2034static int vmsvga3dCmdDXDrawIndexed(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDrawIndexed const *pCmd, uint32_t cbCmd)
     2035{
     2036#ifdef VMSVGA3D_DX
     2037ASMBreakpoint();
     2038    RT_NOREF(cbCmd);
     2039    return vmsvga3dDXDrawIndexed(pThisCC, idDXContext, pCmd);
     2040#else
     2041    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2042    return VERR_NOT_SUPPORTED;
     2043#endif
    17342044}
    17352045
    17362046
    17372047/* SVGA_3D_CMD_DX_DRAW_INSTANCED 1154 */
    1738 static void vmsvga3dCmdDXDrawInstanced(PVGASTATECC pThisCC, SVGA3dCmdDXDrawInstanced const *pCmd)
    1739 {
    1740 ASMBreakpoint();
    1741     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1742     if (pSvgaR3State->pFuncsDX)
    1743     {
    1744         RT_NOREF(pCmd);
    1745         pSvgaR3State->pFuncsDX->pfnDXDrawInstanced(pThisCC->svga.p3dState);
    1746     }
     2048static int vmsvga3dCmdDXDrawInstanced(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDrawInstanced const *pCmd, uint32_t cbCmd)
     2049{
     2050#ifdef VMSVGA3D_DX
     2051ASMBreakpoint();
     2052    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2053    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2054    return vmsvga3dDXDrawInstanced(pThisCC, idDXContext);
     2055#else
     2056    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2057    return VERR_NOT_SUPPORTED;
     2058#endif
    17472059}
    17482060
    17492061
    17502062/* SVGA_3D_CMD_DX_DRAW_INDEXED_INSTANCED 1155 */
    1751 static void vmsvga3dCmdDXDrawIndexedInstanced(PVGASTATECC pThisCC, SVGA3dCmdDXDrawIndexedInstanced const *pCmd)
    1752 {
    1753 ASMBreakpoint();
    1754     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1755     if (pSvgaR3State->pFuncsDX)
    1756     {
    1757         RT_NOREF(pCmd);
    1758         pSvgaR3State->pFuncsDX->pfnDXDrawIndexedInstanced(pThisCC->svga.p3dState);
    1759     }
     2063static int vmsvga3dCmdDXDrawIndexedInstanced(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDrawIndexedInstanced const *pCmd, uint32_t cbCmd)
     2064{
     2065#ifdef VMSVGA3D_DX
     2066ASMBreakpoint();
     2067    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2068    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2069    return vmsvga3dDXDrawIndexedInstanced(pThisCC, idDXContext);
     2070#else
     2071    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2072    return VERR_NOT_SUPPORTED;
     2073#endif
    17602074}
    17612075
    17622076
    17632077/* SVGA_3D_CMD_DX_DRAW_AUTO 1156 */
    1764 static void vmsvga3dCmdDXDrawAuto(PVGASTATECC pThisCC, SVGA3dCmdDXDrawAuto const *pCmd)
    1765 {
    1766 ASMBreakpoint();
    1767     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1768     if (pSvgaR3State->pFuncsDX)
    1769     {
    1770         RT_NOREF(pCmd);
    1771         pSvgaR3State->pFuncsDX->pfnDXDrawAuto(pThisCC->svga.p3dState);
    1772     }
     2078static int vmsvga3dCmdDXDrawAuto(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDrawAuto const *pCmd, uint32_t cbCmd)
     2079{
     2080#ifdef VMSVGA3D_DX
     2081ASMBreakpoint();
     2082    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2083    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2084    return vmsvga3dDXDrawAuto(pThisCC, idDXContext);
     2085#else
     2086    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2087    return VERR_NOT_SUPPORTED;
     2088#endif
    17732089}
    17742090
    17752091
    17762092/* SVGA_3D_CMD_DX_SET_INPUT_LAYOUT 1157 */
    1777 static void vmsvga3dCmdDXSetInputLayout(PVGASTATECC pThisCC, SVGA3dCmdDXSetInputLayout const *pCmd)
    1778 {
    1779 ASMBreakpoint();
    1780     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1781     if (pSvgaR3State->pFuncsDX)
    1782     {
    1783         RT_NOREF(pCmd);
    1784         pSvgaR3State->pFuncsDX->pfnDXSetInputLayout(pThisCC->svga.p3dState);
    1785     }
     2093static int vmsvga3dCmdDXSetInputLayout(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetInputLayout const *pCmd, uint32_t cbCmd)
     2094{
     2095#ifdef VMSVGA3D_DX
     2096//ASMBreakpoint();
     2097    RT_NOREF(cbCmd);
     2098    return vmsvga3dDXSetInputLayout(pThisCC, idDXContext, pCmd->elementLayoutId);
     2099#else
     2100    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2101    return VERR_NOT_SUPPORTED;
     2102#endif
    17862103}
    17872104
    17882105
    17892106/* SVGA_3D_CMD_DX_SET_VERTEX_BUFFERS 1158 */
    1790 static void vmsvga3dCmdDXSetVertexBuffers(PVGASTATECC pThisCC, SVGA3dCmdDXSetVertexBuffers const *pCmd)
    1791 {
    1792 ASMBreakpoint();
    1793     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1794     if (pSvgaR3State->pFuncsDX)
    1795     {
    1796         RT_NOREF(pCmd);
    1797         pSvgaR3State->pFuncsDX->pfnDXSetVertexBuffers(pThisCC->svga.p3dState);
    1798     }
     2107static int vmsvga3dCmdDXSetVertexBuffers(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetVertexBuffers const *pCmd, uint32_t cbCmd)
     2108{
     2109#ifdef VMSVGA3D_DX
     2110//ASMBreakpoint();
     2111    SVGA3dVertexBuffer const *paVertexBuffer = (SVGA3dVertexBuffer *)&pCmd[1];
     2112    uint32_t const cVertexBuffer = (cbCmd - sizeof(*pCmd)) / sizeof(SVGA3dVertexBuffer);
     2113    return vmsvga3dDXSetVertexBuffers(pThisCC, idDXContext, pCmd->startBuffer, cVertexBuffer, paVertexBuffer);
     2114#else
     2115    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2116    return VERR_NOT_SUPPORTED;
     2117#endif
    17992118}
    18002119
    18012120
    18022121/* SVGA_3D_CMD_DX_SET_INDEX_BUFFER 1159 */
    1803 static void vmsvga3dCmdDXSetIndexBuffer(PVGASTATECC pThisCC, SVGA3dCmdDXSetIndexBuffer const *pCmd)
    1804 {
    1805 ASMBreakpoint();
    1806     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1807     if (pSvgaR3State->pFuncsDX)
    1808     {
    1809         RT_NOREF(pCmd);
    1810         pSvgaR3State->pFuncsDX->pfnDXSetIndexBuffer(pThisCC->svga.p3dState);
    1811     }
     2122static int vmsvga3dCmdDXSetIndexBuffer(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetIndexBuffer const *pCmd, uint32_t cbCmd)
     2123{
     2124#ifdef VMSVGA3D_DX
     2125//ASMBreakpoint();
     2126    RT_NOREF(cbCmd);
     2127    return vmsvga3dDXSetIndexBuffer(pThisCC, idDXContext, pCmd);
     2128#else
     2129    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2130    return VERR_NOT_SUPPORTED;
     2131#endif
    18122132}
    18132133
    18142134
    18152135/* SVGA_3D_CMD_DX_SET_TOPOLOGY 1160 */
    1816 static void vmsvga3dCmdDXSetTopology(PVGASTATECC pThisCC, SVGA3dCmdDXSetTopology const *pCmd)
    1817 {
    1818 ASMBreakpoint();
    1819     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1820     if (pSvgaR3State->pFuncsDX)
    1821     {
    1822         RT_NOREF(pCmd);
    1823         pSvgaR3State->pFuncsDX->pfnDXSetTopology(pThisCC->svga.p3dState);
    1824     }
     2136static int vmsvga3dCmdDXSetTopology(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetTopology const *pCmd, uint32_t cbCmd)
     2137{
     2138#ifdef VMSVGA3D_DX
     2139//ASMBreakpoint();
     2140    RT_NOREF(cbCmd);
     2141    return vmsvga3dDXSetTopology(pThisCC, idDXContext, pCmd->topology);
     2142#else
     2143    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2144    return VERR_NOT_SUPPORTED;
     2145#endif
    18252146}
    18262147
    18272148
    18282149/* SVGA_3D_CMD_DX_SET_RENDERTARGETS 1161 */
    1829 static void vmsvga3dCmdDXSetRenderTargets(PVGASTATECC pThisCC, SVGA3dCmdDXSetRenderTargets const *pCmd)
    1830 {
    1831 ASMBreakpoint();
    1832     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1833     if (pSvgaR3State->pFuncsDX)
    1834     {
    1835         RT_NOREF(pCmd);
    1836         pSvgaR3State->pFuncsDX->pfnDXSetRenderTargets(pThisCC->svga.p3dState);
    1837     }
     2150static int vmsvga3dCmdDXSetRenderTargets(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetRenderTargets const *pCmd, uint32_t cbCmd)
     2151{
     2152#ifdef VMSVGA3D_DX
     2153//ASMBreakpoint();
     2154    SVGA3dRenderTargetViewId const *paRenderTargetViewId = (SVGA3dRenderTargetViewId *)&pCmd[1];
     2155    uint32_t const cRenderTargetViewId = (cbCmd - sizeof(*pCmd)) / sizeof(SVGA3dRenderTargetViewId);
     2156    return vmsvga3dDXSetRenderTargets(pThisCC, idDXContext, pCmd->depthStencilViewId, cRenderTargetViewId, paRenderTargetViewId);
     2157#else
     2158    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2159    return VERR_NOT_SUPPORTED;
     2160#endif
    18382161}
    18392162
    18402163
    18412164/* SVGA_3D_CMD_DX_SET_BLEND_STATE 1162 */
    1842 static void vmsvga3dCmdDXSetBlendState(PVGASTATECC pThisCC, SVGA3dCmdDXSetBlendState const *pCmd)
    1843 {
    1844 ASMBreakpoint();
    1845     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1846     if (pSvgaR3State->pFuncsDX)
    1847     {
    1848         RT_NOREF(pCmd);
    1849         pSvgaR3State->pFuncsDX->pfnDXSetBlendState(pThisCC->svga.p3dState);
    1850     }
     2165static int vmsvga3dCmdDXSetBlendState(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetBlendState const *pCmd, uint32_t cbCmd)
     2166{
     2167#ifdef VMSVGA3D_DX
     2168//ASMBreakpoint();
     2169    RT_NOREF(cbCmd);
     2170    return vmsvga3dDXSetBlendState(pThisCC, idDXContext, pCmd);
     2171#else
     2172    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2173    return VERR_NOT_SUPPORTED;
     2174#endif
    18512175}
    18522176
    18532177
    18542178/* SVGA_3D_CMD_DX_SET_DEPTHSTENCIL_STATE 1163 */
    1855 static void vmsvga3dCmdDXSetDepthStencilState(PVGASTATECC pThisCC, SVGA3dCmdDXSetDepthStencilState const *pCmd)
    1856 {
    1857 ASMBreakpoint();
    1858     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1859     if (pSvgaR3State->pFuncsDX)
    1860     {
    1861         RT_NOREF(pCmd);
    1862         pSvgaR3State->pFuncsDX->pfnDXSetDepthStencilState(pThisCC->svga.p3dState);
    1863     }
     2179static int vmsvga3dCmdDXSetDepthStencilState(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetDepthStencilState const *pCmd, uint32_t cbCmd)
     2180{
     2181#ifdef VMSVGA3D_DX
     2182//ASMBreakpoint();
     2183    RT_NOREF(cbCmd);
     2184    return vmsvga3dDXSetDepthStencilState(pThisCC, idDXContext, pCmd);
     2185#else
     2186    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2187    return VERR_NOT_SUPPORTED;
     2188#endif
    18642189}
    18652190
    18662191
    18672192/* SVGA_3D_CMD_DX_SET_RASTERIZER_STATE 1164 */
    1868 static void vmsvga3dCmdDXSetRasterizerState(PVGASTATECC pThisCC, SVGA3dCmdDXSetRasterizerState const *pCmd)
    1869 {
    1870 ASMBreakpoint();
    1871     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1872     if (pSvgaR3State->pFuncsDX)
    1873     {
    1874         RT_NOREF(pCmd);
    1875         pSvgaR3State->pFuncsDX->pfnDXSetRasterizerState(pThisCC->svga.p3dState);
    1876     }
     2193static int vmsvga3dCmdDXSetRasterizerState(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetRasterizerState const *pCmd, uint32_t cbCmd)
     2194{
     2195#ifdef VMSVGA3D_DX
     2196//ASMBreakpoint();
     2197    RT_NOREF(cbCmd);
     2198    return vmsvga3dDXSetRasterizerState(pThisCC, idDXContext, pCmd->rasterizerId);
     2199#else
     2200    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2201    return VERR_NOT_SUPPORTED;
     2202#endif
    18772203}
    18782204
    18792205
    18802206/* SVGA_3D_CMD_DX_DEFINE_QUERY 1165 */
    1881 static void vmsvga3dCmdDXDefineQuery(PVGASTATECC pThisCC, SVGA3dCmdDXDefineQuery const *pCmd)
    1882 {
    1883 ASMBreakpoint();
    1884     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1885     if (pSvgaR3State->pFuncsDX)
    1886     {
    1887         RT_NOREF(pCmd);
    1888         pSvgaR3State->pFuncsDX->pfnDXDefineQuery(pThisCC->svga.p3dState);
    1889     }
     2207static int vmsvga3dCmdDXDefineQuery(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineQuery const *pCmd, uint32_t cbCmd)
     2208{
     2209#ifdef VMSVGA3D_DX
     2210ASMBreakpoint();
     2211    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2212    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2213    return vmsvga3dDXDefineQuery(pThisCC, idDXContext);
     2214#else
     2215    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2216    return VERR_NOT_SUPPORTED;
     2217#endif
    18902218}
    18912219
    18922220
    18932221/* SVGA_3D_CMD_DX_DESTROY_QUERY 1166 */
    1894 static void vmsvga3dCmdDXDestroyQuery(PVGASTATECC pThisCC, SVGA3dCmdDXDestroyQuery const *pCmd)
    1895 {
    1896 ASMBreakpoint();
    1897     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1898     if (pSvgaR3State->pFuncsDX)
    1899     {
    1900         RT_NOREF(pCmd);
    1901         pSvgaR3State->pFuncsDX->pfnDXDestroyQuery(pThisCC->svga.p3dState);
    1902     }
     2222static int vmsvga3dCmdDXDestroyQuery(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDestroyQuery const *pCmd, uint32_t cbCmd)
     2223{
     2224#ifdef VMSVGA3D_DX
     2225ASMBreakpoint();
     2226    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2227    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2228    return vmsvga3dDXDestroyQuery(pThisCC, idDXContext);
     2229#else
     2230    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2231    return VERR_NOT_SUPPORTED;
     2232#endif
    19032233}
    19042234
    19052235
    19062236/* SVGA_3D_CMD_DX_BIND_QUERY 1167 */
    1907 static void vmsvga3dCmdDXBindQuery(PVGASTATECC pThisCC, SVGA3dCmdDXBindQuery const *pCmd)
    1908 {
    1909 ASMBreakpoint();
    1910     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1911     if (pSvgaR3State->pFuncsDX)
    1912     {
    1913         RT_NOREF(pCmd);
    1914         pSvgaR3State->pFuncsDX->pfnDXBindQuery(pThisCC->svga.p3dState);
    1915     }
     2237static int vmsvga3dCmdDXBindQuery(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXBindQuery const *pCmd, uint32_t cbCmd)
     2238{
     2239#ifdef VMSVGA3D_DX
     2240ASMBreakpoint();
     2241    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2242    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2243    return vmsvga3dDXBindQuery(pThisCC, idDXContext);
     2244#else
     2245    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2246    return VERR_NOT_SUPPORTED;
     2247#endif
    19162248}
    19172249
    19182250
    19192251/* SVGA_3D_CMD_DX_SET_QUERY_OFFSET 1168 */
    1920 static void vmsvga3dCmdDXSetQueryOffset(PVGASTATECC pThisCC, SVGA3dCmdDXSetQueryOffset const *pCmd)
    1921 {
    1922 ASMBreakpoint();
    1923     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1924     if (pSvgaR3State->pFuncsDX)
    1925     {
    1926         RT_NOREF(pCmd);
    1927         pSvgaR3State->pFuncsDX->pfnDXSetQueryOffset(pThisCC->svga.p3dState);
    1928     }
     2252static int vmsvga3dCmdDXSetQueryOffset(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetQueryOffset const *pCmd, uint32_t cbCmd)
     2253{
     2254#ifdef VMSVGA3D_DX
     2255ASMBreakpoint();
     2256    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2257    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2258    return vmsvga3dDXSetQueryOffset(pThisCC, idDXContext);
     2259#else
     2260    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2261    return VERR_NOT_SUPPORTED;
     2262#endif
    19292263}
    19302264
    19312265
    19322266/* SVGA_3D_CMD_DX_BEGIN_QUERY 1169 */
    1933 static void vmsvga3dCmdDXBeginQuery(PVGASTATECC pThisCC, SVGA3dCmdDXBeginQuery const *pCmd)
    1934 {
    1935 ASMBreakpoint();
    1936     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1937     if (pSvgaR3State->pFuncsDX)
    1938     {
    1939         RT_NOREF(pCmd);
    1940         pSvgaR3State->pFuncsDX->pfnDXBeginQuery(pThisCC->svga.p3dState);
    1941     }
     2267static int vmsvga3dCmdDXBeginQuery(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXBeginQuery const *pCmd, uint32_t cbCmd)
     2268{
     2269#ifdef VMSVGA3D_DX
     2270ASMBreakpoint();
     2271    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2272    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2273    return vmsvga3dDXBeginQuery(pThisCC, idDXContext);
     2274#else
     2275    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2276    return VERR_NOT_SUPPORTED;
     2277#endif
    19422278}
    19432279
    19442280
    19452281/* SVGA_3D_CMD_DX_END_QUERY 1170 */
    1946 static void vmsvga3dCmdDXEndQuery(PVGASTATECC pThisCC, SVGA3dCmdDXEndQuery const *pCmd)
    1947 {
    1948 ASMBreakpoint();
    1949     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1950     if (pSvgaR3State->pFuncsDX)
    1951     {
    1952         RT_NOREF(pCmd);
    1953         pSvgaR3State->pFuncsDX->pfnDXEndQuery(pThisCC->svga.p3dState);
    1954     }
     2282static int vmsvga3dCmdDXEndQuery(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXEndQuery const *pCmd, uint32_t cbCmd)
     2283{
     2284#ifdef VMSVGA3D_DX
     2285ASMBreakpoint();
     2286    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2287    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2288    return vmsvga3dDXEndQuery(pThisCC, idDXContext);
     2289#else
     2290    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2291    return VERR_NOT_SUPPORTED;
     2292#endif
    19552293}
    19562294
    19572295
    19582296/* SVGA_3D_CMD_DX_READBACK_QUERY 1171 */
    1959 static void vmsvga3dCmdDXReadbackQuery(PVGASTATECC pThisCC, SVGA3dCmdDXReadbackQuery const *pCmd)
    1960 {
    1961 ASMBreakpoint();
    1962     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1963     if (pSvgaR3State->pFuncsDX)
    1964     {
    1965         RT_NOREF(pCmd);
    1966         pSvgaR3State->pFuncsDX->pfnDXReadbackQuery(pThisCC->svga.p3dState);
    1967     }
     2297static int vmsvga3dCmdDXReadbackQuery(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXReadbackQuery const *pCmd, uint32_t cbCmd)
     2298{
     2299#ifdef VMSVGA3D_DX
     2300ASMBreakpoint();
     2301    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2302    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2303    return vmsvga3dDXReadbackQuery(pThisCC, idDXContext);
     2304#else
     2305    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2306    return VERR_NOT_SUPPORTED;
     2307#endif
    19682308}
    19692309
    19702310
    19712311/* SVGA_3D_CMD_DX_SET_PREDICATION 1172 */
    1972 static void vmsvga3dCmdDXSetPredication(PVGASTATECC pThisCC, SVGA3dCmdDXSetPredication const *pCmd)
    1973 {
    1974 ASMBreakpoint();
    1975     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1976     if (pSvgaR3State->pFuncsDX)
    1977     {
    1978         RT_NOREF(pCmd);
    1979         pSvgaR3State->pFuncsDX->pfnDXSetPredication(pThisCC->svga.p3dState);
    1980     }
     2312static int vmsvga3dCmdDXSetPredication(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetPredication const *pCmd, uint32_t cbCmd)
     2313{
     2314#ifdef VMSVGA3D_DX
     2315ASMBreakpoint();
     2316    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2317    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2318    return vmsvga3dDXSetPredication(pThisCC, idDXContext);
     2319#else
     2320    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2321    return VERR_NOT_SUPPORTED;
     2322#endif
    19812323}
    19822324
    19832325
    19842326/* SVGA_3D_CMD_DX_SET_SOTARGETS 1173 */
    1985 static void vmsvga3dCmdDXSetSOTargets(PVGASTATECC pThisCC, SVGA3dCmdDXSetSOTargets const *pCmd)
    1986 {
    1987 ASMBreakpoint();
    1988     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    1989     if (pSvgaR3State->pFuncsDX)
    1990     {
    1991         RT_NOREF(pCmd);
    1992         pSvgaR3State->pFuncsDX->pfnDXSetSOTargets(pThisCC->svga.p3dState);
    1993     }
     2327static int vmsvga3dCmdDXSetSOTargets(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetSOTargets const *pCmd, uint32_t cbCmd)
     2328{
     2329#ifdef VMSVGA3D_DX
     2330ASMBreakpoint();
     2331    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2332    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2333    return vmsvga3dDXSetSOTargets(pThisCC, idDXContext);
     2334#else
     2335    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2336    return VERR_NOT_SUPPORTED;
     2337#endif
    19942338}
    19952339
    19962340
    19972341/* SVGA_3D_CMD_DX_SET_VIEWPORTS 1174 */
    1998 static void vmsvga3dCmdDXSetViewports(PVGASTATECC pThisCC, SVGA3dCmdDXSetViewports const *pCmd)
    1999 {
    2000 ASMBreakpoint();
    2001     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2002     if (pSvgaR3State->pFuncsDX)
    2003     {
    2004         RT_NOREF(pCmd);
    2005         pSvgaR3State->pFuncsDX->pfnDXSetViewports(pThisCC->svga.p3dState);
    2006     }
     2342static int vmsvga3dCmdDXSetViewports(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetViewports const *pCmd, uint32_t cbCmd)
     2343{
     2344#ifdef VMSVGA3D_DX
     2345//ASMBreakpoint();
     2346    SVGA3dViewport const *paViewport = (SVGA3dViewport *)&pCmd[1];
     2347    uint32_t const cViewport = (cbCmd - sizeof(*pCmd)) / sizeof(SVGA3dViewport);
     2348    return vmsvga3dDXSetViewports(pThisCC, idDXContext, cViewport, paViewport);
     2349#else
     2350    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2351    return VERR_NOT_SUPPORTED;
     2352#endif
    20072353}
    20082354
    20092355
    20102356/* SVGA_3D_CMD_DX_SET_SCISSORRECTS 1175 */
    2011 static void vmsvga3dCmdDXSetScissorRects(PVGASTATECC pThisCC, SVGA3dCmdDXSetScissorRects const *pCmd)
    2012 {
    2013 ASMBreakpoint();
    2014     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2015     if (pSvgaR3State->pFuncsDX)
    2016     {
    2017         RT_NOREF(pCmd);
    2018         pSvgaR3State->pFuncsDX->pfnDXSetScissorRects(pThisCC->svga.p3dState);
    2019     }
     2357static int vmsvga3dCmdDXSetScissorRects(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetScissorRects const *pCmd, uint32_t cbCmd)
     2358{
     2359#ifdef VMSVGA3D_DX
     2360//ASMBreakpoint();
     2361    SVGASignedRect const *paRect = (SVGASignedRect *)&pCmd[1];
     2362    uint32_t const cRect = (cbCmd - sizeof(*pCmd)) / sizeof(SVGASignedRect);
     2363    return vmsvga3dDXSetScissorRects(pThisCC, idDXContext, cRect, paRect);
     2364#else
     2365    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2366    return VERR_NOT_SUPPORTED;
     2367#endif
    20202368}
    20212369
    20222370
    20232371/* SVGA_3D_CMD_DX_CLEAR_RENDERTARGET_VIEW 1176 */
    2024 static void vmsvga3dCmdDXClearRenderTargetView(PVGASTATECC pThisCC, SVGA3dCmdDXClearRenderTargetView const *pCmd)
    2025 {
    2026 ASMBreakpoint();
    2027     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2028     if (pSvgaR3State->pFuncsDX)
    2029     {
    2030         RT_NOREF(pCmd);
    2031         pSvgaR3State->pFuncsDX->pfnDXClearRenderTargetView(pThisCC->svga.p3dState);
    2032     }
     2372static int vmsvga3dCmdDXClearRenderTargetView(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXClearRenderTargetView const *pCmd, uint32_t cbCmd)
     2373{
     2374#ifdef VMSVGA3D_DX
     2375ASMBreakpoint();
     2376    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2377    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2378    return vmsvga3dDXClearRenderTargetView(pThisCC, idDXContext);
     2379#else
     2380    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2381    return VERR_NOT_SUPPORTED;
     2382#endif
    20332383}
    20342384
    20352385
    20362386/* SVGA_3D_CMD_DX_CLEAR_DEPTHSTENCIL_VIEW 1177 */
    2037 static void vmsvga3dCmdDXClearDepthStencilView(PVGASTATECC pThisCC, SVGA3dCmdDXClearDepthStencilView const *pCmd)
    2038 {
    2039 ASMBreakpoint();
    2040     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2041     if (pSvgaR3State->pFuncsDX)
    2042     {
    2043         RT_NOREF(pCmd);
    2044         pSvgaR3State->pFuncsDX->pfnDXClearDepthStencilView(pThisCC->svga.p3dState);
    2045     }
     2387static int vmsvga3dCmdDXClearDepthStencilView(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXClearDepthStencilView const *pCmd, uint32_t cbCmd)
     2388{
     2389#ifdef VMSVGA3D_DX
     2390ASMBreakpoint();
     2391    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2392    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2393    return vmsvga3dDXClearDepthStencilView(pThisCC, idDXContext);
     2394#else
     2395    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2396    return VERR_NOT_SUPPORTED;
     2397#endif
    20462398}
    20472399
    20482400
    20492401/* SVGA_3D_CMD_DX_PRED_COPY_REGION 1178 */
    2050 static void vmsvga3dCmdDXPredCopyRegion(PVGASTATECC pThisCC, SVGA3dCmdDXPredCopyRegion const *pCmd)
    2051 {
    2052 ASMBreakpoint();
    2053     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2054     if (pSvgaR3State->pFuncsDX)
    2055     {
    2056         RT_NOREF(pCmd);
    2057         pSvgaR3State->pFuncsDX->pfnDXPredCopyRegion(pThisCC->svga.p3dState);
    2058     }
     2402static int vmsvga3dCmdDXPredCopyRegion(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXPredCopyRegion const *pCmd, uint32_t cbCmd)
     2403{
     2404#ifdef VMSVGA3D_DX
     2405ASMBreakpoint();
     2406    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2407    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2408    return vmsvga3dDXPredCopyRegion(pThisCC, idDXContext);
     2409#else
     2410    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2411    return VERR_NOT_SUPPORTED;
     2412#endif
    20592413}
    20602414
    20612415
    20622416/* SVGA_3D_CMD_DX_PRED_COPY 1179 */
    2063 static void vmsvga3dCmdDXPredCopy(PVGASTATECC pThisCC, SVGA3dCmdDXPredCopy const *pCmd)
    2064 {
    2065 ASMBreakpoint();
    2066     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2067     if (pSvgaR3State->pFuncsDX)
    2068     {
    2069         RT_NOREF(pCmd);
    2070         pSvgaR3State->pFuncsDX->pfnDXPredCopy(pThisCC->svga.p3dState);
    2071     }
     2417static int vmsvga3dCmdDXPredCopy(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXPredCopy const *pCmd, uint32_t cbCmd)
     2418{
     2419#ifdef VMSVGA3D_DX
     2420ASMBreakpoint();
     2421    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2422    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2423    return vmsvga3dDXPredCopy(pThisCC, idDXContext);
     2424#else
     2425    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2426    return VERR_NOT_SUPPORTED;
     2427#endif
    20722428}
    20732429
    20742430
    20752431/* SVGA_3D_CMD_DX_PRESENTBLT 1180 */
    2076 static void vmsvga3dCmdDXPresentBlt(PVGASTATECC pThisCC, SVGA3dCmdDXPresentBlt const *pCmd)
    2077 {
    2078 ASMBreakpoint();
    2079     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2080     if (pSvgaR3State->pFuncsDX)
    2081     {
    2082         RT_NOREF(pCmd);
    2083         pSvgaR3State->pFuncsDX->pfnDXPresentBlt(pThisCC->svga.p3dState);
    2084     }
     2432static int vmsvga3dCmdDXPresentBlt(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXPresentBlt const *pCmd, uint32_t cbCmd)
     2433{
     2434#ifdef VMSVGA3D_DX
     2435ASMBreakpoint();
     2436    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2437    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2438    return vmsvga3dDXPresentBlt(pThisCC, idDXContext);
     2439#else
     2440    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2441    return VERR_NOT_SUPPORTED;
     2442#endif
    20852443}
    20862444
    20872445
    20882446/* SVGA_3D_CMD_DX_GENMIPS 1181 */
    2089 static void vmsvga3dCmdDXGenMips(PVGASTATECC pThisCC, SVGA3dCmdDXGenMips const *pCmd)
    2090 {
    2091 ASMBreakpoint();
    2092     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2093     if (pSvgaR3State->pFuncsDX)
    2094     {
    2095         RT_NOREF(pCmd);
    2096         pSvgaR3State->pFuncsDX->pfnDXGenMips(pThisCC->svga.p3dState);
    2097     }
     2447static int vmsvga3dCmdDXGenMips(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXGenMips const *pCmd, uint32_t cbCmd)
     2448{
     2449#ifdef VMSVGA3D_DX
     2450ASMBreakpoint();
     2451    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2452    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2453    return vmsvga3dDXGenMips(pThisCC, idDXContext);
     2454#else
     2455    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2456    return VERR_NOT_SUPPORTED;
     2457#endif
    20982458}
    20992459
    21002460
    21012461/* SVGA_3D_CMD_DX_UPDATE_SUBRESOURCE 1182 */
    2102 static void vmsvga3dCmdDXUpdateSubResource(PVGASTATECC pThisCC, SVGA3dCmdDXUpdateSubResource const *pCmd)
    2103 {
    2104 ASMBreakpoint();
    2105     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2106     if (pSvgaR3State->pFuncsDX)
    2107     {
    2108         RT_NOREF(pCmd);
    2109         pSvgaR3State->pFuncsDX->pfnDXUpdateSubResource(pThisCC->svga.p3dState);
    2110     }
     2462static int vmsvga3dCmdDXUpdateSubResource(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXUpdateSubResource const *pCmd, uint32_t cbCmd)
     2463{
     2464#ifdef VMSVGA3D_DX
     2465ASMBreakpoint();
     2466    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2467    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2468    return vmsvga3dDXUpdateSubResource(pThisCC, idDXContext);
     2469#else
     2470    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2471    return VERR_NOT_SUPPORTED;
     2472#endif
    21112473}
    21122474
    21132475
    21142476/* SVGA_3D_CMD_DX_READBACK_SUBRESOURCE 1183 */
    2115 static void vmsvga3dCmdDXReadbackSubResource(PVGASTATECC pThisCC, SVGA3dCmdDXReadbackSubResource const *pCmd)
    2116 {
    2117 ASMBreakpoint();
    2118     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2119     if (pSvgaR3State->pFuncsDX)
    2120     {
    2121         RT_NOREF(pCmd);
    2122         pSvgaR3State->pFuncsDX->pfnDXReadbackSubResource(pThisCC->svga.p3dState);
    2123     }
     2477static int vmsvga3dCmdDXReadbackSubResource(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXReadbackSubResource const *pCmd, uint32_t cbCmd)
     2478{
     2479#ifdef VMSVGA3D_DX
     2480ASMBreakpoint();
     2481    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2482    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2483    return vmsvga3dDXReadbackSubResource(pThisCC, idDXContext);
     2484#else
     2485    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2486    return VERR_NOT_SUPPORTED;
     2487#endif
    21242488}
    21252489
    21262490
    21272491/* SVGA_3D_CMD_DX_INVALIDATE_SUBRESOURCE 1184 */
    2128 static void vmsvga3dCmdDXInvalidateSubResource(PVGASTATECC pThisCC, SVGA3dCmdDXInvalidateSubResource const *pCmd)
    2129 {
    2130 ASMBreakpoint();
    2131     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2132     if (pSvgaR3State->pFuncsDX)
    2133     {
    2134         RT_NOREF(pCmd);
    2135         pSvgaR3State->pFuncsDX->pfnDXInvalidateSubResource(pThisCC->svga.p3dState);
    2136     }
     2492static int vmsvga3dCmdDXInvalidateSubResource(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXInvalidateSubResource const *pCmd, uint32_t cbCmd)
     2493{
     2494#ifdef VMSVGA3D_DX
     2495ASMBreakpoint();
     2496    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2497    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2498    return vmsvga3dDXInvalidateSubResource(pThisCC, idDXContext);
     2499#else
     2500    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2501    return VERR_NOT_SUPPORTED;
     2502#endif
    21372503}
    21382504
    21392505
    21402506/* SVGA_3D_CMD_DX_DEFINE_SHADERRESOURCE_VIEW 1185 */
    2141 static void vmsvga3dCmdDXDefineShaderResourceView(PVGASTATECC pThisCC, SVGA3dCmdDXDefineShaderResourceView const *pCmd)
    2142 {
    2143 ASMBreakpoint();
    2144     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2145     if (pSvgaR3State->pFuncsDX)
    2146     {
    2147         RT_NOREF(pCmd);
    2148         pSvgaR3State->pFuncsDX->pfnDXDefineShaderResourceView(pThisCC->svga.p3dState);
    2149     }
     2507static int vmsvga3dCmdDXDefineShaderResourceView(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineShaderResourceView const *pCmd, uint32_t cbCmd)
     2508{
     2509#ifdef VMSVGA3D_DX
     2510ASMBreakpoint();
     2511    RT_NOREF(cbCmd);
     2512    return vmsvga3dDXDefineShaderResourceView(pThisCC, idDXContext, pCmd);
     2513#else
     2514    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2515    return VERR_NOT_SUPPORTED;
     2516#endif
    21502517}
    21512518
    21522519
    21532520/* SVGA_3D_CMD_DX_DESTROY_SHADERRESOURCE_VIEW 1186 */
    2154 static void vmsvga3dCmdDXDestroyShaderResourceView(PVGASTATECC pThisCC, SVGA3dCmdDXDestroyShaderResourceView const *pCmd)
    2155 {
    2156 ASMBreakpoint();
    2157     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2158     if (pSvgaR3State->pFuncsDX)
    2159     {
    2160         RT_NOREF(pCmd);
    2161         pSvgaR3State->pFuncsDX->pfnDXDestroyShaderResourceView(pThisCC->svga.p3dState);
    2162     }
     2521static int vmsvga3dCmdDXDestroyShaderResourceView(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDestroyShaderResourceView const *pCmd, uint32_t cbCmd)
     2522{
     2523#ifdef VMSVGA3D_DX
     2524ASMBreakpoint();
     2525    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2526    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2527    return vmsvga3dDXDestroyShaderResourceView(pThisCC, idDXContext);
     2528#else
     2529    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2530    return VERR_NOT_SUPPORTED;
     2531#endif
    21632532}
    21642533
    21652534
    21662535/* SVGA_3D_CMD_DX_DEFINE_RENDERTARGET_VIEW 1187 */
    2167 static void vmsvga3dCmdDXDefineRenderTargetView(PVGASTATECC pThisCC, SVGA3dCmdDXDefineRenderTargetView const *pCmd)
    2168 {
    2169 ASMBreakpoint();
    2170     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2171     if (pSvgaR3State->pFuncsDX)
    2172     {
    2173         RT_NOREF(pCmd);
    2174         pSvgaR3State->pFuncsDX->pfnDXDefineRenderTargetView(pThisCC->svga.p3dState);
    2175     }
     2536static int vmsvga3dCmdDXDefineRenderTargetView(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineRenderTargetView const *pCmd, uint32_t cbCmd)
     2537{
     2538#ifdef VMSVGA3D_DX
     2539//ASMBreakpoint();
     2540    RT_NOREF(cbCmd);
     2541    return vmsvga3dDXDefineRenderTargetView(pThisCC, idDXContext, pCmd);
     2542#else
     2543    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2544    return VERR_NOT_SUPPORTED;
     2545#endif
    21762546}
    21772547
    21782548
    21792549/* SVGA_3D_CMD_DX_DESTROY_RENDERTARGET_VIEW 1188 */
    2180 static void vmsvga3dCmdDXDestroyRenderTargetView(PVGASTATECC pThisCC, SVGA3dCmdDXDestroyRenderTargetView const *pCmd)
    2181 {
    2182 ASMBreakpoint();
    2183     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2184     if (pSvgaR3State->pFuncsDX)
    2185     {
    2186         RT_NOREF(pCmd);
    2187         pSvgaR3State->pFuncsDX->pfnDXDestroyRenderTargetView(pThisCC->svga.p3dState);
    2188     }
     2550static int vmsvga3dCmdDXDestroyRenderTargetView(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDestroyRenderTargetView const *pCmd, uint32_t cbCmd)
     2551{
     2552#ifdef VMSVGA3D_DX
     2553ASMBreakpoint();
     2554    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2555    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2556    return vmsvga3dDXDestroyRenderTargetView(pThisCC, idDXContext);
     2557#else
     2558    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2559    return VERR_NOT_SUPPORTED;
     2560#endif
    21892561}
    21902562
    21912563
    21922564/* SVGA_3D_CMD_DX_DEFINE_DEPTHSTENCIL_VIEW 1189 */
    2193 static void vmsvga3dCmdDXDefineDepthStencilView(PVGASTATECC pThisCC, SVGA3dCmdDXDefineDepthStencilView const *pCmd)
    2194 {
    2195 ASMBreakpoint();
    2196     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2197     if (pSvgaR3State->pFuncsDX)
    2198     {
    2199         RT_NOREF(pCmd);
    2200         pSvgaR3State->pFuncsDX->pfnDXDefineDepthStencilView(pThisCC->svga.p3dState);
    2201     }
     2565static int vmsvga3dCmdDXDefineDepthStencilView(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineDepthStencilView const *pCmd, uint32_t cbCmd)
     2566{
     2567#ifdef VMSVGA3D_DX
     2568ASMBreakpoint();
     2569    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2570    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2571    return vmsvga3dDXDefineDepthStencilView(pThisCC, idDXContext);
     2572#else
     2573    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2574    return VERR_NOT_SUPPORTED;
     2575#endif
    22022576}
    22032577
    22042578
    22052579/* SVGA_3D_CMD_DX_DESTROY_DEPTHSTENCIL_VIEW 1190 */
    2206 static void vmsvga3dCmdDXDestroyDepthStencilView(PVGASTATECC pThisCC, SVGA3dCmdDXDestroyDepthStencilView const *pCmd)
    2207 {
    2208 ASMBreakpoint();
    2209     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2210     if (pSvgaR3State->pFuncsDX)
    2211     {
    2212         RT_NOREF(pCmd);
    2213         pSvgaR3State->pFuncsDX->pfnDXDestroyDepthStencilView(pThisCC->svga.p3dState);
    2214     }
     2580static int vmsvga3dCmdDXDestroyDepthStencilView(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDestroyDepthStencilView const *pCmd, uint32_t cbCmd)
     2581{
     2582#ifdef VMSVGA3D_DX
     2583ASMBreakpoint();
     2584    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2585    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2586    return vmsvga3dDXDestroyDepthStencilView(pThisCC, idDXContext);
     2587#else
     2588    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2589    return VERR_NOT_SUPPORTED;
     2590#endif
    22152591}
    22162592
    22172593
    22182594/* SVGA_3D_CMD_DX_DEFINE_ELEMENTLAYOUT 1191 */
    2219 static void vmsvga3dCmdDXDefineElementLayout(PVGASTATECC pThisCC, SVGA3dCmdDXDefineElementLayout const *pCmd)
    2220 {
    2221 ASMBreakpoint();
    2222     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2223     if (pSvgaR3State->pFuncsDX)
    2224     {
    2225         RT_NOREF(pCmd);
    2226         pSvgaR3State->pFuncsDX->pfnDXDefineElementLayout(pThisCC->svga.p3dState);
    2227     }
     2595static int vmsvga3dCmdDXDefineElementLayout(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineElementLayout const *pCmd, uint32_t cbCmd)
     2596{
     2597#ifdef VMSVGA3D_DX
     2598//ASMBreakpoint();
     2599    SVGA3dInputElementDesc const *paDesc = (SVGA3dInputElementDesc *)&pCmd[1];
     2600    uint32_t const cDesc = (cbCmd - sizeof(*pCmd)) / sizeof(SVGA3dInputElementDesc);
     2601    return vmsvga3dDXDefineElementLayout(pThisCC, idDXContext, pCmd->elementLayoutId, cDesc, paDesc);
     2602#else
     2603    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2604    return VERR_NOT_SUPPORTED;
     2605#endif
    22282606}
    22292607
    22302608
    22312609/* SVGA_3D_CMD_DX_DESTROY_ELEMENTLAYOUT 1192 */
    2232 static void vmsvga3dCmdDXDestroyElementLayout(PVGASTATECC pThisCC, SVGA3dCmdDXDestroyElementLayout const *pCmd)
    2233 {
    2234 ASMBreakpoint();
    2235     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2236     if (pSvgaR3State->pFuncsDX)
    2237     {
    2238         RT_NOREF(pCmd);
    2239         pSvgaR3State->pFuncsDX->pfnDXDestroyElementLayout(pThisCC->svga.p3dState);
    2240     }
     2610static int vmsvga3dCmdDXDestroyElementLayout(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDestroyElementLayout const *pCmd, uint32_t cbCmd)
     2611{
     2612#ifdef VMSVGA3D_DX
     2613ASMBreakpoint();
     2614    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2615    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2616    return vmsvga3dDXDestroyElementLayout(pThisCC, idDXContext);
     2617#else
     2618    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2619    return VERR_NOT_SUPPORTED;
     2620#endif
    22412621}
    22422622
    22432623
    22442624/* SVGA_3D_CMD_DX_DEFINE_BLEND_STATE 1193 */
    2245 static void vmsvga3dCmdDXDefineBlendState(PVGASTATECC pThisCC, SVGA3dCmdDXDefineBlendState const *pCmd)
    2246 {
    2247 ASMBreakpoint();
    2248     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2249     if (pSvgaR3State->pFuncsDX)
    2250     {
    2251         RT_NOREF(pCmd);
    2252         pSvgaR3State->pFuncsDX->pfnDXDefineBlendState(pThisCC->svga.p3dState);
    2253     }
     2625static int vmsvga3dCmdDXDefineBlendState(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineBlendState const *pCmd, uint32_t cbCmd)
     2626{
     2627#ifdef VMSVGA3D_DX
     2628//ASMBreakpoint();
     2629    RT_NOREF(cbCmd);
     2630    return vmsvga3dDXDefineBlendState(pThisCC, idDXContext, pCmd);
     2631#else
     2632    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2633    return VERR_NOT_SUPPORTED;
     2634#endif
    22542635}
    22552636
    22562637
    22572638/* SVGA_3D_CMD_DX_DESTROY_BLEND_STATE 1194 */
    2258 static void vmsvga3dCmdDXDestroyBlendState(PVGASTATECC pThisCC, SVGA3dCmdDXDestroyBlendState const *pCmd)
    2259 {
    2260 ASMBreakpoint();
    2261     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2262     if (pSvgaR3State->pFuncsDX)
    2263     {
    2264         RT_NOREF(pCmd);
    2265         pSvgaR3State->pFuncsDX->pfnDXDestroyBlendState(pThisCC->svga.p3dState);
    2266     }
     2639static int vmsvga3dCmdDXDestroyBlendState(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDestroyBlendState const *pCmd, uint32_t cbCmd)
     2640{
     2641#ifdef VMSVGA3D_DX
     2642ASMBreakpoint();
     2643    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2644    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2645    return vmsvga3dDXDestroyBlendState(pThisCC, idDXContext);
     2646#else
     2647    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2648    return VERR_NOT_SUPPORTED;
     2649#endif
    22672650}
    22682651
    22692652
    22702653/* SVGA_3D_CMD_DX_DEFINE_DEPTHSTENCIL_STATE 1195 */
    2271 static void vmsvga3dCmdDXDefineDepthStencilState(PVGASTATECC pThisCC, SVGA3dCmdDXDefineDepthStencilState const *pCmd)
    2272 {
    2273 ASMBreakpoint();
    2274     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2275     if (pSvgaR3State->pFuncsDX)
    2276     {
    2277         RT_NOREF(pCmd);
    2278         pSvgaR3State->pFuncsDX->pfnDXDefineDepthStencilState(pThisCC->svga.p3dState);
    2279     }
     2654static int vmsvga3dCmdDXDefineDepthStencilState(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineDepthStencilState const *pCmd, uint32_t cbCmd)
     2655{
     2656#ifdef VMSVGA3D_DX
     2657//ASMBreakpoint();
     2658    RT_NOREF(cbCmd);
     2659    return vmsvga3dDXDefineDepthStencilState(pThisCC, idDXContext, pCmd);
     2660#else
     2661    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2662    return VERR_NOT_SUPPORTED;
     2663#endif
    22802664}
    22812665
    22822666
    22832667/* SVGA_3D_CMD_DX_DESTROY_DEPTHSTENCIL_STATE 1196 */
    2284 static void vmsvga3dCmdDXDestroyDepthStencilState(PVGASTATECC pThisCC, SVGA3dCmdDXDestroyDepthStencilState const *pCmd)
    2285 {
    2286 ASMBreakpoint();
    2287     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2288     if (pSvgaR3State->pFuncsDX)
    2289     {
    2290         RT_NOREF(pCmd);
    2291         pSvgaR3State->pFuncsDX->pfnDXDestroyDepthStencilState(pThisCC->svga.p3dState);
    2292     }
     2668static int vmsvga3dCmdDXDestroyDepthStencilState(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDestroyDepthStencilState const *pCmd, uint32_t cbCmd)
     2669{
     2670#ifdef VMSVGA3D_DX
     2671ASMBreakpoint();
     2672    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2673    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2674    return vmsvga3dDXDestroyDepthStencilState(pThisCC, idDXContext);
     2675#else
     2676    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2677    return VERR_NOT_SUPPORTED;
     2678#endif
    22932679}
    22942680
    22952681
    22962682/* SVGA_3D_CMD_DX_DEFINE_RASTERIZER_STATE 1197 */
    2297 static void vmsvga3dCmdDXDefineRasterizerState(PVGASTATECC pThisCC, SVGA3dCmdDXDefineRasterizerState const *pCmd)
    2298 {
    2299 ASMBreakpoint();
    2300     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2301     if (pSvgaR3State->pFuncsDX)
    2302     {
    2303         RT_NOREF(pCmd);
    2304         pSvgaR3State->pFuncsDX->pfnDXDefineRasterizerState(pThisCC->svga.p3dState);
    2305     }
     2683static int vmsvga3dCmdDXDefineRasterizerState(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineRasterizerState const *pCmd, uint32_t cbCmd)
     2684{
     2685#ifdef VMSVGA3D_DX
     2686//ASMBreakpoint();
     2687    RT_NOREF(cbCmd);
     2688    return vmsvga3dDXDefineRasterizerState(pThisCC, idDXContext, pCmd);
     2689#else
     2690    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2691    return VERR_NOT_SUPPORTED;
     2692#endif
    23062693}
    23072694
    23082695
    23092696/* SVGA_3D_CMD_DX_DESTROY_RASTERIZER_STATE 1198 */
    2310 static void vmsvga3dCmdDXDestroyRasterizerState(PVGASTATECC pThisCC, SVGA3dCmdDXDestroyRasterizerState const *pCmd)
    2311 {
    2312 ASMBreakpoint();
    2313     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2314     if (pSvgaR3State->pFuncsDX)
    2315     {
    2316         RT_NOREF(pCmd);
    2317         pSvgaR3State->pFuncsDX->pfnDXDestroyRasterizerState(pThisCC->svga.p3dState);
    2318     }
     2697static int vmsvga3dCmdDXDestroyRasterizerState(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDestroyRasterizerState const *pCmd, uint32_t cbCmd)
     2698{
     2699#ifdef VMSVGA3D_DX
     2700ASMBreakpoint();
     2701    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2702    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2703    return vmsvga3dDXDestroyRasterizerState(pThisCC, idDXContext);
     2704#else
     2705    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2706    return VERR_NOT_SUPPORTED;
     2707#endif
    23192708}
    23202709
    23212710
    23222711/* SVGA_3D_CMD_DX_DEFINE_SAMPLER_STATE 1199 */
    2323 static void vmsvga3dCmdDXDefineSamplerState(PVGASTATECC pThisCC, SVGA3dCmdDXDefineSamplerState const *pCmd)
    2324 {
    2325 ASMBreakpoint();
    2326     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2327     if (pSvgaR3State->pFuncsDX)
    2328     {
    2329         RT_NOREF(pCmd);
    2330         pSvgaR3State->pFuncsDX->pfnDXDefineSamplerState(pThisCC->svga.p3dState);
    2331     }
     2712static int vmsvga3dCmdDXDefineSamplerState(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineSamplerState const *pCmd, uint32_t cbCmd)
     2713{
     2714#ifdef VMSVGA3D_DX
     2715//ASMBreakpoint();
     2716    RT_NOREF(cbCmd);
     2717    return vmsvga3dDXDefineSamplerState(pThisCC, idDXContext, pCmd);
     2718#else
     2719    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2720    return VERR_NOT_SUPPORTED;
     2721#endif
    23322722}
    23332723
    23342724
    23352725/* SVGA_3D_CMD_DX_DESTROY_SAMPLER_STATE 1200 */
    2336 static void vmsvga3dCmdDXDestroySamplerState(PVGASTATECC pThisCC, SVGA3dCmdDXDestroySamplerState const *pCmd)
    2337 {
    2338 ASMBreakpoint();
    2339     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2340     if (pSvgaR3State->pFuncsDX)
    2341     {
    2342         RT_NOREF(pCmd);
    2343         pSvgaR3State->pFuncsDX->pfnDXDestroySamplerState(pThisCC->svga.p3dState);
    2344     }
     2726static int vmsvga3dCmdDXDestroySamplerState(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDestroySamplerState const *pCmd, uint32_t cbCmd)
     2727{
     2728#ifdef VMSVGA3D_DX
     2729ASMBreakpoint();
     2730    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2731    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2732    return vmsvga3dDXDestroySamplerState(pThisCC, idDXContext);
     2733#else
     2734    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2735    return VERR_NOT_SUPPORTED;
     2736#endif
    23452737}
    23462738
    23472739
    23482740/* SVGA_3D_CMD_DX_DEFINE_SHADER 1201 */
    2349 static void vmsvga3dCmdDXDefineShader(PVGASTATECC pThisCC, SVGA3dCmdDXDefineShader const *pCmd)
    2350 {
    2351 ASMBreakpoint();
    2352     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2353     if (pSvgaR3State->pFuncsDX)
    2354     {
    2355         RT_NOREF(pCmd);
    2356         pSvgaR3State->pFuncsDX->pfnDXDefineShader(pThisCC->svga.p3dState);
    2357     }
     2741static int vmsvga3dCmdDXDefineShader(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineShader const *pCmd, uint32_t cbCmd)
     2742{
     2743#ifdef VMSVGA3D_DX
     2744//ASMBreakpoint();
     2745    RT_NOREF(cbCmd);
     2746    return vmsvga3dDXDefineShader(pThisCC, idDXContext, pCmd);
     2747#else
     2748    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2749    return VERR_NOT_SUPPORTED;
     2750#endif
    23582751}
    23592752
    23602753
    23612754/* SVGA_3D_CMD_DX_DESTROY_SHADER 1202 */
    2362 static void vmsvga3dCmdDXDestroyShader(PVGASTATECC pThisCC, SVGA3dCmdDXDestroyShader const *pCmd)
    2363 {
    2364 ASMBreakpoint();
    2365     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2366     if (pSvgaR3State->pFuncsDX)
    2367     {
    2368         RT_NOREF(pCmd);
    2369         pSvgaR3State->pFuncsDX->pfnDXDestroyShader(pThisCC->svga.p3dState);
    2370     }
     2755static int vmsvga3dCmdDXDestroyShader(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDestroyShader const *pCmd, uint32_t cbCmd)
     2756{
     2757#ifdef VMSVGA3D_DX
     2758ASMBreakpoint();
     2759    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2760    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2761    return vmsvga3dDXDestroyShader(pThisCC, idDXContext);
     2762#else
     2763    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2764    return VERR_NOT_SUPPORTED;
     2765#endif
    23712766}
    23722767
    23732768
    23742769/* SVGA_3D_CMD_DX_BIND_SHADER 1203 */
    2375 static void vmsvga3dCmdDXBindShader(PVGASTATECC pThisCC, SVGA3dCmdDXBindShader const *pCmd)
    2376 {
    2377 ASMBreakpoint();
    2378     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2379     if (pSvgaR3State->pFuncsDX)
    2380     {
    2381         RT_NOREF(pCmd);
    2382         pSvgaR3State->pFuncsDX->pfnDXBindShader(pThisCC->svga.p3dState);
    2383     }
     2770static int vmsvga3dCmdDXBindShader(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXBindShader const *pCmd, uint32_t cbCmd)
     2771{
     2772#ifdef VMSVGA3D_DX
     2773//ASMBreakpoint();
     2774    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2775    RT_NOREF(cbCmd);
     2776    ASSERT_GUEST_LOGREL_MSG(idDXContext == pCmd->cid, ("idDXContext = %u, pCmd->cid = %u\n", idDXContext, pCmd->cid));
     2777    /* This returns NULL if mob does not exist. If the guest sends a wrong mob id, the current mob will be unbound. */
     2778    PVMSVGAMOB pMob = vmsvgaR3MobGet(pSvgaR3State, pCmd->mobid);
     2779    return vmsvga3dDXBindShader(pThisCC, pCmd->cid, pMob, pCmd->shid, pCmd->offsetInBytes);
     2780#else
     2781    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2782    return VERR_NOT_SUPPORTED;
     2783#endif
    23842784}
    23852785
    23862786
    23872787/* SVGA_3D_CMD_DX_DEFINE_STREAMOUTPUT 1204 */
    2388 static void vmsvga3dCmdDXDefineStreamOutput(PVGASTATECC pThisCC, SVGA3dCmdDXDefineStreamOutput const *pCmd)
    2389 {
    2390 ASMBreakpoint();
    2391     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2392     if (pSvgaR3State->pFuncsDX)
    2393     {
    2394         RT_NOREF(pCmd);
    2395         pSvgaR3State->pFuncsDX->pfnDXDefineStreamOutput(pThisCC->svga.p3dState);
    2396     }
     2788static int vmsvga3dCmdDXDefineStreamOutput(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineStreamOutput const *pCmd, uint32_t cbCmd)
     2789{
     2790#ifdef VMSVGA3D_DX
     2791ASMBreakpoint();
     2792    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2793    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2794    return vmsvga3dDXDefineStreamOutput(pThisCC, idDXContext);
     2795#else
     2796    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2797    return VERR_NOT_SUPPORTED;
     2798#endif
    23972799}
    23982800
    23992801
    24002802/* SVGA_3D_CMD_DX_DESTROY_STREAMOUTPUT 1205 */
    2401 static void vmsvga3dCmdDXDestroyStreamOutput(PVGASTATECC pThisCC, SVGA3dCmdDXDestroyStreamOutput const *pCmd)
    2402 {
    2403 ASMBreakpoint();
    2404     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2405     if (pSvgaR3State->pFuncsDX)
    2406     {
    2407         RT_NOREF(pCmd);
    2408         pSvgaR3State->pFuncsDX->pfnDXDestroyStreamOutput(pThisCC->svga.p3dState);
    2409     }
     2803static int vmsvga3dCmdDXDestroyStreamOutput(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDestroyStreamOutput const *pCmd, uint32_t cbCmd)
     2804{
     2805#ifdef VMSVGA3D_DX
     2806ASMBreakpoint();
     2807    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2808    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2809    return vmsvga3dDXDestroyStreamOutput(pThisCC, idDXContext);
     2810#else
     2811    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2812    return VERR_NOT_SUPPORTED;
     2813#endif
    24102814}
    24112815
    24122816
    24132817/* SVGA_3D_CMD_DX_SET_STREAMOUTPUT 1206 */
    2414 static void vmsvga3dCmdDXSetStreamOutput(PVGASTATECC pThisCC, SVGA3dCmdDXSetStreamOutput const *pCmd)
    2415 {
    2416 ASMBreakpoint();
    2417     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2418     if (pSvgaR3State->pFuncsDX)
    2419     {
    2420         RT_NOREF(pCmd);
    2421         pSvgaR3State->pFuncsDX->pfnDXSetStreamOutput(pThisCC->svga.p3dState);
    2422     }
     2818static int vmsvga3dCmdDXSetStreamOutput(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetStreamOutput const *pCmd, uint32_t cbCmd)
     2819{
     2820#ifdef VMSVGA3D_DX
     2821ASMBreakpoint();
     2822    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2823    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2824    return vmsvga3dDXSetStreamOutput(pThisCC, idDXContext);
     2825#else
     2826    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2827    return VERR_NOT_SUPPORTED;
     2828#endif
    24232829}
    24242830
    24252831
    24262832/* SVGA_3D_CMD_DX_SET_COTABLE 1207 */
    2427 static void vmsvga3dCmdDXSetCOTable(PVGASTATECC pThisCC, SVGA3dCmdDXSetCOTable const *pCmd)
    2428 {
    2429 ASMBreakpoint();
    2430     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2431     if (pSvgaR3State->pFuncsDX)
    2432     {
    2433         RT_NOREF(pCmd);
    2434         pSvgaR3State->pFuncsDX->pfnDXSetCOTable(pThisCC->svga.p3dState);
    2435     }
     2833static int vmsvga3dCmdDXSetCOTable(PVGASTATECC pThisCC, SVGA3dCmdDXSetCOTable const *pCmd, uint32_t cbCmd)
     2834{
     2835#ifdef VMSVGA3D_DX
     2836//ASMBreakpoint();
     2837    RT_NOREF(cbCmd);
     2838    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2839    /* This returns NULL if mob does not exist. If the guest sends a wrong mob id, the current mob will be unbound. */
     2840    PVMSVGAMOB pMob = vmsvgaR3MobGet(pSvgaR3State, pCmd->mobid);
     2841    return vmsvga3dDXSetCOTable(pThisCC, pCmd->cid, pMob, pCmd->type, pCmd->validSizeInBytes);
     2842#else
     2843    RT_NOREF(pThisCC, pCmd, cbCmd);
     2844    return VERR_NOT_SUPPORTED;
     2845#endif
    24362846}
    24372847
    24382848
    24392849/* SVGA_3D_CMD_DX_READBACK_COTABLE 1208 */
    2440 static void vmsvga3dCmdDXReadbackCOTable(PVGASTATECC pThisCC, SVGA3dCmdDXReadbackCOTable const *pCmd)
    2441 {
    2442 ASMBreakpoint();
    2443     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2444     if (pSvgaR3State->pFuncsDX)
    2445     {
    2446         RT_NOREF(pCmd);
    2447         pSvgaR3State->pFuncsDX->pfnDXReadbackCOTable(pThisCC->svga.p3dState);
    2448     }
     2850static int vmsvga3dCmdDXReadbackCOTable(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXReadbackCOTable const *pCmd, uint32_t cbCmd)
     2851{
     2852#ifdef VMSVGA3D_DX
     2853ASMBreakpoint();
     2854    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2855    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2856    return vmsvga3dDXReadbackCOTable(pThisCC, idDXContext);
     2857#else
     2858    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2859    return VERR_NOT_SUPPORTED;
     2860#endif
    24492861}
    24502862
    24512863
    24522864/* SVGA_3D_CMD_DX_BUFFER_COPY 1209 */
    2453 static void vmsvga3dCmdDXBufferCopy(PVGASTATECC pThisCC, SVGA3dCmdDXBufferCopy const *pCmd)
    2454 {
    2455 ASMBreakpoint();
    2456     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2457     if (pSvgaR3State->pFuncsDX)
    2458     {
    2459         RT_NOREF(pCmd);
    2460         pSvgaR3State->pFuncsDX->pfnDXBufferCopy(pThisCC->svga.p3dState);
    2461     }
     2865static int vmsvga3dCmdDXBufferCopy(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXBufferCopy const *pCmd, uint32_t cbCmd)
     2866{
     2867#ifdef VMSVGA3D_DX
     2868ASMBreakpoint();
     2869    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2870    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2871    return vmsvga3dDXBufferCopy(pThisCC, idDXContext);
     2872#else
     2873    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2874    return VERR_NOT_SUPPORTED;
     2875#endif
    24622876}
    24632877
    24642878
    24652879/* SVGA_3D_CMD_DX_TRANSFER_FROM_BUFFER 1210 */
    2466 static void vmsvga3dCmdDXTransferFromBuffer(PVGASTATECC pThisCC, SVGA3dCmdDXTransferFromBuffer const *pCmd)
    2467 {
    2468 ASMBreakpoint();
    2469     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2470     if (pSvgaR3State->pFuncsDX)
    2471     {
    2472         RT_NOREF(pCmd);
    2473         pSvgaR3State->pFuncsDX->pfnDXTransferFromBuffer(pThisCC->svga.p3dState);
    2474     }
     2880static int vmsvga3dCmdDXTransferFromBuffer(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXTransferFromBuffer const *pCmd, uint32_t cbCmd)
     2881{
     2882#ifdef VMSVGA3D_DX
     2883ASMBreakpoint();
     2884    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2885    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2886    return vmsvga3dDXTransferFromBuffer(pThisCC, idDXContext);
     2887#else
     2888    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2889    return VERR_NOT_SUPPORTED;
     2890#endif
    24752891}
    24762892
    24772893
    24782894/* SVGA_3D_CMD_DX_SURFACE_COPY_AND_READBACK 1211 */
    2479 static void vmsvga3dCmdDXSurfaceCopyAndReadback(PVGASTATECC pThisCC, SVGA3dCmdDXSurfaceCopyAndReadback const *pCmd)
    2480 {
    2481 ASMBreakpoint();
    2482     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2483     if (pSvgaR3State->pFuncsDX)
    2484     {
    2485         RT_NOREF(pCmd);
    2486         pSvgaR3State->pFuncsDX->pfnDXSurfaceCopyAndReadback(pThisCC->svga.p3dState);
    2487     }
     2895static int vmsvga3dCmdDXSurfaceCopyAndReadback(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSurfaceCopyAndReadback const *pCmd, uint32_t cbCmd)
     2896{
     2897#ifdef VMSVGA3D_DX
     2898ASMBreakpoint();
     2899    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2900    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2901    return vmsvga3dDXSurfaceCopyAndReadback(pThisCC, idDXContext);
     2902#else
     2903    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2904    return VERR_NOT_SUPPORTED;
     2905#endif
    24882906}
    24892907
    24902908
    24912909/* SVGA_3D_CMD_DX_MOVE_QUERY 1212 */
    2492 static void vmsvga3dCmdDXMoveQuery(PVGASTATECC pThisCC, SVGA3dCmdDXMoveQuery const *pCmd)
    2493 {
    2494 ASMBreakpoint();
    2495     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2496     if (pSvgaR3State->pFuncsDX)
    2497     {
    2498         RT_NOREF(pCmd);
    2499         pSvgaR3State->pFuncsDX->pfnDXMoveQuery(pThisCC->svga.p3dState);
    2500     }
     2910static int vmsvga3dCmdDXMoveQuery(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXMoveQuery const *pCmd, uint32_t cbCmd)
     2911{
     2912#ifdef VMSVGA3D_DX
     2913ASMBreakpoint();
     2914    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2915    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2916    return vmsvga3dDXMoveQuery(pThisCC, idDXContext);
     2917#else
     2918    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2919    return VERR_NOT_SUPPORTED;
     2920#endif
    25012921}
    25022922
    25032923
    25042924/* SVGA_3D_CMD_DX_BIND_ALL_QUERY 1213 */
    2505 static void vmsvga3dCmdDXBindAllQuery(PVGASTATECC pThisCC, SVGA3dCmdDXBindAllQuery const *pCmd)
    2506 {
    2507 ASMBreakpoint();
    2508     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2509     if (pSvgaR3State->pFuncsDX)
    2510     {
    2511         RT_NOREF(pCmd);
    2512         pSvgaR3State->pFuncsDX->pfnDXBindAllQuery(pThisCC->svga.p3dState);
    2513     }
     2925static int vmsvga3dCmdDXBindAllQuery(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXBindAllQuery const *pCmd, uint32_t cbCmd)
     2926{
     2927#ifdef VMSVGA3D_DX
     2928ASMBreakpoint();
     2929    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2930    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2931    return vmsvga3dDXBindAllQuery(pThisCC, idDXContext);
     2932#else
     2933    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2934    return VERR_NOT_SUPPORTED;
     2935#endif
    25142936}
    25152937
    25162938
    25172939/* SVGA_3D_CMD_DX_READBACK_ALL_QUERY 1214 */
    2518 static void vmsvga3dCmdDXReadbackAllQuery(PVGASTATECC pThisCC, SVGA3dCmdDXReadbackAllQuery const *pCmd)
    2519 {
    2520 ASMBreakpoint();
    2521     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2522     if (pSvgaR3State->pFuncsDX)
    2523     {
    2524         RT_NOREF(pCmd);
    2525         pSvgaR3State->pFuncsDX->pfnDXReadbackAllQuery(pThisCC->svga.p3dState);
    2526     }
     2940static int vmsvga3dCmdDXReadbackAllQuery(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXReadbackAllQuery const *pCmd, uint32_t cbCmd)
     2941{
     2942#ifdef VMSVGA3D_DX
     2943ASMBreakpoint();
     2944    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2945    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2946    return vmsvga3dDXReadbackAllQuery(pThisCC, idDXContext);
     2947#else
     2948    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2949    return VERR_NOT_SUPPORTED;
     2950#endif
    25272951}
    25282952
    25292953
    25302954/* SVGA_3D_CMD_DX_PRED_TRANSFER_FROM_BUFFER 1215 */
    2531 static void vmsvga3dCmdDXPredTransferFromBuffer(PVGASTATECC pThisCC, SVGA3dCmdDXPredTransferFromBuffer const *pCmd)
    2532 {
    2533 ASMBreakpoint();
    2534     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2535     if (pSvgaR3State->pFuncsDX)
    2536     {
    2537         RT_NOREF(pCmd);
    2538         pSvgaR3State->pFuncsDX->pfnDXPredTransferFromBuffer(pThisCC->svga.p3dState);
    2539     }
     2955static int vmsvga3dCmdDXPredTransferFromBuffer(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXPredTransferFromBuffer const *pCmd, uint32_t cbCmd)
     2956{
     2957#ifdef VMSVGA3D_DX
     2958ASMBreakpoint();
     2959    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2960    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2961    return vmsvga3dDXPredTransferFromBuffer(pThisCC, idDXContext);
     2962#else
     2963    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2964    return VERR_NOT_SUPPORTED;
     2965#endif
    25402966}
    25412967
    25422968
    25432969/* SVGA_3D_CMD_DX_MOB_FENCE_64 1216 */
    2544 static void vmsvga3dCmdDXMobFence64(PVGASTATECC pThisCC, SVGA3dCmdDXMobFence64 const *pCmd)
    2545 {
    2546 ASMBreakpoint();
    2547     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2548     if (pSvgaR3State->pFuncsDX)
    2549     {
    2550         RT_NOREF(pCmd);
    2551         pSvgaR3State->pFuncsDX->pfnDXMobFence64(pThisCC->svga.p3dState);
    2552     }
     2970static int vmsvga3dCmdDXMobFence64(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXMobFence64 const *pCmd, uint32_t cbCmd)
     2971{
     2972#ifdef VMSVGA3D_DX
     2973ASMBreakpoint();
     2974    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2975    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2976    return vmsvga3dDXMobFence64(pThisCC, idDXContext);
     2977#else
     2978    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2979    return VERR_NOT_SUPPORTED;
     2980#endif
    25532981}
    25542982
    25552983
    25562984/* SVGA_3D_CMD_DX_BIND_ALL_SHADER 1217 */
    2557 static void vmsvga3dCmdDXBindAllShader(PVGASTATECC pThisCC, SVGA3dCmdDXBindAllShader const *pCmd)
    2558 {
    2559 ASMBreakpoint();
    2560     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2561     if (pSvgaR3State->pFuncsDX)
    2562     {
    2563         RT_NOREF(pCmd);
    2564         pSvgaR3State->pFuncsDX->pfnDXBindAllShader(pThisCC->svga.p3dState);
    2565     }
     2985static int vmsvga3dCmdDXBindAllShader(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXBindAllShader const *pCmd, uint32_t cbCmd)
     2986{
     2987#ifdef VMSVGA3D_DX
     2988ASMBreakpoint();
     2989    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     2990    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     2991    return vmsvga3dDXBindAllShader(pThisCC, idDXContext);
     2992#else
     2993    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     2994    return VERR_NOT_SUPPORTED;
     2995#endif
    25662996}
    25672997
    25682998
    25692999/* SVGA_3D_CMD_DX_HINT 1218 */
    2570 static void vmsvga3dCmdDXHint(PVGASTATECC pThisCC, SVGA3dCmdDXHint const *pCmd)
    2571 {
    2572 ASMBreakpoint();
    2573     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2574     if (pSvgaR3State->pFuncsDX)
    2575     {
    2576         RT_NOREF(pCmd);
    2577         pSvgaR3State->pFuncsDX->pfnDXHint(pThisCC->svga.p3dState);
    2578     }
     3000static int vmsvga3dCmdDXHint(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXHint const *pCmd, uint32_t cbCmd)
     3001{
     3002#ifdef VMSVGA3D_DX
     3003ASMBreakpoint();
     3004    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3005    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3006    return vmsvga3dDXHint(pThisCC, idDXContext);
     3007#else
     3008    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3009    return VERR_NOT_SUPPORTED;
     3010#endif
    25793011}
    25803012
    25813013
    25823014/* SVGA_3D_CMD_DX_BUFFER_UPDATE 1219 */
    2583 static void vmsvga3dCmdDXBufferUpdate(PVGASTATECC pThisCC, SVGA3dCmdDXBufferUpdate const *pCmd)
    2584 {
    2585 ASMBreakpoint();
    2586     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2587     if (pSvgaR3State->pFuncsDX)
    2588     {
    2589         RT_NOREF(pCmd);
    2590         pSvgaR3State->pFuncsDX->pfnDXBufferUpdate(pThisCC->svga.p3dState);
    2591     }
     3015static int vmsvga3dCmdDXBufferUpdate(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXBufferUpdate const *pCmd, uint32_t cbCmd)
     3016{
     3017#ifdef VMSVGA3D_DX
     3018ASMBreakpoint();
     3019    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3020    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3021    return vmsvga3dDXBufferUpdate(pThisCC, idDXContext);
     3022#else
     3023    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3024    return VERR_NOT_SUPPORTED;
     3025#endif
    25923026}
    25933027
    25943028
    25953029/* SVGA_3D_CMD_DX_SET_VS_CONSTANT_BUFFER_OFFSET 1220 */
    2596 static void vmsvga3dCmdDXSetVSConstantBufferOffset(PVGASTATECC pThisCC, SVGA3dCmdDXSetVSConstantBufferOffset const *pCmd)
    2597 {
    2598 ASMBreakpoint();
    2599     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2600     if (pSvgaR3State->pFuncsDX)
    2601     {
    2602         RT_NOREF(pCmd);
    2603         pSvgaR3State->pFuncsDX->pfnDXSetVSConstantBufferOffset(pThisCC->svga.p3dState);
    2604     }
     3030static int vmsvga3dCmdDXSetVSConstantBufferOffset(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetVSConstantBufferOffset const *pCmd, uint32_t cbCmd)
     3031{
     3032#ifdef VMSVGA3D_DX
     3033ASMBreakpoint();
     3034    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3035    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3036    return vmsvga3dDXSetVSConstantBufferOffset(pThisCC, idDXContext);
     3037#else
     3038    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3039    return VERR_NOT_SUPPORTED;
     3040#endif
    26053041}
    26063042
    26073043
    26083044/* SVGA_3D_CMD_DX_SET_PS_CONSTANT_BUFFER_OFFSET 1221 */
    2609 static void vmsvga3dCmdDXSetPSConstantBufferOffset(PVGASTATECC pThisCC, SVGA3dCmdDXSetPSConstantBufferOffset const *pCmd)
    2610 {
    2611 ASMBreakpoint();
    2612     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2613     if (pSvgaR3State->pFuncsDX)
    2614     {
    2615         RT_NOREF(pCmd);
    2616         pSvgaR3State->pFuncsDX->pfnDXSetPSConstantBufferOffset(pThisCC->svga.p3dState);
    2617     }
     3045static int vmsvga3dCmdDXSetPSConstantBufferOffset(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetPSConstantBufferOffset const *pCmd, uint32_t cbCmd)
     3046{
     3047#ifdef VMSVGA3D_DX
     3048ASMBreakpoint();
     3049    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3050    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3051    return vmsvga3dDXSetPSConstantBufferOffset(pThisCC, idDXContext);
     3052#else
     3053    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3054    return VERR_NOT_SUPPORTED;
     3055#endif
    26183056}
    26193057
    26203058
    26213059/* SVGA_3D_CMD_DX_SET_GS_CONSTANT_BUFFER_OFFSET 1222 */
    2622 static void vmsvga3dCmdDXSetGSConstantBufferOffset(PVGASTATECC pThisCC, SVGA3dCmdDXSetGSConstantBufferOffset const *pCmd)
    2623 {
    2624 ASMBreakpoint();
    2625     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2626     if (pSvgaR3State->pFuncsDX)
    2627     {
    2628         RT_NOREF(pCmd);
    2629         pSvgaR3State->pFuncsDX->pfnDXSetGSConstantBufferOffset(pThisCC->svga.p3dState);
    2630     }
     3060static int vmsvga3dCmdDXSetGSConstantBufferOffset(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetGSConstantBufferOffset const *pCmd, uint32_t cbCmd)
     3061{
     3062#ifdef VMSVGA3D_DX
     3063ASMBreakpoint();
     3064    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3065    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3066    return vmsvga3dDXSetGSConstantBufferOffset(pThisCC, idDXContext);
     3067#else
     3068    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3069    return VERR_NOT_SUPPORTED;
     3070#endif
    26313071}
    26323072
    26333073
    26343074/* SVGA_3D_CMD_DX_SET_HS_CONSTANT_BUFFER_OFFSET 1223 */
    2635 static void vmsvga3dCmdDXSetHSConstantBufferOffset(PVGASTATECC pThisCC, SVGA3dCmdDXSetHSConstantBufferOffset const *pCmd)
    2636 {
    2637 ASMBreakpoint();
    2638     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2639     if (pSvgaR3State->pFuncsDX)
    2640     {
    2641         RT_NOREF(pCmd);
    2642         pSvgaR3State->pFuncsDX->pfnDXSetHSConstantBufferOffset(pThisCC->svga.p3dState);
    2643     }
     3075static int vmsvga3dCmdDXSetHSConstantBufferOffset(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetHSConstantBufferOffset const *pCmd, uint32_t cbCmd)
     3076{
     3077#ifdef VMSVGA3D_DX
     3078ASMBreakpoint();
     3079    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3080    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3081    return vmsvga3dDXSetHSConstantBufferOffset(pThisCC, idDXContext);
     3082#else
     3083    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3084    return VERR_NOT_SUPPORTED;
     3085#endif
    26443086}
    26453087
    26463088
    26473089/* SVGA_3D_CMD_DX_SET_DS_CONSTANT_BUFFER_OFFSET 1224 */
    2648 static void vmsvga3dCmdDXSetDSConstantBufferOffset(PVGASTATECC pThisCC, SVGA3dCmdDXSetDSConstantBufferOffset const *pCmd)
    2649 {
    2650 ASMBreakpoint();
    2651     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2652     if (pSvgaR3State->pFuncsDX)
    2653     {
    2654         RT_NOREF(pCmd);
    2655         pSvgaR3State->pFuncsDX->pfnDXSetDSConstantBufferOffset(pThisCC->svga.p3dState);
    2656     }
     3090static int vmsvga3dCmdDXSetDSConstantBufferOffset(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetDSConstantBufferOffset const *pCmd, uint32_t cbCmd)
     3091{
     3092#ifdef VMSVGA3D_DX
     3093ASMBreakpoint();
     3094    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3095    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3096    return vmsvga3dDXSetDSConstantBufferOffset(pThisCC, idDXContext);
     3097#else
     3098    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3099    return VERR_NOT_SUPPORTED;
     3100#endif
    26573101}
    26583102
    26593103
    26603104/* SVGA_3D_CMD_DX_SET_CS_CONSTANT_BUFFER_OFFSET 1225 */
    2661 static void vmsvga3dCmdDXSetCSConstantBufferOffset(PVGASTATECC pThisCC, SVGA3dCmdDXSetCSConstantBufferOffset const *pCmd)
    2662 {
    2663 ASMBreakpoint();
    2664     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2665     if (pSvgaR3State->pFuncsDX)
    2666     {
    2667         RT_NOREF(pCmd);
    2668         pSvgaR3State->pFuncsDX->pfnDXSetCSConstantBufferOffset(pThisCC->svga.p3dState);
    2669     }
     3105static int vmsvga3dCmdDXSetCSConstantBufferOffset(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetCSConstantBufferOffset const *pCmd, uint32_t cbCmd)
     3106{
     3107#ifdef VMSVGA3D_DX
     3108ASMBreakpoint();
     3109    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3110    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3111    return vmsvga3dDXSetCSConstantBufferOffset(pThisCC, idDXContext);
     3112#else
     3113    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3114    return VERR_NOT_SUPPORTED;
     3115#endif
    26703116}
    26713117
    26723118
    26733119/* SVGA_3D_CMD_DX_COND_BIND_ALL_SHADER 1226 */
    2674 static void vmsvga3dCmdDXCondBindAllShader(PVGASTATECC pThisCC, SVGA3dCmdDXCondBindAllShader const *pCmd)
    2675 {
    2676 ASMBreakpoint();
    2677     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2678     if (pSvgaR3State->pFuncsDX)
    2679     {
    2680         RT_NOREF(pCmd);
    2681         pSvgaR3State->pFuncsDX->pfnDXCondBindAllShader(pThisCC->svga.p3dState);
    2682     }
     3120static int vmsvga3dCmdDXCondBindAllShader(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXCondBindAllShader const *pCmd, uint32_t cbCmd)
     3121{
     3122#ifdef VMSVGA3D_DX
     3123ASMBreakpoint();
     3124    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3125    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3126    return vmsvga3dDXCondBindAllShader(pThisCC, idDXContext);
     3127#else
     3128    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3129    return VERR_NOT_SUPPORTED;
     3130#endif
    26833131}
    26843132
    26853133
    26863134/* SVGA_3D_CMD_SCREEN_COPY 1227 */
    2687 static void vmsvga3dCmdScreenCopy(PVGASTATECC pThisCC, SVGA3dCmdScreenCopy const *pCmd)
    2688 {
    2689 ASMBreakpoint();
    2690     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2691     if (pSvgaR3State->pFuncsDX)
    2692     {
    2693         RT_NOREF(pCmd);
    2694         pSvgaR3State->pFuncsDX->pfnScreenCopy(pThisCC->svga.p3dState);
    2695     }
     3135static int vmsvga3dCmdScreenCopy(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdScreenCopy const *pCmd, uint32_t cbCmd)
     3136{
     3137#ifdef VMSVGA3D_DX
     3138ASMBreakpoint();
     3139    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3140    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3141    return vmsvga3dScreenCopy(pThisCC, idDXContext);
     3142#else
     3143    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3144    return VERR_NOT_SUPPORTED;
     3145#endif
    26963146}
    26973147
    26983148
    26993149/* SVGA_3D_CMD_GROW_OTABLE 1236 */
    2700 static void vmsvga3dCmdGrowOTable(PVGASTATECC pThisCC, SVGA3dCmdGrowOTable const *pCmd)
    2701 {
    2702 ASMBreakpoint();
    2703     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2704     if (pSvgaR3State->pFuncsDX)
    2705     {
    2706         RT_NOREF(pCmd);
    2707         pSvgaR3State->pFuncsDX->pfnGrowOTable(pThisCC->svga.p3dState);
    2708     }
     3150static int vmsvga3dCmdGrowOTable(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdGrowOTable const *pCmd, uint32_t cbCmd)
     3151{
     3152#ifdef VMSVGA3D_DX
     3153ASMBreakpoint();
     3154    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3155    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3156    return vmsvga3dGrowOTable(pThisCC, idDXContext);
     3157#else
     3158    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3159    return VERR_NOT_SUPPORTED;
     3160#endif
    27093161}
    27103162
    27113163
    27123164/* SVGA_3D_CMD_DX_GROW_COTABLE 1237 */
    2713 static void vmsvga3dCmdDXGrowCOTable(PVGASTATECC pThisCC, SVGA3dCmdDXGrowCOTable const *pCmd)
    2714 {
    2715 ASMBreakpoint();
    2716     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2717     if (pSvgaR3State->pFuncsDX)
    2718     {
    2719         RT_NOREF(pCmd);
    2720         pSvgaR3State->pFuncsDX->pfnDXGrowCOTable(pThisCC->svga.p3dState);
    2721     }
     3165static int vmsvga3dCmdDXGrowCOTable(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXGrowCOTable const *pCmd, uint32_t cbCmd)
     3166{
     3167#ifdef VMSVGA3D_DX
     3168ASMBreakpoint();
     3169    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3170    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3171    return vmsvga3dDXGrowCOTable(pThisCC, idDXContext);
     3172#else
     3173    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3174    return VERR_NOT_SUPPORTED;
     3175#endif
    27223176}
    27233177
    27243178
    27253179/* SVGA_3D_CMD_INTRA_SURFACE_COPY 1238 */
    2726 static void vmsvga3dCmdIntraSurfaceCopy(PVGASTATECC pThisCC, SVGA3dCmdIntraSurfaceCopy const *pCmd)
    2727 {
    2728 ASMBreakpoint();
    2729     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2730     if (pSvgaR3State->pFuncsDX)
    2731     {
    2732         RT_NOREF(pCmd);
    2733         pSvgaR3State->pFuncsDX->pfnIntraSurfaceCopy(pThisCC->svga.p3dState);
    2734     }
     3180static int vmsvga3dCmdIntraSurfaceCopy(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdIntraSurfaceCopy const *pCmd, uint32_t cbCmd)
     3181{
     3182#ifdef VMSVGA3D_DX
     3183ASMBreakpoint();
     3184    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3185    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3186    return vmsvga3dIntraSurfaceCopy(pThisCC, idDXContext);
     3187#else
     3188    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3189    return VERR_NOT_SUPPORTED;
     3190#endif
    27353191}
    27363192
    27373193
    27383194/* SVGA_3D_CMD_DEFINE_GB_SURFACE_V3 1239 */
    2739 static void vmsvga3dCmdDefineGBSurface_v3(PVGASTATECC pThisCC, SVGA3dCmdDefineGBSurface_v3 const *pCmd)
    2740 {
    2741 ASMBreakpoint();
    2742     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2743     if (pSvgaR3State->pFuncsDX)
    2744     {
    2745         RT_NOREF(pCmd);
    2746         pSvgaR3State->pFuncsDX->pfnDefineGBSurface_v3(pThisCC->svga.p3dState);
    2747     }
     3195static int vmsvga3dCmdDefineGBSurface_v3(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDefineGBSurface_v3 const *pCmd, uint32_t cbCmd)
     3196{
     3197#ifdef VMSVGA3D_DX
     3198ASMBreakpoint();
     3199    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3200    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3201    return vmsvga3dDefineGBSurface_v3(pThisCC, idDXContext);
     3202#else
     3203    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3204    return VERR_NOT_SUPPORTED;
     3205#endif
    27483206}
    27493207
    27503208
    27513209/* SVGA_3D_CMD_DX_RESOLVE_COPY 1240 */
    2752 static void vmsvga3dCmdDXResolveCopy(PVGASTATECC pThisCC, SVGA3dCmdDXResolveCopy const *pCmd)
    2753 {
    2754 ASMBreakpoint();
    2755     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2756     if (pSvgaR3State->pFuncsDX)
    2757     {
    2758         RT_NOREF(pCmd);
    2759         pSvgaR3State->pFuncsDX->pfnDXResolveCopy(pThisCC->svga.p3dState);
    2760     }
     3210static int vmsvga3dCmdDXResolveCopy(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXResolveCopy const *pCmd, uint32_t cbCmd)
     3211{
     3212#ifdef VMSVGA3D_DX
     3213ASMBreakpoint();
     3214    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3215    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3216    return vmsvga3dDXResolveCopy(pThisCC, idDXContext);
     3217#else
     3218    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3219    return VERR_NOT_SUPPORTED;
     3220#endif
    27613221}
    27623222
    27633223
    27643224/* SVGA_3D_CMD_DX_PRED_RESOLVE_COPY 1241 */
    2765 static void vmsvga3dCmdDXPredResolveCopy(PVGASTATECC pThisCC, SVGA3dCmdDXPredResolveCopy const *pCmd)
    2766 {
    2767 ASMBreakpoint();
    2768     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2769     if (pSvgaR3State->pFuncsDX)
    2770     {
    2771         RT_NOREF(pCmd);
    2772         pSvgaR3State->pFuncsDX->pfnDXPredResolveCopy(pThisCC->svga.p3dState);
    2773     }
     3225static int vmsvga3dCmdDXPredResolveCopy(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXPredResolveCopy const *pCmd, uint32_t cbCmd)
     3226{
     3227#ifdef VMSVGA3D_DX
     3228ASMBreakpoint();
     3229    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3230    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3231    return vmsvga3dDXPredResolveCopy(pThisCC, idDXContext);
     3232#else
     3233    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3234    return VERR_NOT_SUPPORTED;
     3235#endif
    27743236}
    27753237
    27763238
    27773239/* SVGA_3D_CMD_DX_PRED_CONVERT_REGION 1242 */
    2778 static void vmsvga3dCmdDXPredConvertRegion(PVGASTATECC pThisCC, SVGA3dCmdDXPredConvertRegion const *pCmd)
    2779 {
    2780 ASMBreakpoint();
    2781     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2782     if (pSvgaR3State->pFuncsDX)
    2783     {
    2784         RT_NOREF(pCmd);
    2785         pSvgaR3State->pFuncsDX->pfnDXPredConvertRegion(pThisCC->svga.p3dState);
    2786     }
     3240static int vmsvga3dCmdDXPredConvertRegion(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXPredConvertRegion const *pCmd, uint32_t cbCmd)
     3241{
     3242#ifdef VMSVGA3D_DX
     3243ASMBreakpoint();
     3244    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3245    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3246    return vmsvga3dDXPredConvertRegion(pThisCC, idDXContext);
     3247#else
     3248    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3249    return VERR_NOT_SUPPORTED;
     3250#endif
    27873251}
    27883252
    27893253
    27903254/* SVGA_3D_CMD_DX_PRED_CONVERT 1243 */
    2791 static void vmsvga3dCmdDXPredConvert(PVGASTATECC pThisCC, SVGA3dCmdDXPredConvert const *pCmd)
    2792 {
    2793 ASMBreakpoint();
    2794     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2795     if (pSvgaR3State->pFuncsDX)
    2796     {
    2797         RT_NOREF(pCmd);
    2798         pSvgaR3State->pFuncsDX->pfnDXPredConvert(pThisCC->svga.p3dState);
    2799     }
     3255static int vmsvga3dCmdDXPredConvert(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXPredConvert const *pCmd, uint32_t cbCmd)
     3256{
     3257#ifdef VMSVGA3D_DX
     3258ASMBreakpoint();
     3259    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3260    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3261    return vmsvga3dDXPredConvert(pThisCC, idDXContext);
     3262#else
     3263    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3264    return VERR_NOT_SUPPORTED;
     3265#endif
    28003266}
    28013267
    28023268
    28033269/* SVGA_3D_CMD_WHOLE_SURFACE_COPY 1244 */
    2804 static void vmsvga3dCmdWholeSurfaceCopy(PVGASTATECC pThisCC, SVGA3dCmdWholeSurfaceCopy const *pCmd)
    2805 {
    2806 ASMBreakpoint();
    2807     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2808     if (pSvgaR3State->pFuncsDX)
    2809     {
    2810         RT_NOREF(pCmd);
    2811         pSvgaR3State->pFuncsDX->pfnWholeSurfaceCopy(pThisCC->svga.p3dState);
    2812     }
     3270static int vmsvga3dCmdWholeSurfaceCopy(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdWholeSurfaceCopy const *pCmd, uint32_t cbCmd)
     3271{
     3272#ifdef VMSVGA3D_DX
     3273ASMBreakpoint();
     3274    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3275    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3276    return vmsvga3dWholeSurfaceCopy(pThisCC, idDXContext);
     3277#else
     3278    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3279    return VERR_NOT_SUPPORTED;
     3280#endif
    28133281}
    28143282
    28153283
    28163284/* SVGA_3D_CMD_DX_DEFINE_UA_VIEW 1245 */
    2817 static void vmsvga3dCmdDXDefineUAView(PVGASTATECC pThisCC, SVGA3dCmdDXDefineUAView const *pCmd)
    2818 {
    2819 ASMBreakpoint();
    2820     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2821     if (pSvgaR3State->pFuncsDX)
    2822     {
    2823         RT_NOREF(pCmd);
    2824         pSvgaR3State->pFuncsDX->pfnDXDefineUAView(pThisCC->svga.p3dState);
    2825     }
     3285static int vmsvga3dCmdDXDefineUAView(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineUAView const *pCmd, uint32_t cbCmd)
     3286{
     3287#ifdef VMSVGA3D_DX
     3288ASMBreakpoint();
     3289    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3290    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3291    return vmsvga3dDXDefineUAView(pThisCC, idDXContext);
     3292#else
     3293    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3294    return VERR_NOT_SUPPORTED;
     3295#endif
    28263296}
    28273297
    28283298
    28293299/* SVGA_3D_CMD_DX_DESTROY_UA_VIEW 1246 */
    2830 static void vmsvga3dCmdDXDestroyUAView(PVGASTATECC pThisCC, SVGA3dCmdDXDestroyUAView const *pCmd)
    2831 {
    2832 ASMBreakpoint();
    2833     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2834     if (pSvgaR3State->pFuncsDX)
    2835     {
    2836         RT_NOREF(pCmd);
    2837         pSvgaR3State->pFuncsDX->pfnDXDestroyUAView(pThisCC->svga.p3dState);
    2838     }
     3300static int vmsvga3dCmdDXDestroyUAView(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDestroyUAView const *pCmd, uint32_t cbCmd)
     3301{
     3302#ifdef VMSVGA3D_DX
     3303ASMBreakpoint();
     3304    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3305    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3306    return vmsvga3dDXDestroyUAView(pThisCC, idDXContext);
     3307#else
     3308    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3309    return VERR_NOT_SUPPORTED;
     3310#endif
    28393311}
    28403312
    28413313
    28423314/* SVGA_3D_CMD_DX_CLEAR_UA_VIEW_UINT 1247 */
    2843 static void vmsvga3dCmdDXClearUAViewUint(PVGASTATECC pThisCC, SVGA3dCmdDXClearUAViewUint const *pCmd)
    2844 {
    2845 ASMBreakpoint();
    2846     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2847     if (pSvgaR3State->pFuncsDX)
    2848     {
    2849         RT_NOREF(pCmd);
    2850         pSvgaR3State->pFuncsDX->pfnDXClearUAViewUint(pThisCC->svga.p3dState);
    2851     }
     3315static int vmsvga3dCmdDXClearUAViewUint(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXClearUAViewUint const *pCmd, uint32_t cbCmd)
     3316{
     3317#ifdef VMSVGA3D_DX
     3318ASMBreakpoint();
     3319    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3320    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3321    return vmsvga3dDXClearUAViewUint(pThisCC, idDXContext);
     3322#else
     3323    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3324    return VERR_NOT_SUPPORTED;
     3325#endif
    28523326}
    28533327
    28543328
    28553329/* SVGA_3D_CMD_DX_CLEAR_UA_VIEW_FLOAT 1248 */
    2856 static void vmsvga3dCmdDXClearUAViewFloat(PVGASTATECC pThisCC, SVGA3dCmdDXClearUAViewFloat const *pCmd)
    2857 {
    2858 ASMBreakpoint();
    2859     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2860     if (pSvgaR3State->pFuncsDX)
    2861     {
    2862         RT_NOREF(pCmd);
    2863         pSvgaR3State->pFuncsDX->pfnDXClearUAViewFloat(pThisCC->svga.p3dState);
    2864     }
     3330static int vmsvga3dCmdDXClearUAViewFloat(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXClearUAViewFloat const *pCmd, uint32_t cbCmd)
     3331{
     3332#ifdef VMSVGA3D_DX
     3333ASMBreakpoint();
     3334    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3335    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3336    return vmsvga3dDXClearUAViewFloat(pThisCC, idDXContext);
     3337#else
     3338    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3339    return VERR_NOT_SUPPORTED;
     3340#endif
    28653341}
    28663342
    28673343
    28683344/* SVGA_3D_CMD_DX_COPY_STRUCTURE_COUNT 1249 */
    2869 static void vmsvga3dCmdDXCopyStructureCount(PVGASTATECC pThisCC, SVGA3dCmdDXCopyStructureCount const *pCmd)
    2870 {
    2871 ASMBreakpoint();
    2872     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2873     if (pSvgaR3State->pFuncsDX)
    2874     {
    2875         RT_NOREF(pCmd);
    2876         pSvgaR3State->pFuncsDX->pfnDXCopyStructureCount(pThisCC->svga.p3dState);
    2877     }
     3345static int vmsvga3dCmdDXCopyStructureCount(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXCopyStructureCount const *pCmd, uint32_t cbCmd)
     3346{
     3347#ifdef VMSVGA3D_DX
     3348ASMBreakpoint();
     3349    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3350    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3351    return vmsvga3dDXCopyStructureCount(pThisCC, idDXContext);
     3352#else
     3353    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3354    return VERR_NOT_SUPPORTED;
     3355#endif
    28783356}
    28793357
    28803358
    28813359/* SVGA_3D_CMD_DX_SET_UA_VIEWS 1250 */
    2882 static void vmsvga3dCmdDXSetUAViews(PVGASTATECC pThisCC, SVGA3dCmdDXSetUAViews const *pCmd)
    2883 {
    2884 ASMBreakpoint();
    2885     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2886     if (pSvgaR3State->pFuncsDX)
    2887     {
    2888         RT_NOREF(pCmd);
    2889         pSvgaR3State->pFuncsDX->pfnDXSetUAViews(pThisCC->svga.p3dState);
    2890     }
     3360static int vmsvga3dCmdDXSetUAViews(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetUAViews const *pCmd, uint32_t cbCmd)
     3361{
     3362#ifdef VMSVGA3D_DX
     3363ASMBreakpoint();
     3364    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3365    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3366    return vmsvga3dDXSetUAViews(pThisCC, idDXContext);
     3367#else
     3368    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3369    return VERR_NOT_SUPPORTED;
     3370#endif
    28913371}
    28923372
    28933373
    28943374/* SVGA_3D_CMD_DX_DRAW_INDEXED_INSTANCED_INDIRECT 1251 */
    2895 static void vmsvga3dCmdDXDrawIndexedInstancedIndirect(PVGASTATECC pThisCC, SVGA3dCmdDXDrawIndexedInstancedIndirect const *pCmd)
    2896 {
    2897 ASMBreakpoint();
    2898     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2899     if (pSvgaR3State->pFuncsDX)
    2900     {
    2901         RT_NOREF(pCmd);
    2902         pSvgaR3State->pFuncsDX->pfnDXDrawIndexedInstancedIndirect(pThisCC->svga.p3dState);
    2903     }
     3375static int vmsvga3dCmdDXDrawIndexedInstancedIndirect(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDrawIndexedInstancedIndirect const *pCmd, uint32_t cbCmd)
     3376{
     3377#ifdef VMSVGA3D_DX
     3378ASMBreakpoint();
     3379    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3380    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3381    return vmsvga3dDXDrawIndexedInstancedIndirect(pThisCC, idDXContext);
     3382#else
     3383    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3384    return VERR_NOT_SUPPORTED;
     3385#endif
    29043386}
    29053387
    29063388
    29073389/* SVGA_3D_CMD_DX_DRAW_INSTANCED_INDIRECT 1252 */
    2908 static void vmsvga3dCmdDXDrawInstancedIndirect(PVGASTATECC pThisCC, SVGA3dCmdDXDrawInstancedIndirect const *pCmd)
    2909 {
    2910 ASMBreakpoint();
    2911     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2912     if (pSvgaR3State->pFuncsDX)
    2913     {
    2914         RT_NOREF(pCmd);
    2915         pSvgaR3State->pFuncsDX->pfnDXDrawInstancedIndirect(pThisCC->svga.p3dState);
    2916     }
     3390static int vmsvga3dCmdDXDrawInstancedIndirect(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDrawInstancedIndirect const *pCmd, uint32_t cbCmd)
     3391{
     3392#ifdef VMSVGA3D_DX
     3393ASMBreakpoint();
     3394    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3395    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3396    return vmsvga3dDXDrawInstancedIndirect(pThisCC, idDXContext);
     3397#else
     3398    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3399    return VERR_NOT_SUPPORTED;
     3400#endif
    29173401}
    29183402
    29193403
    29203404/* SVGA_3D_CMD_DX_DISPATCH 1253 */
    2921 static void vmsvga3dCmdDXDispatch(PVGASTATECC pThisCC, SVGA3dCmdDXDispatch const *pCmd)
    2922 {
    2923 ASMBreakpoint();
    2924     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2925     if (pSvgaR3State->pFuncsDX)
    2926     {
    2927         RT_NOREF(pCmd);
    2928         pSvgaR3State->pFuncsDX->pfnDXDispatch(pThisCC->svga.p3dState);
    2929     }
     3405static int vmsvga3dCmdDXDispatch(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDispatch const *pCmd, uint32_t cbCmd)
     3406{
     3407#ifdef VMSVGA3D_DX
     3408ASMBreakpoint();
     3409    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3410    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3411    return vmsvga3dDXDispatch(pThisCC, idDXContext);
     3412#else
     3413    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3414    return VERR_NOT_SUPPORTED;
     3415#endif
    29303416}
    29313417
    29323418
    29333419/* SVGA_3D_CMD_DX_DISPATCH_INDIRECT 1254 */
    2934 static void vmsvga3dCmdDXDispatchIndirect(PVGASTATECC pThisCC, SVGA3dCmdDXDispatchIndirect const *pCmd)
    2935 {
    2936 ASMBreakpoint();
    2937     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2938     if (pSvgaR3State->pFuncsDX)
    2939     {
    2940         RT_NOREF(pCmd);
    2941         pSvgaR3State->pFuncsDX->pfnDXDispatchIndirect(pThisCC->svga.p3dState);
    2942     }
     3420static int vmsvga3dCmdDXDispatchIndirect(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDispatchIndirect const *pCmd, uint32_t cbCmd)
     3421{
     3422#ifdef VMSVGA3D_DX
     3423ASMBreakpoint();
     3424    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3425    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3426    return vmsvga3dDXDispatchIndirect(pThisCC, idDXContext);
     3427#else
     3428    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3429    return VERR_NOT_SUPPORTED;
     3430#endif
    29433431}
    29443432
    29453433
    29463434/* SVGA_3D_CMD_WRITE_ZERO_SURFACE 1255 */
    2947 static void vmsvga3dCmdWriteZeroSurface(PVGASTATECC pThisCC, SVGA3dCmdWriteZeroSurface const *pCmd)
    2948 {
    2949 ASMBreakpoint();
    2950     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2951     if (pSvgaR3State->pFuncsDX)
    2952     {
    2953         RT_NOREF(pCmd);
    2954         pSvgaR3State->pFuncsDX->pfnWriteZeroSurface(pThisCC->svga.p3dState);
    2955     }
     3435static int vmsvga3dCmdWriteZeroSurface(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdWriteZeroSurface const *pCmd, uint32_t cbCmd)
     3436{
     3437#ifdef VMSVGA3D_DX
     3438ASMBreakpoint();
     3439    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3440    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3441    return vmsvga3dWriteZeroSurface(pThisCC, idDXContext);
     3442#else
     3443    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3444    return VERR_NOT_SUPPORTED;
     3445#endif
    29563446}
    29573447
    29583448
    29593449/* SVGA_3D_CMD_HINT_ZERO_SURFACE 1256 */
    2960 static void vmsvga3dCmdHintZeroSurface(PVGASTATECC pThisCC, SVGA3dCmdHintZeroSurface const *pCmd)
    2961 {
    2962 ASMBreakpoint();
    2963     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2964     if (pSvgaR3State->pFuncsDX)
    2965     {
    2966         RT_NOREF(pCmd);
    2967         pSvgaR3State->pFuncsDX->pfnHintZeroSurface(pThisCC->svga.p3dState);
    2968     }
     3450static int vmsvga3dCmdHintZeroSurface(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdHintZeroSurface const *pCmd, uint32_t cbCmd)
     3451{
     3452#ifdef VMSVGA3D_DX
     3453ASMBreakpoint();
     3454    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3455    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3456    return vmsvga3dHintZeroSurface(pThisCC, idDXContext);
     3457#else
     3458    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3459    return VERR_NOT_SUPPORTED;
     3460#endif
    29693461}
    29703462
    29713463
    29723464/* SVGA_3D_CMD_DX_TRANSFER_TO_BUFFER 1257 */
    2973 static void vmsvga3dCmdDXTransferToBuffer(PVGASTATECC pThisCC, SVGA3dCmdDXTransferToBuffer const *pCmd)
    2974 {
    2975 ASMBreakpoint();
    2976     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2977     if (pSvgaR3State->pFuncsDX)
    2978     {
    2979         RT_NOREF(pCmd);
    2980         pSvgaR3State->pFuncsDX->pfnDXTransferToBuffer(pThisCC->svga.p3dState);
    2981     }
     3465static int vmsvga3dCmdDXTransferToBuffer(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXTransferToBuffer const *pCmd, uint32_t cbCmd)
     3466{
     3467#ifdef VMSVGA3D_DX
     3468ASMBreakpoint();
     3469    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3470    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3471    return vmsvga3dDXTransferToBuffer(pThisCC, idDXContext);
     3472#else
     3473    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3474    return VERR_NOT_SUPPORTED;
     3475#endif
    29823476}
    29833477
    29843478
    29853479/* SVGA_3D_CMD_DX_SET_STRUCTURE_COUNT 1258 */
    2986 static void vmsvga3dCmdDXSetStructureCount(PVGASTATECC pThisCC, SVGA3dCmdDXSetStructureCount const *pCmd)
    2987 {
    2988 ASMBreakpoint();
    2989     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    2990     if (pSvgaR3State->pFuncsDX)
    2991     {
    2992         RT_NOREF(pCmd);
    2993         pSvgaR3State->pFuncsDX->pfnDXSetStructureCount(pThisCC->svga.p3dState);
    2994     }
     3480static int vmsvga3dCmdDXSetStructureCount(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetStructureCount const *pCmd, uint32_t cbCmd)
     3481{
     3482#ifdef VMSVGA3D_DX
     3483ASMBreakpoint();
     3484    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3485    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3486    return vmsvga3dDXSetStructureCount(pThisCC, idDXContext);
     3487#else
     3488    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3489    return VERR_NOT_SUPPORTED;
     3490#endif
    29953491}
    29963492
    29973493
    29983494/* SVGA_3D_CMD_LOGICOPS_BITBLT 1259 */
    2999 static void vmsvga3dCmdLogicOpsBitBlt(PVGASTATECC pThisCC, SVGA3dCmdLogicOpsBitBlt const *pCmd)
    3000 {
    3001 ASMBreakpoint();
    3002     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    3003     if (pSvgaR3State->pFuncsDX)
    3004     {
    3005         RT_NOREF(pCmd);
    3006         pSvgaR3State->pFuncsDX->pfnLogicOpsBitBlt(pThisCC->svga.p3dState);
    3007     }
     3495static int vmsvga3dCmdLogicOpsBitBlt(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdLogicOpsBitBlt const *pCmd, uint32_t cbCmd)
     3496{
     3497#ifdef VMSVGA3D_DX
     3498ASMBreakpoint();
     3499    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3500    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3501    return vmsvga3dLogicOpsBitBlt(pThisCC, idDXContext);
     3502#else
     3503    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3504    return VERR_NOT_SUPPORTED;
     3505#endif
    30083506}
    30093507
    30103508
    30113509/* SVGA_3D_CMD_LOGICOPS_TRANSBLT 1260 */
    3012 static void vmsvga3dCmdLogicOpsTransBlt(PVGASTATECC pThisCC, SVGA3dCmdLogicOpsTransBlt const *pCmd)
    3013 {
    3014 ASMBreakpoint();
    3015     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    3016     if (pSvgaR3State->pFuncsDX)
    3017     {
    3018         RT_NOREF(pCmd);
    3019         pSvgaR3State->pFuncsDX->pfnLogicOpsTransBlt(pThisCC->svga.p3dState);
    3020     }
     3510static int vmsvga3dCmdLogicOpsTransBlt(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdLogicOpsTransBlt const *pCmd, uint32_t cbCmd)
     3511{
     3512#ifdef VMSVGA3D_DX
     3513ASMBreakpoint();
     3514    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3515    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3516    return vmsvga3dLogicOpsTransBlt(pThisCC, idDXContext);
     3517#else
     3518    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3519    return VERR_NOT_SUPPORTED;
     3520#endif
    30213521}
    30223522
    30233523
    30243524/* SVGA_3D_CMD_LOGICOPS_STRETCHBLT 1261 */
    3025 static void vmsvga3dCmdLogicOpsStretchBlt(PVGASTATECC pThisCC, SVGA3dCmdLogicOpsStretchBlt const *pCmd)
    3026 {
    3027 ASMBreakpoint();
    3028     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    3029     if (pSvgaR3State->pFuncsDX)
    3030     {
    3031         RT_NOREF(pCmd);
    3032         pSvgaR3State->pFuncsDX->pfnLogicOpsStretchBlt(pThisCC->svga.p3dState);
    3033     }
     3525static int vmsvga3dCmdLogicOpsStretchBlt(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdLogicOpsStretchBlt const *pCmd, uint32_t cbCmd)
     3526{
     3527#ifdef VMSVGA3D_DX
     3528ASMBreakpoint();
     3529    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3530    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3531    return vmsvga3dLogicOpsStretchBlt(pThisCC, idDXContext);
     3532#else
     3533    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3534    return VERR_NOT_SUPPORTED;
     3535#endif
    30343536}
    30353537
    30363538
    30373539/* SVGA_3D_CMD_LOGICOPS_COLORFILL 1262 */
    3038 static void vmsvga3dCmdLogicOpsColorFill(PVGASTATECC pThisCC, SVGA3dCmdLogicOpsColorFill const *pCmd)
    3039 {
    3040 ASMBreakpoint();
    3041     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    3042     if (pSvgaR3State->pFuncsDX)
    3043     {
    3044         RT_NOREF(pCmd);
    3045         pSvgaR3State->pFuncsDX->pfnLogicOpsColorFill(pThisCC->svga.p3dState);
    3046     }
     3540static int vmsvga3dCmdLogicOpsColorFill(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdLogicOpsColorFill const *pCmd, uint32_t cbCmd)
     3541{
     3542#ifdef VMSVGA3D_DX
     3543ASMBreakpoint();
     3544    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3545    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3546    return vmsvga3dLogicOpsColorFill(pThisCC, idDXContext);
     3547#else
     3548    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3549    return VERR_NOT_SUPPORTED;
     3550#endif
    30473551}
    30483552
    30493553
    30503554/* SVGA_3D_CMD_LOGICOPS_ALPHABLEND 1263 */
    3051 static void vmsvga3dCmdLogicOpsAlphaBlend(PVGASTATECC pThisCC, SVGA3dCmdLogicOpsAlphaBlend const *pCmd)
    3052 {
    3053 ASMBreakpoint();
    3054     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    3055     if (pSvgaR3State->pFuncsDX)
    3056     {
    3057         RT_NOREF(pCmd);
    3058         pSvgaR3State->pFuncsDX->pfnLogicOpsAlphaBlend(pThisCC->svga.p3dState);
    3059     }
     3555static int vmsvga3dCmdLogicOpsAlphaBlend(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdLogicOpsAlphaBlend const *pCmd, uint32_t cbCmd)
     3556{
     3557#ifdef VMSVGA3D_DX
     3558ASMBreakpoint();
     3559    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3560    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3561    return vmsvga3dLogicOpsAlphaBlend(pThisCC, idDXContext);
     3562#else
     3563    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3564    return VERR_NOT_SUPPORTED;
     3565#endif
    30603566}
    30613567
    30623568
    30633569/* SVGA_3D_CMD_LOGICOPS_CLEARTYPEBLEND 1264 */
    3064 static void vmsvga3dCmdLogicOpsClearTypeBlend(PVGASTATECC pThisCC, SVGA3dCmdLogicOpsClearTypeBlend const *pCmd)
    3065 {
    3066 ASMBreakpoint();
    3067     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    3068     if (pSvgaR3State->pFuncsDX)
    3069     {
    3070         RT_NOREF(pCmd);
    3071         pSvgaR3State->pFuncsDX->pfnLogicOpsClearTypeBlend(pThisCC->svga.p3dState);
    3072     }
     3570static int vmsvga3dCmdLogicOpsClearTypeBlend(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdLogicOpsClearTypeBlend const *pCmd, uint32_t cbCmd)
     3571{
     3572#ifdef VMSVGA3D_DX
     3573ASMBreakpoint();
     3574    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3575    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3576    return vmsvga3dLogicOpsClearTypeBlend(pThisCC, idDXContext);
     3577#else
     3578    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3579    return VERR_NOT_SUPPORTED;
     3580#endif
    30733581}
    30743582
    30753583
    30763584/* SVGA_3D_CMD_DEFINE_GB_SURFACE_V4 1267 */
    3077 static void vmsvga3dCmdDefineGBSurface_v4(PVGASTATECC pThisCC, SVGA3dCmdDefineGBSurface_v4 const *pCmd)
    3078 {
    3079 ASMBreakpoint();
    3080     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    3081     if (pSvgaR3State->pFuncsDX)
    3082     {
    3083         RT_NOREF(pCmd);
    3084         pSvgaR3State->pFuncsDX->pfnDefineGBSurface_v4(pThisCC->svga.p3dState);
    3085     }
     3585static int vmsvga3dCmdDefineGBSurface_v4(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDefineGBSurface_v4 const *pCmd, uint32_t cbCmd)
     3586{
     3587#ifdef VMSVGA3D_DX
     3588ASMBreakpoint();
     3589    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3590    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3591    return vmsvga3dDefineGBSurface_v4(pThisCC, idDXContext);
     3592#else
     3593    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3594    return VERR_NOT_SUPPORTED;
     3595#endif
    30863596}
    30873597
    30883598
    30893599/* SVGA_3D_CMD_DX_SET_CS_UA_VIEWS 1268 */
    3090 static void vmsvga3dCmdDXSetCSUAViews(PVGASTATECC pThisCC, SVGA3dCmdDXSetCSUAViews const *pCmd)
    3091 {
    3092 ASMBreakpoint();
    3093     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    3094     if (pSvgaR3State->pFuncsDX)
    3095     {
    3096         RT_NOREF(pCmd);
    3097         pSvgaR3State->pFuncsDX->pfnDXSetCSUAViews(pThisCC->svga.p3dState);
    3098     }
     3600static int vmsvga3dCmdDXSetCSUAViews(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetCSUAViews const *pCmd, uint32_t cbCmd)
     3601{
     3602#ifdef VMSVGA3D_DX
     3603ASMBreakpoint();
     3604    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3605    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3606    return vmsvga3dDXSetCSUAViews(pThisCC, idDXContext);
     3607#else
     3608    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3609    return VERR_NOT_SUPPORTED;
     3610#endif
    30993611}
    31003612
    31013613
    31023614/* SVGA_3D_CMD_DX_SET_MIN_LOD 1269 */
    3103 static void vmsvga3dCmdDXSetMinLOD(PVGASTATECC pThisCC, SVGA3dCmdDXSetMinLOD const *pCmd)
    3104 {
    3105 ASMBreakpoint();
    3106     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    3107     if (pSvgaR3State->pFuncsDX)
    3108     {
    3109         RT_NOREF(pCmd);
    3110         pSvgaR3State->pFuncsDX->pfnDXSetMinLOD(pThisCC->svga.p3dState);
    3111     }
     3615static int vmsvga3dCmdDXSetMinLOD(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetMinLOD const *pCmd, uint32_t cbCmd)
     3616{
     3617#ifdef VMSVGA3D_DX
     3618ASMBreakpoint();
     3619    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3620    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3621    return vmsvga3dDXSetMinLOD(pThisCC, idDXContext);
     3622#else
     3623    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3624    return VERR_NOT_SUPPORTED;
     3625#endif
    31123626}
    31133627
    31143628
    31153629/* SVGA_3D_CMD_DX_DEFINE_DEPTHSTENCIL_VIEW_V2 1272 */
    3116 static void vmsvga3dCmdDXDefineDepthStencilView_v2(PVGASTATECC pThisCC, SVGA3dCmdDXDefineDepthStencilView_v2 const *pCmd)
    3117 {
    3118 ASMBreakpoint();
    3119     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    3120     if (pSvgaR3State->pFuncsDX)
    3121     {
    3122         RT_NOREF(pCmd);
    3123         pSvgaR3State->pFuncsDX->pfnDXDefineDepthStencilView_v2(pThisCC->svga.p3dState);
    3124     }
     3630static int vmsvga3dCmdDXDefineDepthStencilView_v2(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineDepthStencilView_v2 const *pCmd, uint32_t cbCmd)
     3631{
     3632#ifdef VMSVGA3D_DX
     3633ASMBreakpoint();
     3634    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3635    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3636    return vmsvga3dDXDefineDepthStencilView_v2(pThisCC, idDXContext);
     3637#else
     3638    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3639    return VERR_NOT_SUPPORTED;
     3640#endif
    31253641}
    31263642
    31273643
    31283644/* SVGA_3D_CMD_DX_DEFINE_STREAMOUTPUT_WITH_MOB 1273 */
    3129 static void vmsvga3dCmdDXDefineStreamOutputWithMob(PVGASTATECC pThisCC, SVGA3dCmdDXDefineStreamOutputWithMob const *pCmd)
    3130 {
    3131 ASMBreakpoint();
    3132     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    3133     if (pSvgaR3State->pFuncsDX)
    3134     {
    3135         RT_NOREF(pCmd);
    3136         pSvgaR3State->pFuncsDX->pfnDXDefineStreamOutputWithMob(pThisCC->svga.p3dState);
    3137     }
     3645static int vmsvga3dCmdDXDefineStreamOutputWithMob(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineStreamOutputWithMob const *pCmd, uint32_t cbCmd)
     3646{
     3647#ifdef VMSVGA3D_DX
     3648ASMBreakpoint();
     3649    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3650    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3651    return vmsvga3dDXDefineStreamOutputWithMob(pThisCC, idDXContext);
     3652#else
     3653    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3654    return VERR_NOT_SUPPORTED;
     3655#endif
    31383656}
    31393657
    31403658
    31413659/* SVGA_3D_CMD_DX_SET_SHADER_IFACE 1274 */
    3142 static void vmsvga3dCmdDXSetShaderIface(PVGASTATECC pThisCC, SVGA3dCmdDXSetShaderIface const *pCmd)
    3143 {
    3144 ASMBreakpoint();
    3145     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    3146     if (pSvgaR3State->pFuncsDX)
    3147     {
    3148         RT_NOREF(pCmd);
    3149         pSvgaR3State->pFuncsDX->pfnDXSetShaderIface(pThisCC->svga.p3dState);
    3150     }
     3660static int vmsvga3dCmdDXSetShaderIface(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetShaderIface const *pCmd, uint32_t cbCmd)
     3661{
     3662#ifdef VMSVGA3D_DX
     3663ASMBreakpoint();
     3664    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3665    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3666    return vmsvga3dDXSetShaderIface(pThisCC, idDXContext);
     3667#else
     3668    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3669    return VERR_NOT_SUPPORTED;
     3670#endif
    31513671}
    31523672
    31533673
    31543674/* SVGA_3D_CMD_DX_BIND_STREAMOUTPUT 1275 */
    3155 static void vmsvga3dCmdDXBindStreamOutput(PVGASTATECC pThisCC, SVGA3dCmdDXBindStreamOutput const *pCmd)
    3156 {
    3157 ASMBreakpoint();
    3158     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    3159     if (pSvgaR3State->pFuncsDX)
    3160     {
    3161         RT_NOREF(pCmd);
    3162         pSvgaR3State->pFuncsDX->pfnDXBindStreamOutput(pThisCC->svga.p3dState);
    3163     }
     3675static int vmsvga3dCmdDXBindStreamOutput(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXBindStreamOutput const *pCmd, uint32_t cbCmd)
     3676{
     3677#ifdef VMSVGA3D_DX
     3678ASMBreakpoint();
     3679    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3680    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3681    return vmsvga3dDXBindStreamOutput(pThisCC, idDXContext);
     3682#else
     3683    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3684    return VERR_NOT_SUPPORTED;
     3685#endif
    31643686}
    31653687
    31663688
    31673689/* SVGA_3D_CMD_SURFACE_STRETCHBLT_NON_MS_TO_MS 1276 */
    3168 static void vmsvga3dCmdSurfaceStretchBltNonMSToMS(PVGASTATECC pThisCC, SVGA3dCmdSurfaceStretchBltNonMSToMS const *pCmd)
    3169 {
    3170 ASMBreakpoint();
    3171     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    3172     if (pSvgaR3State->pFuncsDX)
    3173     {
    3174         RT_NOREF(pCmd);
    3175         pSvgaR3State->pFuncsDX->pfnSurfaceStretchBltNonMSToMS(pThisCC->svga.p3dState);
    3176     }
     3690static int vmsvga3dCmdSurfaceStretchBltNonMSToMS(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdSurfaceStretchBltNonMSToMS const *pCmd, uint32_t cbCmd)
     3691{
     3692#ifdef VMSVGA3D_DX
     3693ASMBreakpoint();
     3694    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3695    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3696    return vmsvga3dSurfaceStretchBltNonMSToMS(pThisCC, idDXContext);
     3697#else
     3698    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3699    return VERR_NOT_SUPPORTED;
     3700#endif
    31773701}
    31783702
    31793703
    31803704/* SVGA_3D_CMD_DX_BIND_SHADER_IFACE 1277 */
    3181 static void vmsvga3dCmdDXBindShaderIface(PVGASTATECC pThisCC, SVGA3dCmdDXBindShaderIface const *pCmd)
    3182 {
    3183 ASMBreakpoint();
    3184     PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
    3185     if (pSvgaR3State->pFuncsDX)
    3186     {
    3187         RT_NOREF(pCmd);
    3188         pSvgaR3State->pFuncsDX->pfnDXBindShaderIface(pThisCC->svga.p3dState);
    3189     }
     3705static int vmsvga3dCmdDXBindShaderIface(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXBindShaderIface const *pCmd, uint32_t cbCmd)
     3706{
     3707#ifdef VMSVGA3D_DX
     3708ASMBreakpoint();
     3709    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     3710    RT_NOREF(pSvgaR3State, pCmd, cbCmd);
     3711    return vmsvga3dDXBindShaderIface(pThisCC, idDXContext);
     3712#else
     3713    RT_NOREF(pThisCC, idDXContext, pCmd, cbCmd);
     3714    return VERR_NOT_SUPPORTED;
     3715#endif
    31903716}
    31913717
     
    32113737 * @param   pThis       The shared VGA/VMSVGA state.
    32123738 * @param   pThisCC     The VGA/VMSVGA state for the current context.
     3739 * @param   idDXContext VGPU10 DX context of the commands or SVGA3D_INVALID_ID if they are not for a specific context.
    32133740 * @param   enmCmdId    SVGA_3D_CMD_* command identifier.
    32143741 * @param   cbCmd       Size of the command in bytes.
     
    32163743 * @returns VBox status code if an error was detected parsing a command.
    32173744 */
    3218 int vmsvgaR3Process3dCmd(PVGASTATE pThis, PVGASTATECC pThisCC, SVGAFifo3dCmdId enmCmdId, uint32_t cbCmd, void const *pvCmd)
     3745int vmsvgaR3Process3dCmd(PVGASTATE pThis, PVGASTATECC pThisCC, uint32_t idDXContext, SVGAFifo3dCmdId enmCmdId, uint32_t cbCmd, void const *pvCmd)
    32193746{
    32203747    if (enmCmdId > SVGA_3D_CMD_MAX)
     
    37854312        SVGA3dCmdInvalidateGBImage *pCmd = (SVGA3dCmdInvalidateGBImage *)pvCmd;
    37864313        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    3787         VMSVGA_3D_CMD_NOTIMPL(); RT_NOREF(pCmd);
     4314        vmsvga3dCmdInvalidateGBImage(pThisCC, pCmd);
    37884315        break;
    37894316    }
     
    40124539    case SVGA_3D_CMD_DEFINE_GB_SURFACE_V2:
    40134540    {
    4014         /// @todo SVGA3dCmdDefineGBSurface_v2 is not defined in Mesa 17 header. Mesa 20 has it.
    4015         //SVGA3dCmdDefineGBSurface_v2 *pCmd = (SVGA3dCmdDefineGBSurface_v2 *)pvCmd;
    4016         //VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4017         VMSVGA_3D_CMD_NOTIMPL();
     4541        SVGA3dCmdDefineGBSurface_v2 *pCmd = (SVGA3dCmdDefineGBSurface_v2 *)pvCmd;
     4542        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
     4543        vmsvga3dCmdDefineGBSurface_v2(pThisCC, pCmd);
    40184544        break;
    40194545    }
     
    40834609        SVGA3dCmdDXDefineContext *pCmd = (SVGA3dCmdDXDefineContext *)pvCmd;
    40844610        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4085         vmsvga3dCmdDXDefineContext(pThisCC, pCmd);
     4611        rcParse = vmsvga3dCmdDXDefineContext(pThisCC, pCmd, cbCmd);
    40864612        break;
    40874613    }
     
    40914617        SVGA3dCmdDXDestroyContext *pCmd = (SVGA3dCmdDXDestroyContext *)pvCmd;
    40924618        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4093         vmsvga3dCmdDXDestroyContext(pThisCC, pCmd);
     4619        rcParse = vmsvga3dCmdDXDestroyContext(pThisCC, pCmd, cbCmd);
    40944620        break;
    40954621    }
     
    40994625        SVGA3dCmdDXBindContext *pCmd = (SVGA3dCmdDXBindContext *)pvCmd;
    41004626        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4101         vmsvga3dCmdDXBindContext(pThisCC, pCmd);
     4627        rcParse = vmsvga3dCmdDXBindContext(pThisCC, pCmd, cbCmd);
    41024628        break;
    41034629    }
     
    41074633        SVGA3dCmdDXReadbackContext *pCmd = (SVGA3dCmdDXReadbackContext *)pvCmd;
    41084634        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4109         vmsvga3dCmdDXReadbackContext(pThisCC, pCmd);
     4635        rcParse = vmsvga3dCmdDXReadbackContext(pThisCC, idDXContext, pCmd, cbCmd);
    41104636        break;
    41114637    }
     
    41154641        SVGA3dCmdDXInvalidateContext *pCmd = (SVGA3dCmdDXInvalidateContext *)pvCmd;
    41164642        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4117         vmsvga3dCmdDXInvalidateContext(pThisCC, pCmd);
     4643        rcParse = vmsvga3dCmdDXInvalidateContext(pThisCC, idDXContext, pCmd, cbCmd);
    41184644        break;
    41194645    }
     
    41234649        SVGA3dCmdDXSetSingleConstantBuffer *pCmd = (SVGA3dCmdDXSetSingleConstantBuffer *)pvCmd;
    41244650        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4125         vmsvga3dCmdDXSetSingleConstantBuffer(pThisCC, pCmd);
     4651        rcParse = vmsvga3dCmdDXSetSingleConstantBuffer(pThisCC, idDXContext, pCmd, cbCmd);
    41264652        break;
    41274653    }
     
    41314657        SVGA3dCmdDXSetShaderResources *pCmd = (SVGA3dCmdDXSetShaderResources *)pvCmd;
    41324658        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4133         vmsvga3dCmdDXSetShaderResources(pThisCC, pCmd);
     4659        rcParse = vmsvga3dCmdDXSetShaderResources(pThisCC, idDXContext, pCmd, cbCmd);
    41344660        break;
    41354661    }
     
    41394665        SVGA3dCmdDXSetShader *pCmd = (SVGA3dCmdDXSetShader *)pvCmd;
    41404666        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4141         vmsvga3dCmdDXSetShader(pThisCC, pCmd);
     4667        rcParse = vmsvga3dCmdDXSetShader(pThisCC, idDXContext, pCmd, cbCmd);
    41424668        break;
    41434669    }
     
    41474673        SVGA3dCmdDXSetSamplers *pCmd = (SVGA3dCmdDXSetSamplers *)pvCmd;
    41484674        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4149         vmsvga3dCmdDXSetSamplers(pThisCC, pCmd);
     4675        rcParse = vmsvga3dCmdDXSetSamplers(pThisCC, idDXContext, pCmd, cbCmd);
    41504676        break;
    41514677    }
     
    41554681        SVGA3dCmdDXDraw *pCmd = (SVGA3dCmdDXDraw *)pvCmd;
    41564682        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4157         vmsvga3dCmdDXDraw(pThisCC, pCmd);
     4683        rcParse = vmsvga3dCmdDXDraw(pThisCC, idDXContext, pCmd, cbCmd);
    41584684        break;
    41594685    }
     
    41634689        SVGA3dCmdDXDrawIndexed *pCmd = (SVGA3dCmdDXDrawIndexed *)pvCmd;
    41644690        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4165         vmsvga3dCmdDXDrawIndexed(pThisCC, pCmd);
     4691        rcParse = vmsvga3dCmdDXDrawIndexed(pThisCC, idDXContext, pCmd, cbCmd);
    41664692        break;
    41674693    }
     
    41714697        SVGA3dCmdDXDrawInstanced *pCmd = (SVGA3dCmdDXDrawInstanced *)pvCmd;
    41724698        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4173         vmsvga3dCmdDXDrawInstanced(pThisCC, pCmd);
     4699        rcParse = vmsvga3dCmdDXDrawInstanced(pThisCC, idDXContext, pCmd, cbCmd);
    41744700        break;
    41754701    }
     
    41794705        SVGA3dCmdDXDrawIndexedInstanced *pCmd = (SVGA3dCmdDXDrawIndexedInstanced *)pvCmd;
    41804706        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4181         vmsvga3dCmdDXDrawIndexedInstanced(pThisCC, pCmd);
     4707        rcParse = vmsvga3dCmdDXDrawIndexedInstanced(pThisCC, idDXContext, pCmd, cbCmd);
    41824708        break;
    41834709    }
     
    41874713        SVGA3dCmdDXDrawAuto *pCmd = (SVGA3dCmdDXDrawAuto *)pvCmd;
    41884714        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4189         vmsvga3dCmdDXDrawAuto(pThisCC, pCmd);
     4715        rcParse = vmsvga3dCmdDXDrawAuto(pThisCC, idDXContext, pCmd, cbCmd);
    41904716        break;
    41914717    }
     
    41954721        SVGA3dCmdDXSetInputLayout *pCmd = (SVGA3dCmdDXSetInputLayout *)pvCmd;
    41964722        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4197         vmsvga3dCmdDXSetInputLayout(pThisCC, pCmd);
     4723        rcParse = vmsvga3dCmdDXSetInputLayout(pThisCC, idDXContext, pCmd, cbCmd);
    41984724        break;
    41994725    }
     
    42034729        SVGA3dCmdDXSetVertexBuffers *pCmd = (SVGA3dCmdDXSetVertexBuffers *)pvCmd;
    42044730        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4205         vmsvga3dCmdDXSetVertexBuffers(pThisCC, pCmd);
     4731        rcParse = vmsvga3dCmdDXSetVertexBuffers(pThisCC, idDXContext, pCmd, cbCmd);
    42064732        break;
    42074733    }
     
    42114737        SVGA3dCmdDXSetIndexBuffer *pCmd = (SVGA3dCmdDXSetIndexBuffer *)pvCmd;
    42124738        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4213         vmsvga3dCmdDXSetIndexBuffer(pThisCC, pCmd);
     4739        rcParse = vmsvga3dCmdDXSetIndexBuffer(pThisCC, idDXContext, pCmd, cbCmd);
    42144740        break;
    42154741    }
     
    42194745        SVGA3dCmdDXSetTopology *pCmd = (SVGA3dCmdDXSetTopology *)pvCmd;
    42204746        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4221         vmsvga3dCmdDXSetTopology(pThisCC, pCmd);
     4747        rcParse = vmsvga3dCmdDXSetTopology(pThisCC, idDXContext, pCmd, cbCmd);
    42224748        break;
    42234749    }
     
    42274753        SVGA3dCmdDXSetRenderTargets *pCmd = (SVGA3dCmdDXSetRenderTargets *)pvCmd;
    42284754        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4229         vmsvga3dCmdDXSetRenderTargets(pThisCC, pCmd);
     4755        rcParse = vmsvga3dCmdDXSetRenderTargets(pThisCC, idDXContext, pCmd, cbCmd);
    42304756        break;
    42314757    }
     
    42354761        SVGA3dCmdDXSetBlendState *pCmd = (SVGA3dCmdDXSetBlendState *)pvCmd;
    42364762        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4237         vmsvga3dCmdDXSetBlendState(pThisCC, pCmd);
     4763        rcParse = vmsvga3dCmdDXSetBlendState(pThisCC, idDXContext, pCmd, cbCmd);
    42384764        break;
    42394765    }
     
    42434769        SVGA3dCmdDXSetDepthStencilState *pCmd = (SVGA3dCmdDXSetDepthStencilState *)pvCmd;
    42444770        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4245         vmsvga3dCmdDXSetDepthStencilState(pThisCC, pCmd);
     4771        rcParse = vmsvga3dCmdDXSetDepthStencilState(pThisCC, idDXContext, pCmd, cbCmd);
    42464772        break;
    42474773    }
     
    42514777        SVGA3dCmdDXSetRasterizerState *pCmd = (SVGA3dCmdDXSetRasterizerState *)pvCmd;
    42524778        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4253         vmsvga3dCmdDXSetRasterizerState(pThisCC, pCmd);
     4779        rcParse = vmsvga3dCmdDXSetRasterizerState(pThisCC, idDXContext, pCmd, cbCmd);
    42544780        break;
    42554781    }
     
    42594785        SVGA3dCmdDXDefineQuery *pCmd = (SVGA3dCmdDXDefineQuery *)pvCmd;
    42604786        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4261         vmsvga3dCmdDXDefineQuery(pThisCC, pCmd);
     4787        rcParse = vmsvga3dCmdDXDefineQuery(pThisCC, idDXContext, pCmd, cbCmd);
    42624788        break;
    42634789    }
     
    42674793        SVGA3dCmdDXDestroyQuery *pCmd = (SVGA3dCmdDXDestroyQuery *)pvCmd;
    42684794        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4269         vmsvga3dCmdDXDestroyQuery(pThisCC, pCmd);
     4795        rcParse = vmsvga3dCmdDXDestroyQuery(pThisCC, idDXContext, pCmd, cbCmd);
    42704796        break;
    42714797    }
     
    42754801        SVGA3dCmdDXBindQuery *pCmd = (SVGA3dCmdDXBindQuery *)pvCmd;
    42764802        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4277         vmsvga3dCmdDXBindQuery(pThisCC, pCmd);
     4803        rcParse = vmsvga3dCmdDXBindQuery(pThisCC, idDXContext, pCmd, cbCmd);
    42784804        break;
    42794805    }
     
    42834809        SVGA3dCmdDXSetQueryOffset *pCmd = (SVGA3dCmdDXSetQueryOffset *)pvCmd;
    42844810        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4285         vmsvga3dCmdDXSetQueryOffset(pThisCC, pCmd);
     4811        rcParse = vmsvga3dCmdDXSetQueryOffset(pThisCC, idDXContext, pCmd, cbCmd);
    42864812        break;
    42874813    }
     
    42914817        SVGA3dCmdDXBeginQuery *pCmd = (SVGA3dCmdDXBeginQuery *)pvCmd;
    42924818        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4293         vmsvga3dCmdDXBeginQuery(pThisCC, pCmd);
     4819        rcParse = vmsvga3dCmdDXBeginQuery(pThisCC, idDXContext, pCmd, cbCmd);
    42944820        break;
    42954821    }
     
    42994825        SVGA3dCmdDXEndQuery *pCmd = (SVGA3dCmdDXEndQuery *)pvCmd;
    43004826        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4301         vmsvga3dCmdDXEndQuery(pThisCC, pCmd);
     4827        rcParse = vmsvga3dCmdDXEndQuery(pThisCC, idDXContext, pCmd, cbCmd);
    43024828        break;
    43034829    }
     
    43074833        SVGA3dCmdDXReadbackQuery *pCmd = (SVGA3dCmdDXReadbackQuery *)pvCmd;
    43084834        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4309         vmsvga3dCmdDXReadbackQuery(pThisCC, pCmd);
     4835        rcParse = vmsvga3dCmdDXReadbackQuery(pThisCC, idDXContext, pCmd, cbCmd);
    43104836        break;
    43114837    }
     
    43154841        SVGA3dCmdDXSetPredication *pCmd = (SVGA3dCmdDXSetPredication *)pvCmd;
    43164842        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4317         vmsvga3dCmdDXSetPredication(pThisCC, pCmd);
     4843        rcParse = vmsvga3dCmdDXSetPredication(pThisCC, idDXContext, pCmd, cbCmd);
    43184844        break;
    43194845    }
     
    43234849        SVGA3dCmdDXSetSOTargets *pCmd = (SVGA3dCmdDXSetSOTargets *)pvCmd;
    43244850        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4325         vmsvga3dCmdDXSetSOTargets(pThisCC, pCmd);
     4851        rcParse = vmsvga3dCmdDXSetSOTargets(pThisCC, idDXContext, pCmd, cbCmd);
    43264852        break;
    43274853    }
     
    43314857        SVGA3dCmdDXSetViewports *pCmd = (SVGA3dCmdDXSetViewports *)pvCmd;
    43324858        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4333         vmsvga3dCmdDXSetViewports(pThisCC, pCmd);
     4859        rcParse = vmsvga3dCmdDXSetViewports(pThisCC, idDXContext, pCmd, cbCmd);
    43344860        break;
    43354861    }
     
    43394865        SVGA3dCmdDXSetScissorRects *pCmd = (SVGA3dCmdDXSetScissorRects *)pvCmd;
    43404866        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4341         vmsvga3dCmdDXSetScissorRects(pThisCC, pCmd);
     4867        rcParse = vmsvga3dCmdDXSetScissorRects(pThisCC, idDXContext, pCmd, cbCmd);
    43424868        break;
    43434869    }
     
    43474873        SVGA3dCmdDXClearRenderTargetView *pCmd = (SVGA3dCmdDXClearRenderTargetView *)pvCmd;
    43484874        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4349         vmsvga3dCmdDXClearRenderTargetView(pThisCC, pCmd);
     4875        rcParse = vmsvga3dCmdDXClearRenderTargetView(pThisCC, idDXContext, pCmd, cbCmd);
    43504876        break;
    43514877    }
     
    43554881        SVGA3dCmdDXClearDepthStencilView *pCmd = (SVGA3dCmdDXClearDepthStencilView *)pvCmd;
    43564882        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4357         vmsvga3dCmdDXClearDepthStencilView(pThisCC, pCmd);
     4883        rcParse = vmsvga3dCmdDXClearDepthStencilView(pThisCC, idDXContext, pCmd, cbCmd);
    43584884        break;
    43594885    }
     
    43634889        SVGA3dCmdDXPredCopyRegion *pCmd = (SVGA3dCmdDXPredCopyRegion *)pvCmd;
    43644890        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4365         vmsvga3dCmdDXPredCopyRegion(pThisCC, pCmd);
     4891        rcParse = vmsvga3dCmdDXPredCopyRegion(pThisCC, idDXContext, pCmd, cbCmd);
    43664892        break;
    43674893    }
     
    43714897        SVGA3dCmdDXPredCopy *pCmd = (SVGA3dCmdDXPredCopy *)pvCmd;
    43724898        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4373         vmsvga3dCmdDXPredCopy(pThisCC, pCmd);
     4899        rcParse = vmsvga3dCmdDXPredCopy(pThisCC, idDXContext, pCmd, cbCmd);
    43744900        break;
    43754901    }
     
    43794905        SVGA3dCmdDXPresentBlt *pCmd = (SVGA3dCmdDXPresentBlt *)pvCmd;
    43804906        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4381         vmsvga3dCmdDXPresentBlt(pThisCC, pCmd);
     4907        rcParse = vmsvga3dCmdDXPresentBlt(pThisCC, idDXContext, pCmd, cbCmd);
    43824908        break;
    43834909    }
     
    43874913        SVGA3dCmdDXGenMips *pCmd = (SVGA3dCmdDXGenMips *)pvCmd;
    43884914        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4389         vmsvga3dCmdDXGenMips(pThisCC, pCmd);
     4915        rcParse = vmsvga3dCmdDXGenMips(pThisCC, idDXContext, pCmd, cbCmd);
    43904916        break;
    43914917    }
     
    43954921        SVGA3dCmdDXUpdateSubResource *pCmd = (SVGA3dCmdDXUpdateSubResource *)pvCmd;
    43964922        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4397         vmsvga3dCmdDXUpdateSubResource(pThisCC, pCmd);
     4923        rcParse = vmsvga3dCmdDXUpdateSubResource(pThisCC, idDXContext, pCmd, cbCmd);
    43984924        break;
    43994925    }
     
    44034929        SVGA3dCmdDXReadbackSubResource *pCmd = (SVGA3dCmdDXReadbackSubResource *)pvCmd;
    44044930        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4405         vmsvga3dCmdDXReadbackSubResource(pThisCC, pCmd);
     4931        rcParse = vmsvga3dCmdDXReadbackSubResource(pThisCC, idDXContext, pCmd, cbCmd);
    44064932        break;
    44074933    }
     
    44114937        SVGA3dCmdDXInvalidateSubResource *pCmd = (SVGA3dCmdDXInvalidateSubResource *)pvCmd;
    44124938        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4413         vmsvga3dCmdDXInvalidateSubResource(pThisCC, pCmd);
     4939        rcParse = vmsvga3dCmdDXInvalidateSubResource(pThisCC, idDXContext, pCmd, cbCmd);
    44144940        break;
    44154941    }
     
    44194945        SVGA3dCmdDXDefineShaderResourceView *pCmd = (SVGA3dCmdDXDefineShaderResourceView *)pvCmd;
    44204946        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4421         vmsvga3dCmdDXDefineShaderResourceView(pThisCC, pCmd);
     4947        rcParse = vmsvga3dCmdDXDefineShaderResourceView(pThisCC, idDXContext, pCmd, cbCmd);
    44224948        break;
    44234949    }
     
    44274953        SVGA3dCmdDXDestroyShaderResourceView *pCmd = (SVGA3dCmdDXDestroyShaderResourceView *)pvCmd;
    44284954        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4429         vmsvga3dCmdDXDestroyShaderResourceView(pThisCC, pCmd);
     4955        rcParse = vmsvga3dCmdDXDestroyShaderResourceView(pThisCC, idDXContext, pCmd, cbCmd);
    44304956        break;
    44314957    }
     
    44354961        SVGA3dCmdDXDefineRenderTargetView *pCmd = (SVGA3dCmdDXDefineRenderTargetView *)pvCmd;
    44364962        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4437         vmsvga3dCmdDXDefineRenderTargetView(pThisCC, pCmd);
     4963        rcParse = vmsvga3dCmdDXDefineRenderTargetView(pThisCC, idDXContext, pCmd, cbCmd);
    44384964        break;
    44394965    }
     
    44434969        SVGA3dCmdDXDestroyRenderTargetView *pCmd = (SVGA3dCmdDXDestroyRenderTargetView *)pvCmd;
    44444970        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4445         vmsvga3dCmdDXDestroyRenderTargetView(pThisCC, pCmd);
     4971        rcParse = vmsvga3dCmdDXDestroyRenderTargetView(pThisCC, idDXContext, pCmd, cbCmd);
    44464972        break;
    44474973    }
     
    44514977        SVGA3dCmdDXDefineDepthStencilView *pCmd = (SVGA3dCmdDXDefineDepthStencilView *)pvCmd;
    44524978        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4453         vmsvga3dCmdDXDefineDepthStencilView(pThisCC, pCmd);
     4979        rcParse = vmsvga3dCmdDXDefineDepthStencilView(pThisCC, idDXContext, pCmd, cbCmd);
    44544980        break;
    44554981    }
     
    44594985        SVGA3dCmdDXDestroyDepthStencilView *pCmd = (SVGA3dCmdDXDestroyDepthStencilView *)pvCmd;
    44604986        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4461         vmsvga3dCmdDXDestroyDepthStencilView(pThisCC, pCmd);
     4987        rcParse = vmsvga3dCmdDXDestroyDepthStencilView(pThisCC, idDXContext, pCmd, cbCmd);
    44624988        break;
    44634989    }
     
    44674993        SVGA3dCmdDXDefineElementLayout *pCmd = (SVGA3dCmdDXDefineElementLayout *)pvCmd;
    44684994        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4469         vmsvga3dCmdDXDefineElementLayout(pThisCC, pCmd);
     4995        rcParse = vmsvga3dCmdDXDefineElementLayout(pThisCC, idDXContext, pCmd, cbCmd);
    44704996        break;
    44714997    }
     
    44755001        SVGA3dCmdDXDestroyElementLayout *pCmd = (SVGA3dCmdDXDestroyElementLayout *)pvCmd;
    44765002        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4477         vmsvga3dCmdDXDestroyElementLayout(pThisCC, pCmd);
     5003        rcParse = vmsvga3dCmdDXDestroyElementLayout(pThisCC, idDXContext, pCmd, cbCmd);
    44785004        break;
    44795005    }
     
    44835009        SVGA3dCmdDXDefineBlendState *pCmd = (SVGA3dCmdDXDefineBlendState *)pvCmd;
    44845010        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4485         vmsvga3dCmdDXDefineBlendState(pThisCC, pCmd);
     5011        rcParse = vmsvga3dCmdDXDefineBlendState(pThisCC, idDXContext, pCmd, cbCmd);
    44865012        break;
    44875013    }
     
    44915017        SVGA3dCmdDXDestroyBlendState *pCmd = (SVGA3dCmdDXDestroyBlendState *)pvCmd;
    44925018        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4493         vmsvga3dCmdDXDestroyBlendState(pThisCC, pCmd);
     5019        rcParse = vmsvga3dCmdDXDestroyBlendState(pThisCC, idDXContext, pCmd, cbCmd);
    44945020        break;
    44955021    }
     
    44995025        SVGA3dCmdDXDefineDepthStencilState *pCmd = (SVGA3dCmdDXDefineDepthStencilState *)pvCmd;
    45005026        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4501         vmsvga3dCmdDXDefineDepthStencilState(pThisCC, pCmd);
     5027        rcParse = vmsvga3dCmdDXDefineDepthStencilState(pThisCC, idDXContext, pCmd, cbCmd);
    45025028        break;
    45035029    }
     
    45075033        SVGA3dCmdDXDestroyDepthStencilState *pCmd = (SVGA3dCmdDXDestroyDepthStencilState *)pvCmd;
    45085034        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4509         vmsvga3dCmdDXDestroyDepthStencilState(pThisCC, pCmd);
     5035        rcParse = vmsvga3dCmdDXDestroyDepthStencilState(pThisCC, idDXContext, pCmd, cbCmd);
    45105036        break;
    45115037    }
     
    45155041        SVGA3dCmdDXDefineRasterizerState *pCmd = (SVGA3dCmdDXDefineRasterizerState *)pvCmd;
    45165042        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4517         vmsvga3dCmdDXDefineRasterizerState(pThisCC, pCmd);
     5043        rcParse = vmsvga3dCmdDXDefineRasterizerState(pThisCC, idDXContext, pCmd, cbCmd);
    45185044        break;
    45195045    }
     
    45235049        SVGA3dCmdDXDestroyRasterizerState *pCmd = (SVGA3dCmdDXDestroyRasterizerState *)pvCmd;
    45245050        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4525         vmsvga3dCmdDXDestroyRasterizerState(pThisCC, pCmd);
     5051        rcParse = vmsvga3dCmdDXDestroyRasterizerState(pThisCC, idDXContext, pCmd, cbCmd);
    45265052        break;
    45275053    }
     
    45315057        SVGA3dCmdDXDefineSamplerState *pCmd = (SVGA3dCmdDXDefineSamplerState *)pvCmd;
    45325058        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4533         vmsvga3dCmdDXDefineSamplerState(pThisCC, pCmd);
     5059        rcParse = vmsvga3dCmdDXDefineSamplerState(pThisCC, idDXContext, pCmd, cbCmd);
    45345060        break;
    45355061    }
     
    45395065        SVGA3dCmdDXDestroySamplerState *pCmd = (SVGA3dCmdDXDestroySamplerState *)pvCmd;
    45405066        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4541         vmsvga3dCmdDXDestroySamplerState(pThisCC, pCmd);
     5067        rcParse = vmsvga3dCmdDXDestroySamplerState(pThisCC, idDXContext, pCmd, cbCmd);
    45425068        break;
    45435069    }
     
    45475073        SVGA3dCmdDXDefineShader *pCmd = (SVGA3dCmdDXDefineShader *)pvCmd;
    45485074        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4549         vmsvga3dCmdDXDefineShader(pThisCC, pCmd);
     5075        rcParse = vmsvga3dCmdDXDefineShader(pThisCC, idDXContext, pCmd, cbCmd);
    45505076        break;
    45515077    }
     
    45555081        SVGA3dCmdDXDestroyShader *pCmd = (SVGA3dCmdDXDestroyShader *)pvCmd;
    45565082        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4557         vmsvga3dCmdDXDestroyShader(pThisCC, pCmd);
     5083        rcParse = vmsvga3dCmdDXDestroyShader(pThisCC, idDXContext, pCmd, cbCmd);
    45585084        break;
    45595085    }
     
    45635089        SVGA3dCmdDXBindShader *pCmd = (SVGA3dCmdDXBindShader *)pvCmd;
    45645090        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4565         vmsvga3dCmdDXBindShader(pThisCC, pCmd);
     5091        rcParse = vmsvga3dCmdDXBindShader(pThisCC, idDXContext, pCmd, cbCmd);
    45665092        break;
    45675093    }
     
    45715097        SVGA3dCmdDXDefineStreamOutput *pCmd = (SVGA3dCmdDXDefineStreamOutput *)pvCmd;
    45725098        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4573         vmsvga3dCmdDXDefineStreamOutput(pThisCC, pCmd);
     5099        rcParse = vmsvga3dCmdDXDefineStreamOutput(pThisCC, idDXContext, pCmd, cbCmd);
    45745100        break;
    45755101    }
     
    45795105        SVGA3dCmdDXDestroyStreamOutput *pCmd = (SVGA3dCmdDXDestroyStreamOutput *)pvCmd;
    45805106        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4581         vmsvga3dCmdDXDestroyStreamOutput(pThisCC, pCmd);
     5107        rcParse = vmsvga3dCmdDXDestroyStreamOutput(pThisCC, idDXContext, pCmd, cbCmd);
    45825108        break;
    45835109    }
     
    45875113        SVGA3dCmdDXSetStreamOutput *pCmd = (SVGA3dCmdDXSetStreamOutput *)pvCmd;
    45885114        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4589         vmsvga3dCmdDXSetStreamOutput(pThisCC, pCmd);
     5115        rcParse = vmsvga3dCmdDXSetStreamOutput(pThisCC, idDXContext, pCmd, cbCmd);
    45905116        break;
    45915117    }
     
    45955121        SVGA3dCmdDXSetCOTable *pCmd = (SVGA3dCmdDXSetCOTable *)pvCmd;
    45965122        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4597         vmsvga3dCmdDXSetCOTable(pThisCC, pCmd);
     5123        rcParse = vmsvga3dCmdDXSetCOTable(pThisCC, pCmd, cbCmd);
    45985124        break;
    45995125    }
     
    46035129        SVGA3dCmdDXReadbackCOTable *pCmd = (SVGA3dCmdDXReadbackCOTable *)pvCmd;
    46045130        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4605         vmsvga3dCmdDXReadbackCOTable(pThisCC, pCmd);
     5131        rcParse = vmsvga3dCmdDXReadbackCOTable(pThisCC, idDXContext, pCmd, cbCmd);
    46065132        break;
    46075133    }
     
    46115137        SVGA3dCmdDXBufferCopy *pCmd = (SVGA3dCmdDXBufferCopy *)pvCmd;
    46125138        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4613         vmsvga3dCmdDXBufferCopy(pThisCC, pCmd);
     5139        rcParse = vmsvga3dCmdDXBufferCopy(pThisCC, idDXContext, pCmd, cbCmd);
    46145140        break;
    46155141    }
     
    46195145        SVGA3dCmdDXTransferFromBuffer *pCmd = (SVGA3dCmdDXTransferFromBuffer *)pvCmd;
    46205146        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4621         vmsvga3dCmdDXTransferFromBuffer(pThisCC, pCmd);
     5147        rcParse = vmsvga3dCmdDXTransferFromBuffer(pThisCC, idDXContext, pCmd, cbCmd);
    46225148        break;
    46235149    }
     
    46275153        SVGA3dCmdDXSurfaceCopyAndReadback *pCmd = (SVGA3dCmdDXSurfaceCopyAndReadback *)pvCmd;
    46285154        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4629         vmsvga3dCmdDXSurfaceCopyAndReadback(pThisCC, pCmd);
     5155        rcParse = vmsvga3dCmdDXSurfaceCopyAndReadback(pThisCC, idDXContext, pCmd, cbCmd);
    46305156        break;
    46315157    }
     
    46355161        SVGA3dCmdDXMoveQuery *pCmd = (SVGA3dCmdDXMoveQuery *)pvCmd;
    46365162        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4637         vmsvga3dCmdDXMoveQuery(pThisCC, pCmd);
     5163        rcParse = vmsvga3dCmdDXMoveQuery(pThisCC, idDXContext, pCmd, cbCmd);
    46385164        break;
    46395165    }
     
    46435169        SVGA3dCmdDXBindAllQuery *pCmd = (SVGA3dCmdDXBindAllQuery *)pvCmd;
    46445170        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4645         vmsvga3dCmdDXBindAllQuery(pThisCC, pCmd);
     5171        rcParse = vmsvga3dCmdDXBindAllQuery(pThisCC, idDXContext, pCmd, cbCmd);
    46465172        break;
    46475173    }
     
    46515177        SVGA3dCmdDXReadbackAllQuery *pCmd = (SVGA3dCmdDXReadbackAllQuery *)pvCmd;
    46525178        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4653         vmsvga3dCmdDXReadbackAllQuery(pThisCC, pCmd);
     5179        rcParse = vmsvga3dCmdDXReadbackAllQuery(pThisCC, idDXContext, pCmd, cbCmd);
    46545180        break;
    46555181    }
     
    46595185        SVGA3dCmdDXPredTransferFromBuffer *pCmd = (SVGA3dCmdDXPredTransferFromBuffer *)pvCmd;
    46605186        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4661         vmsvga3dCmdDXPredTransferFromBuffer(pThisCC, pCmd);
     5187        rcParse = vmsvga3dCmdDXPredTransferFromBuffer(pThisCC, idDXContext, pCmd, cbCmd);
    46625188        break;
    46635189    }
     
    46675193        SVGA3dCmdDXMobFence64 *pCmd = (SVGA3dCmdDXMobFence64 *)pvCmd;
    46685194        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4669         vmsvga3dCmdDXMobFence64(pThisCC, pCmd);
     5195        rcParse = vmsvga3dCmdDXMobFence64(pThisCC, idDXContext, pCmd, cbCmd);
    46705196        break;
    46715197    }
     
    46755201        SVGA3dCmdDXBindAllShader *pCmd = (SVGA3dCmdDXBindAllShader *)pvCmd;
    46765202        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4677         vmsvga3dCmdDXBindAllShader(pThisCC, pCmd);
     5203        rcParse = vmsvga3dCmdDXBindAllShader(pThisCC, idDXContext, pCmd, cbCmd);
    46785204        break;
    46795205    }
     
    46835209        SVGA3dCmdDXHint *pCmd = (SVGA3dCmdDXHint *)pvCmd;
    46845210        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4685         vmsvga3dCmdDXHint(pThisCC, pCmd);
     5211        rcParse = vmsvga3dCmdDXHint(pThisCC, idDXContext, pCmd, cbCmd);
    46865212        break;
    46875213    }
     
    46915217        SVGA3dCmdDXBufferUpdate *pCmd = (SVGA3dCmdDXBufferUpdate *)pvCmd;
    46925218        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4693         vmsvga3dCmdDXBufferUpdate(pThisCC, pCmd);
     5219        rcParse = vmsvga3dCmdDXBufferUpdate(pThisCC, idDXContext, pCmd, cbCmd);
    46945220        break;
    46955221    }
     
    46995225        SVGA3dCmdDXSetVSConstantBufferOffset *pCmd = (SVGA3dCmdDXSetVSConstantBufferOffset *)pvCmd;
    47005226        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4701         vmsvga3dCmdDXSetVSConstantBufferOffset(pThisCC, pCmd);
     5227        rcParse = vmsvga3dCmdDXSetVSConstantBufferOffset(pThisCC, idDXContext, pCmd, cbCmd);
    47025228        break;
    47035229    }
     
    47075233        SVGA3dCmdDXSetPSConstantBufferOffset *pCmd = (SVGA3dCmdDXSetPSConstantBufferOffset *)pvCmd;
    47085234        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4709         vmsvga3dCmdDXSetPSConstantBufferOffset(pThisCC, pCmd);
     5235        rcParse = vmsvga3dCmdDXSetPSConstantBufferOffset(pThisCC, idDXContext, pCmd, cbCmd);
    47105236        break;
    47115237    }
     
    47155241        SVGA3dCmdDXSetGSConstantBufferOffset *pCmd = (SVGA3dCmdDXSetGSConstantBufferOffset *)pvCmd;
    47165242        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4717         vmsvga3dCmdDXSetGSConstantBufferOffset(pThisCC, pCmd);
     5243        rcParse = vmsvga3dCmdDXSetGSConstantBufferOffset(pThisCC, idDXContext, pCmd, cbCmd);
    47185244        break;
    47195245    }
     
    47235249        SVGA3dCmdDXSetHSConstantBufferOffset *pCmd = (SVGA3dCmdDXSetHSConstantBufferOffset *)pvCmd;
    47245250        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4725         vmsvga3dCmdDXSetHSConstantBufferOffset(pThisCC, pCmd);
     5251        rcParse = vmsvga3dCmdDXSetHSConstantBufferOffset(pThisCC, idDXContext, pCmd, cbCmd);
    47265252        break;
    47275253    }
     
    47315257        SVGA3dCmdDXSetDSConstantBufferOffset *pCmd = (SVGA3dCmdDXSetDSConstantBufferOffset *)pvCmd;
    47325258        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4733         vmsvga3dCmdDXSetDSConstantBufferOffset(pThisCC, pCmd);
     5259        rcParse = vmsvga3dCmdDXSetDSConstantBufferOffset(pThisCC, idDXContext, pCmd, cbCmd);
    47345260        break;
    47355261    }
     
    47395265        SVGA3dCmdDXSetCSConstantBufferOffset *pCmd = (SVGA3dCmdDXSetCSConstantBufferOffset *)pvCmd;
    47405266        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4741         vmsvga3dCmdDXSetCSConstantBufferOffset(pThisCC, pCmd);
     5267        rcParse = vmsvga3dCmdDXSetCSConstantBufferOffset(pThisCC, idDXContext, pCmd, cbCmd);
    47425268        break;
    47435269    }
     
    47475273        SVGA3dCmdDXCondBindAllShader *pCmd = (SVGA3dCmdDXCondBindAllShader *)pvCmd;
    47485274        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4749         vmsvga3dCmdDXCondBindAllShader(pThisCC, pCmd);
     5275        rcParse = vmsvga3dCmdDXCondBindAllShader(pThisCC, idDXContext, pCmd, cbCmd);
    47505276        break;
    47515277    }
     
    47555281        SVGA3dCmdScreenCopy *pCmd = (SVGA3dCmdScreenCopy *)pvCmd;
    47565282        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4757         vmsvga3dCmdScreenCopy(pThisCC, pCmd);
     5283        rcParse = vmsvga3dCmdScreenCopy(pThisCC, idDXContext, pCmd, cbCmd);
    47585284        break;
    47595285    }
     
    48115337        SVGA3dCmdGrowOTable *pCmd = (SVGA3dCmdGrowOTable *)pvCmd;
    48125338        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4813         vmsvga3dCmdGrowOTable(pThisCC, pCmd);
     5339        rcParse = vmsvga3dCmdGrowOTable(pThisCC, idDXContext, pCmd, cbCmd);
    48145340        break;
    48155341    }
     
    48195345        SVGA3dCmdDXGrowCOTable *pCmd = (SVGA3dCmdDXGrowCOTable *)pvCmd;
    48205346        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4821         vmsvga3dCmdDXGrowCOTable(pThisCC, pCmd);
     5347        rcParse = vmsvga3dCmdDXGrowCOTable(pThisCC, idDXContext, pCmd, cbCmd);
    48225348        break;
    48235349    }
     
    48275353        SVGA3dCmdIntraSurfaceCopy *pCmd = (SVGA3dCmdIntraSurfaceCopy *)pvCmd;
    48285354        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4829         vmsvga3dCmdIntraSurfaceCopy(pThisCC, pCmd);
     5355        rcParse = vmsvga3dCmdIntraSurfaceCopy(pThisCC, idDXContext, pCmd, cbCmd);
    48305356        break;
    48315357    }
     
    48355361        SVGA3dCmdDefineGBSurface_v3 *pCmd = (SVGA3dCmdDefineGBSurface_v3 *)pvCmd;
    48365362        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4837         vmsvga3dCmdDefineGBSurface_v3(pThisCC, pCmd);
     5363        rcParse = vmsvga3dCmdDefineGBSurface_v3(pThisCC, idDXContext, pCmd, cbCmd);
    48385364        break;
    48395365    }
     
    48435369        SVGA3dCmdDXResolveCopy *pCmd = (SVGA3dCmdDXResolveCopy *)pvCmd;
    48445370        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4845         vmsvga3dCmdDXResolveCopy(pThisCC, pCmd);
     5371        rcParse = vmsvga3dCmdDXResolveCopy(pThisCC, idDXContext, pCmd, cbCmd);
    48465372        break;
    48475373    }
     
    48515377        SVGA3dCmdDXPredResolveCopy *pCmd = (SVGA3dCmdDXPredResolveCopy *)pvCmd;
    48525378        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4853         vmsvga3dCmdDXPredResolveCopy(pThisCC, pCmd);
     5379        rcParse = vmsvga3dCmdDXPredResolveCopy(pThisCC, idDXContext, pCmd, cbCmd);
    48545380        break;
    48555381    }
     
    48595385        SVGA3dCmdDXPredConvertRegion *pCmd = (SVGA3dCmdDXPredConvertRegion *)pvCmd;
    48605386        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4861         vmsvga3dCmdDXPredConvertRegion(pThisCC, pCmd);
     5387        rcParse = vmsvga3dCmdDXPredConvertRegion(pThisCC, idDXContext, pCmd, cbCmd);
    48625388        break;
    48635389    }
     
    48675393        SVGA3dCmdDXPredConvert *pCmd = (SVGA3dCmdDXPredConvert *)pvCmd;
    48685394        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4869         vmsvga3dCmdDXPredConvert(pThisCC, pCmd);
     5395        rcParse = vmsvga3dCmdDXPredConvert(pThisCC, idDXContext, pCmd, cbCmd);
    48705396        break;
    48715397    }
     
    48755401        SVGA3dCmdWholeSurfaceCopy *pCmd = (SVGA3dCmdWholeSurfaceCopy *)pvCmd;
    48765402        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4877         vmsvga3dCmdWholeSurfaceCopy(pThisCC, pCmd);
     5403        rcParse = vmsvga3dCmdWholeSurfaceCopy(pThisCC, idDXContext, pCmd, cbCmd);
    48785404        break;
    48795405    }
     
    48835409        SVGA3dCmdDXDefineUAView *pCmd = (SVGA3dCmdDXDefineUAView *)pvCmd;
    48845410        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4885         vmsvga3dCmdDXDefineUAView(pThisCC, pCmd);
     5411        rcParse = vmsvga3dCmdDXDefineUAView(pThisCC, idDXContext, pCmd, cbCmd);
    48865412        break;
    48875413    }
     
    48915417        SVGA3dCmdDXDestroyUAView *pCmd = (SVGA3dCmdDXDestroyUAView *)pvCmd;
    48925418        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4893         vmsvga3dCmdDXDestroyUAView(pThisCC, pCmd);
     5419        rcParse = vmsvga3dCmdDXDestroyUAView(pThisCC, idDXContext, pCmd, cbCmd);
    48945420        break;
    48955421    }
     
    48995425        SVGA3dCmdDXClearUAViewUint *pCmd = (SVGA3dCmdDXClearUAViewUint *)pvCmd;
    49005426        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4901         vmsvga3dCmdDXClearUAViewUint(pThisCC, pCmd);
     5427        rcParse = vmsvga3dCmdDXClearUAViewUint(pThisCC, idDXContext, pCmd, cbCmd);
    49025428        break;
    49035429    }
     
    49075433        SVGA3dCmdDXClearUAViewFloat *pCmd = (SVGA3dCmdDXClearUAViewFloat *)pvCmd;
    49085434        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4909         vmsvga3dCmdDXClearUAViewFloat(pThisCC, pCmd);
     5435        rcParse = vmsvga3dCmdDXClearUAViewFloat(pThisCC, idDXContext, pCmd, cbCmd);
    49105436        break;
    49115437    }
     
    49155441        SVGA3dCmdDXCopyStructureCount *pCmd = (SVGA3dCmdDXCopyStructureCount *)pvCmd;
    49165442        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4917         vmsvga3dCmdDXCopyStructureCount(pThisCC, pCmd);
     5443        rcParse = vmsvga3dCmdDXCopyStructureCount(pThisCC, idDXContext, pCmd, cbCmd);
    49185444        break;
    49195445    }
     
    49235449        SVGA3dCmdDXSetUAViews *pCmd = (SVGA3dCmdDXSetUAViews *)pvCmd;
    49245450        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4925         vmsvga3dCmdDXSetUAViews(pThisCC, pCmd);
     5451        rcParse = vmsvga3dCmdDXSetUAViews(pThisCC, idDXContext, pCmd, cbCmd);
    49265452        break;
    49275453    }
     
    49315457        SVGA3dCmdDXDrawIndexedInstancedIndirect *pCmd = (SVGA3dCmdDXDrawIndexedInstancedIndirect *)pvCmd;
    49325458        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4933         vmsvga3dCmdDXDrawIndexedInstancedIndirect(pThisCC, pCmd);
     5459        rcParse = vmsvga3dCmdDXDrawIndexedInstancedIndirect(pThisCC, idDXContext, pCmd, cbCmd);
    49345460        break;
    49355461    }
     
    49395465        SVGA3dCmdDXDrawInstancedIndirect *pCmd = (SVGA3dCmdDXDrawInstancedIndirect *)pvCmd;
    49405466        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4941         vmsvga3dCmdDXDrawInstancedIndirect(pThisCC, pCmd);
     5467        rcParse = vmsvga3dCmdDXDrawInstancedIndirect(pThisCC, idDXContext, pCmd, cbCmd);
    49425468        break;
    49435469    }
     
    49475473        SVGA3dCmdDXDispatch *pCmd = (SVGA3dCmdDXDispatch *)pvCmd;
    49485474        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4949         vmsvga3dCmdDXDispatch(pThisCC, pCmd);
     5475        rcParse = vmsvga3dCmdDXDispatch(pThisCC, idDXContext, pCmd, cbCmd);
    49505476        break;
    49515477    }
     
    49555481        SVGA3dCmdDXDispatchIndirect *pCmd = (SVGA3dCmdDXDispatchIndirect *)pvCmd;
    49565482        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4957         vmsvga3dCmdDXDispatchIndirect(pThisCC, pCmd);
     5483        rcParse = vmsvga3dCmdDXDispatchIndirect(pThisCC, idDXContext, pCmd, cbCmd);
    49585484        break;
    49595485    }
     
    49635489        SVGA3dCmdWriteZeroSurface *pCmd = (SVGA3dCmdWriteZeroSurface *)pvCmd;
    49645490        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4965         vmsvga3dCmdWriteZeroSurface(pThisCC, pCmd);
     5491        rcParse = vmsvga3dCmdWriteZeroSurface(pThisCC, idDXContext, pCmd, cbCmd);
    49665492        break;
    49675493    }
     
    49715497        SVGA3dCmdHintZeroSurface *pCmd = (SVGA3dCmdHintZeroSurface *)pvCmd;
    49725498        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4973         vmsvga3dCmdHintZeroSurface(pThisCC, pCmd);
     5499        rcParse = vmsvga3dCmdHintZeroSurface(pThisCC, idDXContext, pCmd, cbCmd);
    49745500        break;
    49755501    }
     
    49795505        SVGA3dCmdDXTransferToBuffer *pCmd = (SVGA3dCmdDXTransferToBuffer *)pvCmd;
    49805506        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4981         vmsvga3dCmdDXTransferToBuffer(pThisCC, pCmd);
     5507        rcParse = vmsvga3dCmdDXTransferToBuffer(pThisCC, idDXContext, pCmd, cbCmd);
    49825508        break;
    49835509    }
     
    49875513        SVGA3dCmdDXSetStructureCount *pCmd = (SVGA3dCmdDXSetStructureCount *)pvCmd;
    49885514        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4989         vmsvga3dCmdDXSetStructureCount(pThisCC, pCmd);
     5515        rcParse = vmsvga3dCmdDXSetStructureCount(pThisCC, idDXContext, pCmd, cbCmd);
    49905516        break;
    49915517    }
     
    49955521        SVGA3dCmdLogicOpsBitBlt *pCmd = (SVGA3dCmdLogicOpsBitBlt *)pvCmd;
    49965522        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    4997         vmsvga3dCmdLogicOpsBitBlt(pThisCC, pCmd);
     5523        rcParse = vmsvga3dCmdLogicOpsBitBlt(pThisCC, idDXContext, pCmd, cbCmd);
    49985524        break;
    49995525    }
     
    50035529        SVGA3dCmdLogicOpsTransBlt *pCmd = (SVGA3dCmdLogicOpsTransBlt *)pvCmd;
    50045530        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    5005         vmsvga3dCmdLogicOpsTransBlt(pThisCC, pCmd);
     5531        rcParse = vmsvga3dCmdLogicOpsTransBlt(pThisCC, idDXContext, pCmd, cbCmd);
    50065532        break;
    50075533    }
     
    50115537        SVGA3dCmdLogicOpsStretchBlt *pCmd = (SVGA3dCmdLogicOpsStretchBlt *)pvCmd;
    50125538        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    5013         vmsvga3dCmdLogicOpsStretchBlt(pThisCC, pCmd);
     5539        rcParse = vmsvga3dCmdLogicOpsStretchBlt(pThisCC, idDXContext, pCmd, cbCmd);
    50145540        break;
    50155541    }
     
    50195545        SVGA3dCmdLogicOpsColorFill *pCmd = (SVGA3dCmdLogicOpsColorFill *)pvCmd;
    50205546        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    5021         vmsvga3dCmdLogicOpsColorFill(pThisCC, pCmd);
     5547        rcParse = vmsvga3dCmdLogicOpsColorFill(pThisCC, idDXContext, pCmd, cbCmd);
    50225548        break;
    50235549    }
     
    50275553        SVGA3dCmdLogicOpsAlphaBlend *pCmd = (SVGA3dCmdLogicOpsAlphaBlend *)pvCmd;
    50285554        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    5029         vmsvga3dCmdLogicOpsAlphaBlend(pThisCC, pCmd);
     5555        rcParse = vmsvga3dCmdLogicOpsAlphaBlend(pThisCC, idDXContext, pCmd, cbCmd);
    50305556        break;
    50315557    }
     
    50355561        SVGA3dCmdLogicOpsClearTypeBlend *pCmd = (SVGA3dCmdLogicOpsClearTypeBlend *)pvCmd;
    50365562        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    5037         vmsvga3dCmdLogicOpsClearTypeBlend(pThisCC, pCmd);
     5563        rcParse = vmsvga3dCmdLogicOpsClearTypeBlend(pThisCC, idDXContext, pCmd, cbCmd);
    50385564        break;
    50395565    }
     
    50555581        SVGA3dCmdDefineGBSurface_v4 *pCmd = (SVGA3dCmdDefineGBSurface_v4 *)pvCmd;
    50565582        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    5057         vmsvga3dCmdDefineGBSurface_v4(pThisCC, pCmd);
     5583        rcParse = vmsvga3dCmdDefineGBSurface_v4(pThisCC, idDXContext, pCmd, cbCmd);
    50585584        break;
    50595585    }
     
    50635589        SVGA3dCmdDXSetCSUAViews *pCmd = (SVGA3dCmdDXSetCSUAViews *)pvCmd;
    50645590        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    5065         vmsvga3dCmdDXSetCSUAViews(pThisCC, pCmd);
     5591        rcParse = vmsvga3dCmdDXSetCSUAViews(pThisCC, idDXContext, pCmd, cbCmd);
    50665592        break;
    50675593    }
     
    50715597        SVGA3dCmdDXSetMinLOD *pCmd = (SVGA3dCmdDXSetMinLOD *)pvCmd;
    50725598        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    5073         vmsvga3dCmdDXSetMinLOD(pThisCC, pCmd);
     5599        rcParse = vmsvga3dCmdDXSetMinLOD(pThisCC, idDXContext, pCmd, cbCmd);
    50745600        break;
    50755601    }
     
    50915617        SVGA3dCmdDXDefineDepthStencilView_v2 *pCmd = (SVGA3dCmdDXDefineDepthStencilView_v2 *)pvCmd;
    50925618        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    5093         vmsvga3dCmdDXDefineDepthStencilView_v2(pThisCC, pCmd);
     5619        rcParse = vmsvga3dCmdDXDefineDepthStencilView_v2(pThisCC, idDXContext, pCmd, cbCmd);
    50945620        break;
    50955621    }
     
    50995625        SVGA3dCmdDXDefineStreamOutputWithMob *pCmd = (SVGA3dCmdDXDefineStreamOutputWithMob *)pvCmd;
    51005626        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    5101         vmsvga3dCmdDXDefineStreamOutputWithMob(pThisCC, pCmd);
     5627        rcParse = vmsvga3dCmdDXDefineStreamOutputWithMob(pThisCC, idDXContext, pCmd, cbCmd);
    51025628        break;
    51035629    }
     
    51075633        SVGA3dCmdDXSetShaderIface *pCmd = (SVGA3dCmdDXSetShaderIface *)pvCmd;
    51085634        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    5109         vmsvga3dCmdDXSetShaderIface(pThisCC, pCmd);
     5635        rcParse = vmsvga3dCmdDXSetShaderIface(pThisCC, idDXContext, pCmd, cbCmd);
    51105636        break;
    51115637    }
     
    51155641        SVGA3dCmdDXBindStreamOutput *pCmd = (SVGA3dCmdDXBindStreamOutput *)pvCmd;
    51165642        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    5117         vmsvga3dCmdDXBindStreamOutput(pThisCC, pCmd);
     5643        rcParse = vmsvga3dCmdDXBindStreamOutput(pThisCC, idDXContext, pCmd, cbCmd);
    51185644        break;
    51195645    }
     
    51235649        SVGA3dCmdSurfaceStretchBltNonMSToMS *pCmd = (SVGA3dCmdSurfaceStretchBltNonMSToMS *)pvCmd;
    51245650        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    5125         vmsvga3dCmdSurfaceStretchBltNonMSToMS(pThisCC, pCmd);
     5651        rcParse = vmsvga3dCmdSurfaceStretchBltNonMSToMS(pThisCC, idDXContext, pCmd, cbCmd);
    51265652        break;
    51275653    }
     
    51315657        SVGA3dCmdDXBindShaderIface *pCmd = (SVGA3dCmdDXBindShaderIface *)pvCmd;
    51325658        VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK(sizeof(*pCmd));
    5133         vmsvga3dCmdDXBindShaderIface(pThisCC, pCmd);
     5659        rcParse = vmsvga3dCmdDXBindShaderIface(pThisCC, idDXContext, pCmd, cbCmd);
    51345660        break;
    51355661    }
     
    51565682    }
    51575683
    5158     return rcParse;
     5684    return VINF_SUCCESS;
     5685//    return rcParse;
    51595686}
    51605687# undef VMSVGAFIFO_CHECK_3D_CMD_MIN_SIZE_BREAK
  • trunk/src/VBox/Devices/Graphics/DevVGA-SVGA-internal.h

    r86886 r88787  
    2929#endif
    3030
    31 #include <iprt/avl.h>
    32 #include <iprt/list.h>
    33 
    3431
    3532/*********************************************************************************************************************************
     
    5552    PVMSVGAGMRDESCRIPTOR    paDesc;
    5653} GMR, *PGMR;
    57 
    58 /*
    59  * GBO (Guest Backed Object).
    60  * A GBO is a list of the guest pages. GBOs are used for VMSVGA MOBs (Memory OBjects)
    61  * and Object Tables which the guest shares with the host.
    62  *
    63  * A GBO is similar to a GMR. Nevertheless I'll create a new code for GBOs in order
    64  * to avoid tweaking and possibly breaking existing code. Moreover it will be probably possible to
    65  * map the guest pages into the host R3 memory and access them directly.
    66  */
    67 
    68 /* GBO descriptor. */
    69 typedef struct VMSVGAGBODESCRIPTOR
    70 {
    71    RTGCPHYS                 GCPhys;
    72    uint64_t                 cPages;
    73 } VMSVGAGBODESCRIPTOR, *PVMSVGAGBODESCRIPTOR;
    74 typedef VMSVGAGBODESCRIPTOR const *PCVMSVGAGBODESCRIPTOR;
    75 
    76 /* GBO.
    77  */
    78 typedef struct VMSVGAGBO
    79 {
    80     uint32_t                fGboFlags;
    81     uint32_t                cTotalPages;
    82     uint32_t                cbTotal;
    83     uint32_t                cDescriptors;
    84     PVMSVGAGBODESCRIPTOR    paDescriptors;
    85 } VMSVGAGBO, *PVMSVGAGBO;
    86 typedef VMSVGAGBO const *PCVMSVGAGBO;
    87 
    88 #define VMSVGAGBO_F_WRITE_PROTECTED 1
    89 
    90 #define VMSVGA_IS_GBO_CREATED(a_Gbo) ((a_Gbo)->paDescriptors != NULL)
    91 
    92 /* MOB is also a GBO.
    93  */
    94 typedef struct VMSVGAMOB
    95 {
    96     AVLU32NODECORE          Core; /* Key is the mobid. */
    97     RTLISTNODE              nodeLRU;
    98     VMSVGAGBO               Gbo;
    99 } VMSVGAMOB, *PVMSVGAMOB;
    100 typedef VMSVGAMOB const *PCVMSVGAMOB;
    10154
    10255
     
    327280void vmsvgaR3CmdDefineGMR2(PVGASTATE pThis, PVGASTATECC pThisCC, SVGAFifoCmdDefineGMR2 const *pCmd);
    328281void vmsvgaR3CmdRemapGMR2(PVGASTATE pThis, PVGASTATECC pThisCC, SVGAFifoCmdRemapGMR2 const *pCmd);
    329 int vmsvgaR3Process3dCmd(PVGASTATE pThis, PVGASTATECC pThisCC, SVGAFifo3dCmdId enmCmdId, uint32_t cbCmd, void const *pvCmd);
     282int vmsvgaR3Process3dCmd(PVGASTATE pThis, PVGASTATECC pThisCC, uint32_t idDXContext, SVGAFifo3dCmdId enmCmdId, uint32_t cbCmd, void const *pvCmd);
    330283#endif
    331284
  • trunk/src/VBox/Devices/Graphics/DevVGA-SVGA.cpp

    r88774 r88787  
    32453245 * @thread EMT
    32463246 */
    3247 static SVGACBStatus vmsvgaR3CmdBufSubmit(PPDMDEVINS pDevIns, PVGASTATE pThis, PVGASTATECC pThisCC, PVMSVGACMDBUF *ppCmdBuf)
     3247static SVGACBStatus vmsvgaR3CmdBufSubmitCtx(PPDMDEVINS pDevIns, PVGASTATE pThis, PVGASTATECC pThisCC, PVMSVGACMDBUF *ppCmdBuf)
    32483248{
    32493249    /* Command buffer submission. */
     
    33183318            /* Verify the command buffer header. */
    33193319            if (RT_LIKELY(   pCmdBuf->hdr.status == SVGA_CB_STATUS_NONE
    3320                           && (pCmdBuf->hdr.flags & ~(SVGA_CB_FLAG_NO_IRQ)) == 0 /* No unexpected flags. */
     3320                          && (pCmdBuf->hdr.flags & ~(SVGA_CB_FLAG_NO_IRQ | SVGA_CB_FLAG_DX_CONTEXT)) == 0 /* No unexpected flags. */
    33213321                          && pCmdBuf->hdr.length <= SVGA_CB_MAX_SIZE))
    33223322            {
     
    33343334                        if (RT_LIKELY(CBCtx < RT_ELEMENTS(pSvgaR3State->apCmdBufCtxs)))
    33353335                            /* This usually processes the CB async and sets pCmbBuf to NULL. */
    3336                             CBstatus = vmsvgaR3CmdBufSubmit(pDevIns, pThis, pThisCC, &pCmdBuf);
     3336                            CBstatus = vmsvgaR3CmdBufSubmitCtx(pDevIns, pThis, pThisCC, &pCmdBuf);
    33373337                        else
    33383338                            CBstatus = vmsvgaR3CmdBufSubmitDC(pDevIns, pThisCC, &pCmdBuf, &offNextCmd);
     
    33773377    if (CBstatus != SVGA_CB_STATUS_NONE)
    33783378    {
    3379         LogFunc(("Write status %#x, offNextCmd %#x (of %#x), fIRQ %#x\n", CBstatus, offNextCmd, pCmdBuf->hdr.length, fIRQ));
     3379        LogFunc(("Write status %#x, offNextCmd %#x (of %#x), fIRQ %#x\n", CBstatus, offNextCmd, pCmdBuf ? pCmdBuf->hdr.length : 0, fIRQ));
    33803380        vmsvgaR3CmdBufWriteStatus(pDevIns, GCPhysCB, CBstatus, offNextCmd);
    33813381        if (fIRQ)
     
    34033403 * @param pThis        The shared VGA/VMSVGA state.
    34043404 * @param pThisCC      The VGA/VMSVGA state for the current context.
     3405 * @param idDXContext  VGPU10 DX context of the commands or SVGA3D_INVALID_ID if they are not for a specific context.
    34053406 * @param pvCommands   Pointer to the command buffer.
    34063407 * @param cbCommands   Size of the command buffer.
     
    34103411 * @thread FIFO
    34113412 */
    3412 static SVGACBStatus vmsvgaR3CmdBufProcessCommands(PPDMDEVINS pDevIns, PVGASTATE pThis, PVGASTATECC pThisCC, void const *pvCommands, uint32_t cbCommands, uint32_t *poffNextCmd, uint32_t *pu32IrqStatus)
    3413 {
     3413static SVGACBStatus vmsvgaR3CmdBufProcessCommands(PPDMDEVINS pDevIns, PVGASTATE pThis, PVGASTATECC pThisCC, uint32_t idDXContext, void const *pvCommands, uint32_t cbCommands, uint32_t *poffNextCmd, uint32_t *pu32IrqStatus)
     3414{
     3415# ifndef VBOX_WITH_VMSVGA3D
     3416    RT_NOREF(idDXContext);
     3417# endif
    34143418    SVGACBStatus CBstatus = SVGA_CB_STATUS_COMPLETED;
    34153419    PVMSVGAR3STATE const pSvgaR3State = pThisCC->svga.pSvgaR3State;
     
    37233727
    37243728                    /* Command data begins after the 32 bit command length. */
    3725                     int rc = vmsvgaR3Process3dCmd(pThis, pThisCC, (SVGAFifo3dCmdId)cmdId, *pcbMore, pcbMore + 1);
     3729                    int rc = vmsvgaR3Process3dCmd(pThis, pThisCC, idDXContext, (SVGAFifo3dCmdId)cmdId, *pcbMore, pcbMore + 1);
    37263730                    if (RT_SUCCESS(rc))
    37273731                    { /* likely */ }
     
    38233827        uint32_t offNextCmd = 0;
    38243828        uint32_t u32IrqStatus = 0;
    3825 
     3829        uint32_t const idDXContext = RT_BOOL(pCmdBuf->hdr.flags & SVGA_CB_FLAG_DX_CONTEXT)
     3830                                   ? pCmdBuf->hdr.dxContext
     3831                                   : SVGA3D_INVALID_ID;
    38263832        /* Process one buffer. */
    3827         CBstatus = vmsvgaR3CmdBufProcessCommands(pDevIns, pThis, pThisCC, pCmdBuf->pvCommands, pCmdBuf->hdr.length, &offNextCmd, &u32IrqStatus);
     3833        CBstatus = vmsvgaR3CmdBufProcessCommands(pDevIns, pThis, pThisCC, idDXContext, pCmdBuf->pvCommands, pCmdBuf->hdr.length, &offNextCmd, &u32IrqStatus);
    38283834
    38293835        if (!RT_BOOL(pCmdBuf->hdr.flags & SVGA_CB_FLAG_NO_IRQ))
     
    49794985                    }
    49804986
    4981                     vmsvgaR3Process3dCmd(pThis, pThisCC, (SVGAFifo3dCmdId)enmCmdId, cbCmd, pu32Cmd);
     4987                    vmsvgaR3Process3dCmd(pThis, pThisCC, SVGA3D_INVALID_ID, (SVGAFifo3dCmdId)enmCmdId, cbCmd, pu32Cmd);
    49824988                }
    49834989                else
  • trunk/src/VBox/Devices/Graphics/DevVGA-SVGA.h

    r86855 r88787  
    3636#endif
    3737
     38#include <iprt/avl.h>
     39#include <iprt/list.h>
     40
     41
    3842/*
    3943 * PCI device IDs.
     
    5963# pragma GCC diagnostic ignored "-Wpedantic"
    6064#endif
    61 /* VMSVGA headers from SVGA Gallium driver. */
     65/* VMSVGA headers. */
    6266#pragma pack(1) /* VMSVGA structures are '__packed'. */
    6367#include <svga3d_caps.h>
     
    575579void vmsvgaR3Clip3dRect(SVGA3dRect const *pBound, SVGA3dRect RT_UNTRUSTED_GUEST *pRect);
    576580
     581/*
     582 * GBO (Guest Backed Object).
     583 * A GBO is a list of the guest pages. GBOs are used for VMSVGA MOBs (Memory OBjects)
     584 * and Object Tables which the guest shares with the host.
     585 *
     586 * A GBO is similar to a GMR. Nevertheless I'll create a new code for GBOs in order
     587 * to avoid tweaking and possibly breaking existing code. Moreover it will be probably possible to
     588 * map the guest pages into the host R3 memory and access them directly.
     589 */
     590
     591/* GBO descriptor. */
     592typedef struct VMSVGAGBODESCRIPTOR
     593{
     594   RTGCPHYS                 GCPhys;
     595   uint64_t                 cPages;
     596} VMSVGAGBODESCRIPTOR, *PVMSVGAGBODESCRIPTOR;
     597typedef VMSVGAGBODESCRIPTOR const *PCVMSVGAGBODESCRIPTOR;
     598
     599/* GBO.
     600 */
     601typedef struct VMSVGAGBO
     602{
     603    uint32_t                fGboFlags;
     604    uint32_t                cTotalPages;
     605    uint32_t                cbTotal;
     606    uint32_t                cDescriptors;
     607    PVMSVGAGBODESCRIPTOR    paDescriptors;
     608    void                   *pvHost; /* Pointer to cbTotal bytes on the host if VMSVGAGBO_F_HOST_BACKED is set. */
     609} VMSVGAGBO, *PVMSVGAGBO;
     610typedef VMSVGAGBO const *PCVMSVGAGBO;
     611
     612#define VMSVGAGBO_F_WRITE_PROTECTED 0x1
     613#define VMSVGAGBO_F_HOST_BACKED     0x2
     614
     615#define VMSVGA_IS_GBO_CREATED(a_Gbo) ((a_Gbo)->paDescriptors != NULL)
     616
     617/* MOB is also a GBO.
     618 */
     619typedef struct VMSVGAMOB
     620{
     621    AVLU32NODECORE          Core; /* Key is the mobid. */
     622    RTLISTNODE              nodeLRU;
     623    VMSVGAGBO               Gbo;
     624} VMSVGAMOB, *PVMSVGAMOB;
     625typedef VMSVGAMOB const *PCVMSVGAMOB;
     626
     627int vmsvgaR3MobBackingStoreCreate(PVMSVGAR3STATE pSvgaR3State, PVMSVGAMOB pMob, uint32_t cbValid);
     628void vmsvgaR3MobBackingStoreDelete(PVMSVGAR3STATE pSvgaR3State, PVMSVGAMOB pMob);
     629void *vmsvgaR3MobBackingStoreGet(PVMSVGAMOB pMob, uint32_t off);
     630
     631DECLINLINE(uint32_t) vmsvgaR3MobSize(PVMSVGAMOB pMob)
     632{
     633    if (pMob)
     634        return pMob->Gbo.cbTotal;
     635    return 0;
     636}
     637
     638DECLINLINE(uint32_t) vmsvgaR3MobId(PVMSVGAMOB pMob)
     639{
     640    if (pMob)
     641        return pMob->Core.Key;
     642    return SVGA_ID_INVALID;
     643}
     644
     645#ifdef VBOX_WITH_VMSVGA3D
     646int vmsvgaR3UpdateGBSurface(PVGASTATECC pThisCC, SVGA3dSurfaceImageId const *pImageId, SVGA3dBox const *pBox);
     647int vmsvgaR3UpdateGBSurfaceEx(PVGASTATECC pThisCC, SVGA3dSurfaceImageId const *pImageId, SVGA3dBox const *pBoxDst, SVGA3dPoint const *pPtSrc);
     648#endif
     649
    577650#endif /* !VBOX_INCLUDED_SRC_Graphics_DevVGA_SVGA_h */
  • trunk/src/VBox/Devices/Graphics/DevVGA-SVGA3d-info.cpp

    r86905 r88787  
    5050static const VMSVGAINFOENUM g_aSVGA3dSurfaceFormats[] =
    5151{
    52     { SVGA3D_FORMAT_INVALID     , "FORMAT_INVALID" },
    53     { SVGA3D_X8R8G8B8           , "X8R8G8B8" },
    54     { SVGA3D_A8R8G8B8           , "A8R8G8B8" },
    55     { SVGA3D_R5G6B5             , "R5G6B5" },
    56     { SVGA3D_X1R5G5B5           , "X1R5G5B5" },
    57     { SVGA3D_A1R5G5B5           , "A1R5G5B5" },
    58     { SVGA3D_A4R4G4B4           , "A4R4G4B4" },
    59     { SVGA3D_Z_D32              , "Z_D32" },
    60     { SVGA3D_Z_D16              , "Z_D16" },
    61     { SVGA3D_Z_D24S8            , "Z_D24S8" },
    62     { SVGA3D_Z_D15S1            , "Z_D15S1" },
    63     { SVGA3D_LUMINANCE8         , "LUMINANCE8" },
    64     { SVGA3D_LUMINANCE4_ALPHA4  , "LUMINANCE4_ALPHA4" },
    65     { SVGA3D_LUMINANCE16        , "LUMINANCE16" },
    66     { SVGA3D_LUMINANCE8_ALPHA8  , "LUMINANCE8_ALPHA8" },
    67     { SVGA3D_DXT1               , "DXT1" },
    68     { SVGA3D_DXT2               , "DXT2" },
    69     { SVGA3D_DXT3               , "DXT3" },
    70     { SVGA3D_DXT4               , "DXT4" },
    71     { SVGA3D_DXT5               , "DXT5" },
    72     { SVGA3D_BUMPU8V8           , "BUMPU8V8" },
    73     { SVGA3D_BUMPL6V5U5         , "BUMPL6V5U5" },
    74     { SVGA3D_BUMPX8L8V8U8       , "BUMPX8L8V8U8" },
    75     { SVGA3D_FORMAT_DEAD1       , "FORMAT_DEAD1" },
    76     { SVGA3D_ARGB_S10E5         , "ARGB_S10E5" },
    77     { SVGA3D_ARGB_S23E8         , "ARGB_S23E8" },
    78     { SVGA3D_A2R10G10B10        , "A2R10G10B10" },
    79     { SVGA3D_V8U8               , "V8U8" },
    80     { SVGA3D_Q8W8V8U8           , "Q8W8V8U8" },
    81     { SVGA3D_CxV8U8             , "CxV8U8" },
    82     { SVGA3D_X8L8V8U8           , "X8L8V8U8" },
    83     { SVGA3D_A2W10V10U10        , "A2W10V10U10" },
    84     { SVGA3D_ALPHA8             , "ALPHA8" },
    85     { SVGA3D_R_S10E5            , "R_S10E5" },
    86     { SVGA3D_R_S23E8            , "R_S23E8" },
    87     { SVGA3D_RG_S10E5           , "RG_S10E5" },
    88     { SVGA3D_RG_S23E8           , "RG_S23E8" },
    89     { SVGA3D_BUFFER             , "BUFFER" },
    90     { SVGA3D_Z_D24X8            , "Z_D24X8" },
    91     { SVGA3D_V16U16             , "V16U16" },
    92     { SVGA3D_G16R16             , "G16R16" },
    93     { SVGA3D_A16B16G16R16       , "A16B16G16R16" },
    94     { SVGA3D_UYVY               , "UYVY" },
    95     { SVGA3D_YUY2               , "YUY2" },
    96     { SVGA3D_NV12               , "NV12" },
    97     { SVGA3D_FORMAT_DEAD2       , "DEAD2" }, /* Old SVGA3D_AYUV */
    98     { SVGA3D_ATI1               , "ATI1" },
    99     { SVGA3D_ATI2               , "ATI2" },
    100     { SVGA3D_Z_DF16             , "Z_DF16" },
    101     { SVGA3D_Z_DF24             , "Z_DF24" },
    102     { SVGA3D_Z_D24S8_INT        , "Z_D24S8_INT" },
    103     { SVGA3D_R8G8B8A8_SNORM     , "R8G8B8A8_SNORM" },
    104     { SVGA3D_R16G16_UNORM       , "R16G16_UNORM" },
     52    { SVGA3D_FORMAT_INVALID                , "FORMAT_INVALID" },
     53    { SVGA3D_X8R8G8B8                      , "X8R8G8B8" },
     54    { SVGA3D_A8R8G8B8                      , "A8R8G8B8" },
     55    { SVGA3D_R5G6B5                        , "R5G6B5" },
     56    { SVGA3D_X1R5G5B5                      , "X1R5G5B5" },
     57    { SVGA3D_A1R5G5B5                      , "A1R5G5B5" },
     58    { SVGA3D_A4R4G4B4                      , "A4R4G4B4" },
     59    { SVGA3D_Z_D32                         , "Z_D32" },
     60    { SVGA3D_Z_D16                         , "Z_D16" },
     61    { SVGA3D_Z_D24S8                       , "Z_D24S8" },
     62    { SVGA3D_Z_D15S1                       , "Z_D15S1" },
     63    { SVGA3D_LUMINANCE8                    , "LUMINANCE8" },
     64    { SVGA3D_LUMINANCE4_ALPHA4             , "LUMINANCE4_ALPHA4" },
     65    { SVGA3D_LUMINANCE16                   , "LUMINANCE16" },
     66    { SVGA3D_LUMINANCE8_ALPHA8             , "LUMINANCE8_ALPHA8" },
     67    { SVGA3D_DXT1                          , "DXT1" },
     68    { SVGA3D_DXT2                          , "DXT2" },
     69    { SVGA3D_DXT3                          , "DXT3" },
     70    { SVGA3D_DXT4                          , "DXT4" },
     71    { SVGA3D_DXT5                          , "DXT5" },
     72    { SVGA3D_BUMPU8V8                      , "BUMPU8V8" },
     73    { SVGA3D_BUMPL6V5U5                    , "BUMPL6V5U5" },
     74    { SVGA3D_BUMPX8L8V8U8                  , "BUMPX8L8V8U8" },
     75    { SVGA3D_FORMAT_DEAD1                  , "FORMAT_DEAD1" },
     76    { SVGA3D_ARGB_S10E5                    , "ARGB_S10E5" },
     77    { SVGA3D_ARGB_S23E8                    , "ARGB_S23E8" },
     78    { SVGA3D_A2R10G10B10                   , "A2R10G10B10" },
     79    { SVGA3D_V8U8                          , "V8U8" },
     80    { SVGA3D_Q8W8V8U8                      , "Q8W8V8U8" },
     81    { SVGA3D_CxV8U8                        , "CxV8U8" },
     82    { SVGA3D_X8L8V8U8                      , "X8L8V8U8" },
     83    { SVGA3D_A2W10V10U10                   , "A2W10V10U10" },
     84    { SVGA3D_ALPHA8                        , "ALPHA8" },
     85    { SVGA3D_R_S10E5                       , "R_S10E5" },
     86    { SVGA3D_R_S23E8                       , "R_S23E8" },
     87    { SVGA3D_RG_S10E5                      , "RG_S10E5" },
     88    { SVGA3D_RG_S23E8                      , "RG_S23E8" },
     89    { SVGA3D_BUFFER                        , "BUFFER" },
     90    { SVGA3D_Z_D24X8                       , "Z_D24X8" },
     91    { SVGA3D_V16U16                        , "V16U16" },
     92    { SVGA3D_G16R16                        , "G16R16" },
     93    { SVGA3D_A16B16G16R16                  , "A16B16G16R16" },
     94    { SVGA3D_UYVY                          , "UYVY" },
     95    { SVGA3D_YUY2                          , "YUY2" },
     96    { SVGA3D_NV12                          , "NV12" },
     97    { SVGA3D_FORMAT_DEAD2                  , "FORMAT_DEAD2" },
     98    { SVGA3D_R32G32B32A32_TYPELESS         , "R32G32B32A32_TYPELESS" },
     99    { SVGA3D_R32G32B32A32_UINT             , "R32G32B32A32_UINT" },
     100    { SVGA3D_R32G32B32A32_SINT             , "R32G32B32A32_SINT" },
     101    { SVGA3D_R32G32B32_TYPELESS            , "R32G32B32_TYPELESS" },
     102    { SVGA3D_R32G32B32_FLOAT               , "R32G32B32_FLOAT" },
     103    { SVGA3D_R32G32B32_UINT                , "R32G32B32_UINT" },
     104    { SVGA3D_R32G32B32_SINT                , "R32G32B32_SINT" },
     105    { SVGA3D_R16G16B16A16_TYPELESS         , "R16G16B16A16_TYPELESS" },
     106    { SVGA3D_R16G16B16A16_UINT             , "R16G16B16A16_UINT" },
     107    { SVGA3D_R16G16B16A16_SNORM            , "R16G16B16A16_SNORM" },
     108    { SVGA3D_R16G16B16A16_SINT             , "R16G16B16A16_SINT" },
     109    { SVGA3D_R32G32_TYPELESS               , "R32G32_TYPELESS" },
     110    { SVGA3D_R32G32_UINT                   , "R32G32_UINT" },
     111    { SVGA3D_R32G32_SINT                   , "R32G32_SINT" },
     112    { SVGA3D_R32G8X24_TYPELESS             , "R32G8X24_TYPELESS" },
     113    { SVGA3D_D32_FLOAT_S8X24_UINT          , "D32_FLOAT_S8X24_UINT" },
     114    { SVGA3D_R32_FLOAT_X8X24               , "R32_FLOAT_X8X24" },
     115    { SVGA3D_X32_G8X24_UINT                , "X32_G8X24_UINT" },
     116    { SVGA3D_R10G10B10A2_TYPELESS          , "R10G10B10A2_TYPELESS" },
     117    { SVGA3D_R10G10B10A2_UINT              , "R10G10B10A2_UINT" },
     118    { SVGA3D_R11G11B10_FLOAT               , "R11G11B10_FLOAT" },
     119    { SVGA3D_R8G8B8A8_TYPELESS             , "R8G8B8A8_TYPELESS" },
     120    { SVGA3D_R8G8B8A8_UNORM                , "R8G8B8A8_UNORM" },
     121    { SVGA3D_R8G8B8A8_UNORM_SRGB           , "R8G8B8A8_UNORM_SRGB" },
     122    { SVGA3D_R8G8B8A8_UINT                 , "R8G8B8A8_UINT" },
     123    { SVGA3D_R8G8B8A8_SINT                 , "R8G8B8A8_SINT" },
     124    { SVGA3D_R16G16_TYPELESS               , "R16G16_TYPELESS" },
     125    { SVGA3D_R16G16_UINT                   , "R16G16_UINT" },
     126    { SVGA3D_R16G16_SINT                   , "R16G16_SINT" },
     127    { SVGA3D_R32_TYPELESS                  , "R32_TYPELESS" },
     128    { SVGA3D_D32_FLOAT                     , "D32_FLOAT" },
     129    { SVGA3D_R32_UINT                      , "R32_UINT" },
     130    { SVGA3D_R32_SINT                      , "R32_SINT" },
     131    { SVGA3D_R24G8_TYPELESS                , "R24G8_TYPELESS" },
     132    { SVGA3D_D24_UNORM_S8_UINT             , "D24_UNORM_S8_UINT" },
     133    { SVGA3D_R24_UNORM_X8                  , "R24_UNORM_X8" },
     134    { SVGA3D_X24_G8_UINT                   , "X24_G8_UINT" },
     135    { SVGA3D_R8G8_TYPELESS                 , "R8G8_TYPELESS" },
     136    { SVGA3D_R8G8_UNORM                    , "R8G8_UNORM" },
     137    { SVGA3D_R8G8_UINT                     , "R8G8_UINT" },
     138    { SVGA3D_R8G8_SINT                     , "R8G8_SINT" },
     139    { SVGA3D_R16_TYPELESS                  , "R16_TYPELESS" },
     140    { SVGA3D_R16_UNORM                     , "R16_UNORM" },
     141    { SVGA3D_R16_UINT                      , "R16_UINT" },
     142    { SVGA3D_R16_SNORM                     , "R16_SNORM" },
     143    { SVGA3D_R16_SINT                      , "R16_SINT" },
     144    { SVGA3D_R8_TYPELESS                   , "R8_TYPELESS" },
     145    { SVGA3D_R8_UNORM                      , "R8_UNORM" },
     146    { SVGA3D_R8_UINT                       , "R8_UINT" },
     147    { SVGA3D_R8_SNORM                      , "R8_SNORM" },
     148    { SVGA3D_R8_SINT                       , "R8_SINT" },
     149    { SVGA3D_P8                            , "P8" },
     150    { SVGA3D_R9G9B9E5_SHAREDEXP            , "R9G9B9E5_SHAREDEXP" },
     151    { SVGA3D_R8G8_B8G8_UNORM               , "R8G8_B8G8_UNORM" },
     152    { SVGA3D_G8R8_G8B8_UNORM               , "G8R8_G8B8_UNORM" },
     153    { SVGA3D_BC1_TYPELESS                  , "BC1_TYPELESS" },
     154    { SVGA3D_BC1_UNORM_SRGB                , "BC1_UNORM_SRGB" },
     155    { SVGA3D_BC2_TYPELESS                  , "BC2_TYPELESS" },
     156    { SVGA3D_BC2_UNORM_SRGB                , "BC2_UNORM_SRGB" },
     157    { SVGA3D_BC3_TYPELESS                  , "BC3_TYPELESS" },
     158    { SVGA3D_BC3_UNORM_SRGB                , "BC3_UNORM_SRGB" },
     159    { SVGA3D_BC4_TYPELESS                  , "BC4_TYPELESS" },
     160    { SVGA3D_ATI1                          , "ATI1" },
     161    { SVGA3D_BC4_SNORM                     , "BC4_SNORM" },
     162    { SVGA3D_BC5_TYPELESS                  , "BC5_TYPELESS" },
     163    { SVGA3D_ATI2                          , "ATI2" },
     164    { SVGA3D_BC5_SNORM                     , "BC5_SNORM" },
     165    { SVGA3D_R10G10B10_XR_BIAS_A2_UNORM    , "R10G10B10_XR_BIAS_A2_UNORM" },
     166    { SVGA3D_B8G8R8A8_TYPELESS             , "B8G8R8A8_TYPELESS" },
     167    { SVGA3D_B8G8R8A8_UNORM_SRGB           , "B8G8R8A8_UNORM_SRGB" },
     168    { SVGA3D_B8G8R8X8_TYPELESS             , "B8G8R8X8_TYPELESS" },
     169    { SVGA3D_B8G8R8X8_UNORM_SRGB           , "B8G8R8X8_UNORM_SRGB" },
     170    { SVGA3D_Z_DF16                        , "Z_DF16" },
     171    { SVGA3D_Z_DF24                        , "Z_DF24" },
     172    { SVGA3D_Z_D24S8_INT                   , "Z_D24S8_INT" },
     173    { SVGA3D_YV12                          , "YV12" },
     174    { SVGA3D_R32G32B32A32_FLOAT            , "R32G32B32A32_FLOAT" },
     175    { SVGA3D_R16G16B16A16_FLOAT            , "R16G16B16A16_FLOAT" },
     176    { SVGA3D_R16G16B16A16_UNORM            , "R16G16B16A16_UNORM" },
     177    { SVGA3D_R32G32_FLOAT                  , "R32G32_FLOAT" },
     178    { SVGA3D_R10G10B10A2_UNORM             , "R10G10B10A2_UNORM" },
     179    { SVGA3D_R8G8B8A8_SNORM                , "R8G8B8A8_SNORM" },
     180    { SVGA3D_R16G16_FLOAT                  , "R16G16_FLOAT" },
     181    { SVGA3D_R16G16_UNORM                  , "R16G16_UNORM" },
     182    { SVGA3D_R16G16_SNORM                  , "R16G16_SNORM" },
     183    { SVGA3D_R32_FLOAT                     , "R32_FLOAT" },
     184    { SVGA3D_R8G8_SNORM                    , "R8G8_SNORM" },
     185    { SVGA3D_R16_FLOAT                     , "R16_FLOAT" },
     186    { SVGA3D_D16_UNORM                     , "D16_UNORM" },
     187    { SVGA3D_A8_UNORM                      , "A8_UNORM" },
     188    { SVGA3D_BC1_UNORM                     , "BC1_UNORM" },
     189    { SVGA3D_BC2_UNORM                     , "BC2_UNORM" },
     190    { SVGA3D_BC3_UNORM                     , "BC3_UNORM" },
     191    { SVGA3D_B5G6R5_UNORM                  , "B5G6R5_UNORM" },
     192    { SVGA3D_B5G5R5A1_UNORM                , "B5G5R5A1_UNORM" },
     193    { SVGA3D_B8G8R8A8_UNORM                , "B8G8R8A8_UNORM" },
     194    { SVGA3D_B8G8R8X8_UNORM                , "B8G8R8X8_UNORM" },
     195    { SVGA3D_BC4_UNORM                     , "BC4_UNORM" },
     196    { SVGA3D_BC5_UNORM                     , "BC5_UNORM" },
     197    { SVGA3D_B4G4R4A4_UNORM                , "B4G4R4A4_UNORM" },
     198    { SVGA3D_BC6H_TYPELESS                 , "BC6H_TYPELESS" },
     199    { SVGA3D_BC6H_UF16                     , "BC6H_UF16" },
     200    { SVGA3D_BC6H_SF16                     , "BC6H_SF16" },
     201    { SVGA3D_BC7_TYPELESS                  , "BC7_TYPELESS" },
     202    { SVGA3D_BC7_UNORM                     , "BC7_UNORM" },
     203    { SVGA3D_BC7_UNORM_SRGB                , "BC7_UNORM_SRGB" },
     204    { SVGA3D_AYUV                          , "AYUV" },
    105205};
    106206VMSVGAINFOENUMMAP_MAKE(RT_NOTHING, g_SVGA3dSurfaceFormat2String, g_aSVGA3dSurfaceFormats, "SVGA3D_");
     
    497597                            AssertMsgFailed(("%#x\n", fSwitchFlags));
    498598                    }
    499 #elif defined(VMSVGA3D_DX)
     599#elif defined(VMSVGA3D_D3D11)
    500600                    /** @todo */
    501601                    RT_NOREF(pState);
     
    15241624# ifdef VMSVGA3D_DIRECT3D
    15251625    pHlp->pfnPrintf(pHlp, "pDevice:                 %p\n", pContext->pDevice);
    1526 # elif defined(VMSVGA3D_DX)
     1626# elif defined(VMSVGA3D_D3D11)
    15271627    /** @todo */
    15281628# else
     
    20322132    pHlp->pfnPrintf(pHlp, "fStencilAsTexture:       %RTbool\n", pSurface->fStencilAsTexture);
    20332133
    2034 #elif defined(VMSVGA3D_DX)
     2134#elif defined(VMSVGA3D_D3D11)
    20352135    /** @todo */
    20362136#elif defined(VMSVGA3D_OPENGL)
  • trunk/src/VBox/Devices/Graphics/DevVGA-SVGA3d-internal.h

    r86905 r88787  
    2929#endif
    3030#ifdef VMSVGA3D_OPENGL
    31 # if defined(VMSVGA3D_DIRECT3D) || defined(VMSVGA3D_DX)
     31# if defined(VMSVGA3D_DIRECT3D) || defined(VMSVGA3D_D3D11)
    3232#  error "Both VMSVGA3D_DIRECT3D and VMSVGA3D_OPENGL cannot be defined at the same time."
    3333# endif
    34 #elif !defined(VMSVGA3D_DIRECT3D) && !defined(VMSVGA3D_DX)
     34#elif !defined(VMSVGA3D_DIRECT3D) && !defined(VMSVGA3D_D3D11)
    3535# error "Either VMSVGA3D_OPENGL or VMSVGA3D_DIRECT3D must be defined."
    3636#endif
     
    5151#  include <d3d9.h>
    5252#  include <iprt/avl.h>
    53 # elif defined(VMSVGA3D_DX)
     53# elif defined(VMSVGA3D_D3D11)
    5454#  include <d3d11.h>
    5555# else
     
    9292# include "vmsvga_glext/glext.h"
    9393# include "shaderlib/shaderlib.h"
     94#endif
     95
     96#ifdef VMSVGA3D_DX
     97#include "DevVGA-SVGA3d-dx-shader.h"
    9498#endif
    9599
     
    676680#ifdef VMSVGA3D_DIRECT3D
    677681# define VMSVGA3DSURFACE_HAS_HW_SURFACE(a_pSurface) ((a_pSurface)->u.pSurface != NULL)
    678 #elif defined(VMSVGA3D_DX)
     682#elif defined(VMSVGA3D_D3D11)
    679683# define VMSVGA3DSURFACE_HAS_HW_SURFACE(a_pSurface) ((a_pSurface)->pBackendSurface != NULL)
    680684#else
     
    692696   (   (a_pSurface)->enmD3DResType == VMSVGA3D_D3DRESTYPE_VERTEX_BUFFER \
    693697    || (a_pSurface)->enmD3DResType == VMSVGA3D_D3DRESTYPE_INDEX_BUFFER)
    694 #elif defined(VMSVGA3D_DX)
     698#elif defined(VMSVGA3D_D3D11)
    695699  /** @todo */
    696700# define VMSVGA3DSURFACE_NEEDS_DATA(a_pSurface) (false)
     
    703707typedef struct VMSVGA3DSHADER
    704708{
    705     uint32_t                        id;
     709    uint32_t                        id; /** @todo Rename to shid. */
    706710    uint32_t                        cid;
    707711    SVGA3dShaderType                type;
     
    713717        IDirect3DVertexShader9     *pVertexShader;
    714718        IDirect3DPixelShader9      *pPixelShader;
    715 #elif defined(VMSVGA3D_DX)
    716         /** todo */
     719#elif defined(VMSVGA3D_D3D11)
     720        /* Nothing */
    717721#else
    718722        void                       *pVertexShader;
    719723        void                       *pPixelShader;
    720724#endif
    721         void                       *pv;
     725        void                       *pvBackendShader;
    722726    } u;
     727#ifdef VMSVGA3D_DX
     728    DXShaderInfo                   shaderInfo;
     729#endif
    723730} VMSVGA3DSHADER;
    724731typedef VMSVGA3DSHADER *PVMSVGA3DSHADER;
     
    735742    SSMFIELD_ENTRY(                 VMSVGA3DSHADER, cbData),
    736743    SSMFIELD_ENTRY_IGN_HCPTR(       VMSVGA3DSHADER, pShaderProgram),
    737     SSMFIELD_ENTRY_IGN_HCPTR(       VMSVGA3DSHADER, u.pv),
     744    SSMFIELD_ENTRY_IGN_HCPTR(       VMSVGA3DSHADER, u.pvBackendShader),
    738745    SSMFIELD_ENTRY_TERM()
    739746};
     
    766773#ifdef VMSVGA3D_DIRECT3D
    767774    IDirect3DQuery9    *pQuery;
    768 #elif defined(VMSVGA3D_DX)
     775#elif defined(VMSVGA3D_D3D11)
    769776    /** @todo */
    770777#else /* VMSVGA3D_OPENGL */
     
    783790#ifdef VMSVGA3D_DIRECT3D
    784791    SSMFIELD_ENTRY_IGN_HCPTR(       VMSVGA3DQUERY, pQuery),
    785 #elif defined(VMSVGA3D_DX)
     792#elif defined(VMSVGA3D_D3D11)
    786793    /** @todo */
    787794#else /* VMSVGA3D_OPENGL */
     
    796803#ifdef VMSVGA3D_DIRECT3D
    797804#define VMSVGA3DQUERY_EXISTS(p) ((p)->pQuery && (p)->enmQueryState != VMSVGA3DQUERYSTATE_NULL)
    798 #elif defined(VMSVGA3D_DX)
     805#elif defined(VMSVGA3D_D3D11)
    799806    /** @todo */
    800807#define VMSVGA3DQUERY_EXISTS(p) (false)
     
    816823    IDirect3DDevice9Ex     *pDevice;
    817824#  endif
    818 # elif defined(VMSVGA3D_DX)
    819     /** @todo */
     825# elif defined(VMSVGA3D_D3D11)
     826    /** @todo Legacy contexts with DX backend. */
    820827# else
    821828    /* Device context of the context window. */
     
    916923#  ifdef VMSVGA3D_DIRECT3D
    917924    SSMFIELD_ENTRY_IGN_HCPTR(       VMSVGA3DCONTEXT, pDevice),
    918 #  elif defined(VMSVGA3D_DX)
     925#  elif defined(VMSVGA3D_D3D11)
    919926    /** @todo */
    920927#  else
     
    970977
    971978
     979#ifdef VMSVGA3D_DX
     980/* The 3D backend DX context. The actual structure is 3D API specific. */
     981typedef struct VMSVGA3DBACKENDDXCONTEXT *PVMSVGA3DBACKENDDXCONTEXT;
     982
     983/**
     984 * VMSVGA3D DX context (VGPU10+). DX contexts ids are a separate namespace from legacy context ids.
     985 */
     986typedef struct VMSVGA3DDXCONTEXT
     987{
     988    /** The DX context id. */
     989    uint32_t                  cid;
     990    /** . */
     991    uint32_t                  u32Reserved;
     992    /** Backend specific data. */
     993    PVMSVGA3DBACKENDDXCONTEXT pBackendDXContext;
     994    /** Copy of the guest memory for this context. The guest will be updated on unbind. */
     995    SVGADXContextMobFormat    svgaDXContext;
     996    /* Context-Object Tables bound to this context. */
     997    PVMSVGAMOB aCOTMobs[SVGA_COTABLE_MAX];
     998    struct
     999    {
     1000        SVGACOTableDXRTViewEntry          *paRTView;
     1001        SVGACOTableDXDSViewEntry          *paDSView;
     1002        SVGACOTableDXSRViewEntry          *paSRView;
     1003        SVGACOTableDXElementLayoutEntry   *paElementLayout;
     1004        SVGACOTableDXBlendStateEntry      *paBlendState;
     1005        SVGACOTableDXDepthStencilEntry    *paDepthStencil;
     1006        SVGACOTableDXRasterizerStateEntry *paRasterizerState;
     1007        SVGACOTableDXSamplerEntry         *paSampler;
     1008        SVGACOTableDXStreamOutputEntry    *paStreamOutput;
     1009        SVGACOTableDXQueryEntry           *paQuery;
     1010        SVGACOTableDXShaderEntry          *paShader;
     1011        SVGACOTableDXUAViewEntry          *paUAView;
     1012        uint32_t                           cRTView;
     1013        uint32_t                           cDSView;
     1014        uint32_t                           cSRView;
     1015        uint32_t                           cElementLayout;
     1016        uint32_t                           cBlendState;
     1017        uint32_t                           cDepthStencil;
     1018        uint32_t                           cRasterizerState;
     1019        uint32_t                           cSampler;
     1020        uint32_t                           cStreamOutput;
     1021        uint32_t                           cQuery;
     1022        uint32_t                           cShader;
     1023        uint32_t                           cUAView;
     1024    } cot;
     1025    /* Shader information. The array has cot.cShader elements. Some data is dublicated in cot.paShader. */
     1026    PVMSVGA3DSHADER paShader;
     1027} VMSVGA3DDXCONTEXT;
     1028/** Pointer to a VMSVGA3D DX context. */
     1029typedef VMSVGA3DDXCONTEXT *PVMSVGA3DDXCONTEXT;
     1030#endif /* VMSVGA3D_DX */
     1031
     1032
    9721033#ifdef VMSVGA3D_OPENGL
    9731034typedef struct VMSVGA3DFORMATCONVERTER *PVMSVGA3DFORMATCONVERTER;
     
    9881049    /** The size of papSurfaces. */
    9891050    uint32_t                cSurfaces;
     1051#ifdef VMSVGA3D_DX
     1052    /** The size of papDXContexts. */
     1053    uint32_t                cDXContexts;
     1054    /** Reserved. */
     1055    uint32_t                u32Reserved;
     1056#endif
    9901057    /** Contexts indexed by ID.  Grown as needed. */
    9911058    PVMSVGA3DCONTEXT       *papContexts;
    9921059    /** Surfaces indexed by ID.  Grown as needed. */
    9931060    PVMSVGA3DSURFACE       *papSurfaces;
     1061#ifdef VMSVGA3D_DX
     1062    /** DX contexts indexed by ID.  Grown as needed. */
     1063    PVMSVGA3DDXCONTEXT     *papDXContexts;
     1064#endif
    9941065
    9951066#ifdef RT_OS_WINDOWS
     
    10061077    bool                    fSupportedFormatYUY2 : 1;
    10071078    bool                    fSupportedFormatA8B8G8R8 : 1;
    1008 # elif defined(VMSVGA3D_DX)
     1079# elif defined(VMSVGA3D_D3D11)
    10091080    PVMSVGA3DBACKEND        pBackend;
    10101081# endif
     
    12931364}
    12941365
     1366#ifdef VMSVGA3D_DX
     1367DECLINLINE(int) vmsvga3dDXContextFromCid(PVMSVGA3DSTATE pState, uint32_t cid, PVMSVGA3DDXCONTEXT *ppDXContext)
     1368{
     1369    *ppDXContext = NULL;
     1370    if (cid == SVGA_ID_INVALID)
     1371        return VERR_INVALID_STATE;
     1372    AssertReturn(cid < pState->cDXContexts, VERR_INVALID_PARAMETER);
     1373    PVMSVGA3DDXCONTEXT const pDXContext = pState->papDXContexts[cid];
     1374    if (RT_LIKELY(pDXContext && pDXContext->cid == cid))
     1375    {
     1376        *ppDXContext = pDXContext;
     1377        return VINF_SUCCESS;
     1378    }
     1379    LogRelMax(64, ("VMSVGA: unknown DX cid=%u (%s cid=%u)\n", cid, pDXContext ? "expected" : "null", pDXContext ? pDXContext->cid : -1));
     1380    return VERR_INVALID_PARAMETER;
     1381}
     1382#endif
     1383
    12951384DECLINLINE(int) vmsvga3dSurfaceFromSid(PVMSVGA3DSTATE pState, uint32_t sid, PVMSVGA3DSURFACE *ppSurface)
    12961385{
     
    13361425    return Face;
    13371426}
    1338 #elif defined(VMSVGA3D_DX)
     1427#elif defined(VMSVGA3D_D3D11)
    13391428DECLINLINE(D3D11_TEXTURECUBE_FACE) vmsvga3dCubemapFaceFromIndex(uint32_t iFace)
    13401429{
     
    13791468                                 const char *pszPath, const char *pszNamePrefix, const char *pszNameSuffix);
    13801469
    1381 #if defined(VMSVGA3D_DIRECT3D) || defined(VMSVGA3D_DX)
     1470#if defined(VMSVGA3D_DIRECT3D) || defined(VMSVGA3D_D3D11)
    13821471#define D3D_RELEASE(ptr) do { \
    13831472    if (ptr)                  \
  • trunk/src/VBox/Devices/Graphics/DevVGA-SVGA3d-ogl.cpp

    r86905 r88787  
    77177717    return VINF_SUCCESS;
    77187718}
     7719
     7720int vmsvga3dQueryInterface(PVGASTATECC pThisCC, char const *pszInterfaceName, void *pvInterfaceFuncs, size_t cbInterfaceFuncs)
     7721{
     7722    RT_NOREF(pThisCC, pszInterfaceName, pvInterfaceFuncs, cbInterfaceFuncs);
     7723    return VERR_NOT_IMPLEMENTED;
     7724}
  • trunk/src/VBox/Devices/Graphics/DevVGA-SVGA3d-savedstate.cpp

    r86839 r88787  
    956956
    957957                        RTMemFree(pData);
    958 #elif defined(VMSVGA3D_DX)
     958#elif defined(VMSVGA3D_D3D11)
    959959                        /** @todo */
    960960#elif defined(VMSVGA3D_OPENGL)
  • trunk/src/VBox/Devices/Graphics/DevVGA-SVGA3d-shared.cpp

    r86905 r88787  
    295295    {
    296296    case SVGA3D_X8R8G8B8:
     297        *pcxBlock = 1;
     298        *pcyBlock = 1;
     299        return 4;
     300
    297301    case SVGA3D_A8R8G8B8:
    298302        *pcxBlock = 1;
     
    301305
    302306    case SVGA3D_R5G6B5:
     307        *pcxBlock = 1;
     308        *pcyBlock = 1;
     309        return 2;
     310
    303311    case SVGA3D_X1R5G5B5:
     312        *pcxBlock = 1;
     313        *pcyBlock = 1;
     314        return 2;
     315
    304316    case SVGA3D_A1R5G5B5:
     317        *pcxBlock = 1;
     318        *pcyBlock = 1;
     319        return 2;
     320
    305321    case SVGA3D_A4R4G4B4:
    306322        *pcxBlock = 1;
     
    309325
    310326    case SVGA3D_Z_D32:
     327        *pcxBlock = 1;
     328        *pcyBlock = 1;
     329        return 4;
     330
     331    case SVGA3D_Z_D16:
     332        *pcxBlock = 1;
     333        *pcyBlock = 1;
     334        return 2;
     335
    311336    case SVGA3D_Z_D24S8:
     337        *pcxBlock = 1;
     338        *pcyBlock = 1;
     339        return 4;
     340
     341    case SVGA3D_Z_D15S1:
     342        *pcxBlock = 1;
     343        *pcyBlock = 1;
     344        return 2;
     345
     346    case SVGA3D_LUMINANCE8:
     347        *pcxBlock = 1;
     348        *pcyBlock = 1;
     349        return 1;
     350
     351    case SVGA3D_LUMINANCE4_ALPHA4:
     352        *pcxBlock = 1;
     353        *pcyBlock = 1;
     354        return 1;
     355
     356    case SVGA3D_LUMINANCE16:
     357        *pcxBlock = 1;
     358        *pcyBlock = 1;
     359        return 2;
     360
     361    case SVGA3D_LUMINANCE8_ALPHA8:
     362        *pcxBlock = 1;
     363        *pcyBlock = 1;
     364        return 2;
     365
     366    case SVGA3D_DXT1:
     367        *pcxBlock = 4;
     368        *pcyBlock = 4;
     369        return 8;
     370
     371    case SVGA3D_DXT2:
     372        *pcxBlock = 4;
     373        *pcyBlock = 4;
     374        return 16;
     375
     376    case SVGA3D_DXT3:
     377        *pcxBlock = 4;
     378        *pcyBlock = 4;
     379        return 16;
     380
     381    case SVGA3D_DXT4:
     382        *pcxBlock = 4;
     383        *pcyBlock = 4;
     384        return 16;
     385
     386    case SVGA3D_DXT5:
     387        *pcxBlock = 4;
     388        *pcyBlock = 4;
     389        return 16;
     390
     391    case SVGA3D_BUMPU8V8:
     392        *pcxBlock = 1;
     393        *pcyBlock = 1;
     394        return 2;
     395
     396    case SVGA3D_BUMPL6V5U5:
     397        *pcxBlock = 1;
     398        *pcyBlock = 1;
     399        return 2;
     400
     401    case SVGA3D_BUMPX8L8V8U8:
     402        *pcxBlock = 1;
     403        *pcyBlock = 1;
     404        return 4;
     405
     406    case SVGA3D_FORMAT_DEAD1:
     407        *pcxBlock = 1;
     408        *pcyBlock = 1;
     409        return 3;
     410
     411    case SVGA3D_ARGB_S10E5:
     412        *pcxBlock = 1;
     413        *pcyBlock = 1;
     414        return 8;
     415
     416    case SVGA3D_ARGB_S23E8:
     417        *pcxBlock = 1;
     418        *pcyBlock = 1;
     419        return 16;
     420
     421    case SVGA3D_A2R10G10B10:
     422        *pcxBlock = 1;
     423        *pcyBlock = 1;
     424        return 4;
     425
     426    case SVGA3D_V8U8:
     427        *pcxBlock = 1;
     428        *pcyBlock = 1;
     429        return 2;
     430
     431    case SVGA3D_Q8W8V8U8:
     432        *pcxBlock = 1;
     433        *pcyBlock = 1;
     434        return 4;
     435
     436    case SVGA3D_CxV8U8:
     437        *pcxBlock = 1;
     438        *pcyBlock = 1;
     439        return 2;
     440
     441    case SVGA3D_X8L8V8U8:
     442        *pcxBlock = 1;
     443        *pcyBlock = 1;
     444        return 4;
     445
     446    case SVGA3D_A2W10V10U10:
     447        *pcxBlock = 1;
     448        *pcyBlock = 1;
     449        return 4;
     450
     451    case SVGA3D_ALPHA8:
     452        *pcxBlock = 1;
     453        *pcyBlock = 1;
     454        return 1;
     455
     456    case SVGA3D_R_S10E5:
     457        *pcxBlock = 1;
     458        *pcyBlock = 1;
     459        return 2;
     460
     461    case SVGA3D_R_S23E8:
     462        *pcxBlock = 1;
     463        *pcyBlock = 1;
     464        return 4;
     465
     466    case SVGA3D_RG_S10E5:
     467        *pcxBlock = 1;
     468        *pcyBlock = 1;
     469        return 4;
     470
     471    case SVGA3D_RG_S23E8:
     472        *pcxBlock = 1;
     473        *pcyBlock = 1;
     474        return 8;
     475
     476    case SVGA3D_BUFFER:
     477        *pcxBlock = 1;
     478        *pcyBlock = 1;
     479        return 1;
     480
    312481    case SVGA3D_Z_D24X8:
    313     case SVGA3D_Z_DF24:
    314     case SVGA3D_Z_D24S8_INT:
    315         *pcxBlock = 1;
    316         *pcyBlock = 1;
    317         return 4;
    318 
    319     case SVGA3D_Z_D16:
    320     case SVGA3D_Z_DF16:
    321     case SVGA3D_Z_D15S1:
    322         *pcxBlock = 1;
    323         *pcyBlock = 1;
    324         return 2;
    325 
    326     case SVGA3D_LUMINANCE8:
    327     case SVGA3D_LUMINANCE4_ALPHA4:
    328         *pcxBlock = 1;
    329         *pcyBlock = 1;
    330         return 1;
    331 
    332     case SVGA3D_LUMINANCE16:
    333     case SVGA3D_LUMINANCE8_ALPHA8:
    334         *pcxBlock = 1;
    335         *pcyBlock = 1;
    336         return 2;
    337 
    338     case SVGA3D_DXT1:
    339         *pcxBlock = 4;
    340         *pcyBlock = 4;
    341         return 8;
    342 
    343     case SVGA3D_DXT2:
    344     case SVGA3D_DXT3:
    345     case SVGA3D_DXT4:
    346     case SVGA3D_DXT5:
    347         *pcxBlock = 4;
    348         *pcyBlock = 4;
    349         return 16;
    350 
    351     case SVGA3D_BUMPU8V8:
    352     case SVGA3D_BUMPL6V5U5:
    353         *pcxBlock = 1;
    354         *pcyBlock = 1;
    355         return 2;
    356 
    357     case SVGA3D_BUMPX8L8V8U8:
    358     case SVGA3D_Q8W8V8U8:
    359         *pcxBlock = 1;
    360         *pcyBlock = 1;
    361         return 4;
    362 
    363     case SVGA3D_V8U8:
    364     case SVGA3D_CxV8U8:
    365         *pcxBlock = 1;
    366         *pcyBlock = 1;
    367         return 2;
    368 
    369     case SVGA3D_X8L8V8U8:
    370     case SVGA3D_A2W10V10U10:
    371         *pcxBlock = 1;
    372         *pcyBlock = 1;
    373         return 4;
    374 
    375     case SVGA3D_ARGB_S10E5:   /* 16-bit floating-point ARGB */
    376         *pcxBlock = 1;
    377         *pcyBlock = 1;
    378         return 8;
    379     case SVGA3D_ARGB_S23E8:   /* 32-bit floating-point ARGB */
    380         *pcxBlock = 1;
    381         *pcyBlock = 1;
    382         return 16;
    383 
    384     case SVGA3D_A2R10G10B10:
    385         *pcxBlock = 1;
    386         *pcyBlock = 1;
    387         return 4;
    388 
    389     case SVGA3D_ALPHA8:
    390         *pcxBlock = 1;
    391         *pcyBlock = 1;
    392         return 1;
    393 
    394     case SVGA3D_R_S10E5:
    395         *pcxBlock = 1;
    396         *pcyBlock = 1;
    397         return 2;
    398 
    399     case SVGA3D_R_S23E8:
    400     case SVGA3D_RG_S10E5:
    401         *pcxBlock = 1;
    402         *pcyBlock = 1;
    403         return 4;
    404 
    405     case SVGA3D_RG_S23E8:
    406         *pcxBlock = 1;
    407         *pcyBlock = 1;
    408         return 8;
    409 
    410     /*
    411      * Any surface can be used as a buffer object, but SVGA3D_BUFFER is
    412      * the most efficient format to use when creating new surfaces
    413      * expressly for index or vertex data.
    414      */
    415     case SVGA3D_BUFFER:
    416         *pcxBlock = 1;
    417         *pcyBlock = 1;
    418         return 1;
     482        *pcxBlock = 1;
     483        *pcyBlock = 1;
     484        return 4;
     485
     486    case SVGA3D_V16U16:
     487        *pcxBlock = 1;
     488        *pcyBlock = 1;
     489        return 4;
     490
     491    case SVGA3D_G16R16:
     492        *pcxBlock = 1;
     493        *pcyBlock = 1;
     494        return 4;
     495
     496    case SVGA3D_A16B16G16R16:
     497        *pcxBlock = 1;
     498        *pcyBlock = 1;
     499        return 8;
    419500
    420501    case SVGA3D_UYVY:
     
    428509        return 4;
    429510
    430     case SVGA3D_V16U16:
    431         *pcxBlock = 1;
    432         *pcyBlock = 1;
    433         return 4;
    434 
    435     case SVGA3D_G16R16:
    436         *pcxBlock = 1;
    437         *pcyBlock = 1;
    438         return 4;
    439     case SVGA3D_A16B16G16R16:
    440         *pcxBlock = 1;
    441         *pcyBlock = 1;
    442         return 8;
     511    case SVGA3D_NV12:
     512        *pcxBlock = 2;
     513        *pcyBlock = 2;
     514        return 6;
     515
     516    case SVGA3D_FORMAT_DEAD2:
     517        *pcxBlock = 1;
     518        *pcyBlock = 1;
     519        return 4;
     520
     521    case SVGA3D_R32G32B32A32_TYPELESS:
     522        *pcxBlock = 1;
     523        *pcyBlock = 1;
     524        return 16;
     525
     526    case SVGA3D_R32G32B32A32_UINT:
     527        *pcxBlock = 1;
     528        *pcyBlock = 1;
     529        return 16;
     530
     531    case SVGA3D_R32G32B32A32_SINT:
     532        *pcxBlock = 1;
     533        *pcyBlock = 1;
     534        return 16;
     535
     536    case SVGA3D_R32G32B32_TYPELESS:
     537        *pcxBlock = 1;
     538        *pcyBlock = 1;
     539        return 12;
     540
     541    case SVGA3D_R32G32B32_FLOAT:
     542        *pcxBlock = 1;
     543        *pcyBlock = 1;
     544        return 12;
     545
     546    case SVGA3D_R32G32B32_UINT:
     547        *pcxBlock = 1;
     548        *pcyBlock = 1;
     549        return 12;
     550
     551    case SVGA3D_R32G32B32_SINT:
     552        *pcxBlock = 1;
     553        *pcyBlock = 1;
     554        return 12;
     555
     556    case SVGA3D_R16G16B16A16_TYPELESS:
     557        *pcxBlock = 1;
     558        *pcyBlock = 1;
     559        return 8;
     560
     561    case SVGA3D_R16G16B16A16_UINT:
     562        *pcxBlock = 1;
     563        *pcyBlock = 1;
     564        return 8;
     565
     566    case SVGA3D_R16G16B16A16_SNORM:
     567        *pcxBlock = 1;
     568        *pcyBlock = 1;
     569        return 8;
     570
     571    case SVGA3D_R16G16B16A16_SINT:
     572        *pcxBlock = 1;
     573        *pcyBlock = 1;
     574        return 8;
     575
     576    case SVGA3D_R32G32_TYPELESS:
     577        *pcxBlock = 1;
     578        *pcyBlock = 1;
     579        return 8;
     580
     581    case SVGA3D_R32G32_UINT:
     582        *pcxBlock = 1;
     583        *pcyBlock = 1;
     584        return 8;
     585
     586    case SVGA3D_R32G32_SINT:
     587        *pcxBlock = 1;
     588        *pcyBlock = 1;
     589        return 8;
     590
     591    case SVGA3D_R32G8X24_TYPELESS:
     592        *pcxBlock = 1;
     593        *pcyBlock = 1;
     594        return 8;
     595
     596    case SVGA3D_D32_FLOAT_S8X24_UINT:
     597        *pcxBlock = 1;
     598        *pcyBlock = 1;
     599        return 8;
     600
     601    case SVGA3D_R32_FLOAT_X8X24:
     602        *pcxBlock = 1;
     603        *pcyBlock = 1;
     604        return 8;
     605
     606    case SVGA3D_X32_G8X24_UINT:
     607        *pcxBlock = 1;
     608        *pcyBlock = 1;
     609        return 8;
     610
     611    case SVGA3D_R10G10B10A2_TYPELESS:
     612        *pcxBlock = 1;
     613        *pcyBlock = 1;
     614        return 4;
     615
     616    case SVGA3D_R10G10B10A2_UINT:
     617        *pcxBlock = 1;
     618        *pcyBlock = 1;
     619        return 4;
     620
     621    case SVGA3D_R11G11B10_FLOAT:
     622        *pcxBlock = 1;
     623        *pcyBlock = 1;
     624        return 4;
     625
     626    case SVGA3D_R8G8B8A8_TYPELESS:
     627        *pcxBlock = 1;
     628        *pcyBlock = 1;
     629        return 4;
     630
    443631    case SVGA3D_R8G8B8A8_UNORM:
     632        *pcxBlock = 1;
     633        *pcyBlock = 1;
     634        return 4;
     635
     636    case SVGA3D_R8G8B8A8_UNORM_SRGB:
     637        *pcxBlock = 1;
     638        *pcyBlock = 1;
     639        return 4;
     640
     641    case SVGA3D_R8G8B8A8_UINT:
     642        *pcxBlock = 1;
     643        *pcyBlock = 1;
     644        return 4;
     645
     646    case SVGA3D_R8G8B8A8_SINT:
     647        *pcxBlock = 1;
     648        *pcyBlock = 1;
     649        return 4;
     650
     651    case SVGA3D_R16G16_TYPELESS:
     652        *pcxBlock = 1;
     653        *pcyBlock = 1;
     654        return 4;
     655
     656    case SVGA3D_R16G16_UINT:
     657        *pcxBlock = 1;
     658        *pcyBlock = 1;
     659        return 4;
     660
     661    case SVGA3D_R16G16_SINT:
     662        *pcxBlock = 1;
     663        *pcyBlock = 1;
     664        return 4;
     665
     666    case SVGA3D_R32_TYPELESS:
     667        *pcxBlock = 1;
     668        *pcyBlock = 1;
     669        return 4;
     670
     671    case SVGA3D_D32_FLOAT:
     672        *pcxBlock = 1;
     673        *pcyBlock = 1;
     674        return 4;
     675
     676    case SVGA3D_R32_UINT:
     677        *pcxBlock = 1;
     678        *pcyBlock = 1;
     679        return 4;
     680
     681    case SVGA3D_R32_SINT:
     682        *pcxBlock = 1;
     683        *pcyBlock = 1;
     684        return 4;
     685
     686    case SVGA3D_R24G8_TYPELESS:
     687        *pcxBlock = 1;
     688        *pcyBlock = 1;
     689        return 4;
     690
     691    case SVGA3D_D24_UNORM_S8_UINT:
     692        *pcxBlock = 1;
     693        *pcyBlock = 1;
     694        return 4;
     695
     696    case SVGA3D_R24_UNORM_X8:
     697        *pcxBlock = 1;
     698        *pcyBlock = 1;
     699        return 4;
     700
     701    case SVGA3D_X24_G8_UINT:
     702        *pcxBlock = 1;
     703        *pcyBlock = 1;
     704        return 4;
     705
     706    case SVGA3D_R8G8_TYPELESS:
     707        *pcxBlock = 1;
     708        *pcyBlock = 1;
     709        return 2;
     710
     711    case SVGA3D_R8G8_UNORM:
     712        *pcxBlock = 1;
     713        *pcyBlock = 1;
     714        return 2;
     715
     716    case SVGA3D_R8G8_UINT:
     717        *pcxBlock = 1;
     718        *pcyBlock = 1;
     719        return 2;
     720
     721    case SVGA3D_R8G8_SINT:
     722        *pcxBlock = 1;
     723        *pcyBlock = 1;
     724        return 2;
     725
     726    case SVGA3D_R16_TYPELESS:
     727        *pcxBlock = 1;
     728        *pcyBlock = 1;
     729        return 2;
     730
     731    case SVGA3D_R16_UNORM:
     732        *pcxBlock = 1;
     733        *pcyBlock = 1;
     734        return 2;
     735
     736    case SVGA3D_R16_UINT:
     737        *pcxBlock = 1;
     738        *pcyBlock = 1;
     739        return 2;
     740
     741    case SVGA3D_R16_SNORM:
     742        *pcxBlock = 1;
     743        *pcyBlock = 1;
     744        return 2;
     745
     746    case SVGA3D_R16_SINT:
     747        *pcxBlock = 1;
     748        *pcyBlock = 1;
     749        return 2;
     750
     751    case SVGA3D_R8_TYPELESS:
     752        *pcxBlock = 1;
     753        *pcyBlock = 1;
     754        return 1;
     755
     756    case SVGA3D_R8_UNORM:
     757        *pcxBlock = 1;
     758        *pcyBlock = 1;
     759        return 1;
     760
     761    case SVGA3D_R8_UINT:
     762        *pcxBlock = 1;
     763        *pcyBlock = 1;
     764        return 1;
     765
     766    case SVGA3D_R8_SNORM:
     767        *pcxBlock = 1;
     768        *pcyBlock = 1;
     769        return 1;
     770
     771    case SVGA3D_R8_SINT:
     772        *pcxBlock = 1;
     773        *pcyBlock = 1;
     774        return 1;
     775
     776    case SVGA3D_P8:
     777        *pcxBlock = 1;
     778        *pcyBlock = 1;
     779        return 1;
     780
     781    case SVGA3D_R9G9B9E5_SHAREDEXP:
     782        *pcxBlock = 1;
     783        *pcyBlock = 1;
     784        return 4;
     785
     786    case SVGA3D_R8G8_B8G8_UNORM:
     787        *pcxBlock = 2;
     788        *pcyBlock = 1;
     789        return 4;
     790
     791    case SVGA3D_G8R8_G8B8_UNORM:
     792        *pcxBlock = 2;
     793        *pcyBlock = 1;
     794        return 4;
     795
     796    case SVGA3D_BC1_TYPELESS:
     797        *pcxBlock = 4;
     798        *pcyBlock = 4;
     799        return 8;
     800
     801    case SVGA3D_BC1_UNORM_SRGB:
     802        *pcxBlock = 4;
     803        *pcyBlock = 4;
     804        return 8;
     805
     806    case SVGA3D_BC2_TYPELESS:
     807        *pcxBlock = 4;
     808        *pcyBlock = 4;
     809        return 16;
     810
     811    case SVGA3D_BC2_UNORM_SRGB:
     812        *pcxBlock = 4;
     813        *pcyBlock = 4;
     814        return 16;
     815
     816    case SVGA3D_BC3_TYPELESS:
     817        *pcxBlock = 4;
     818        *pcyBlock = 4;
     819        return 16;
     820
     821    case SVGA3D_BC3_UNORM_SRGB:
     822        *pcxBlock = 4;
     823        *pcyBlock = 4;
     824        return 16;
     825
     826    case SVGA3D_BC4_TYPELESS:
     827        *pcxBlock = 4;
     828        *pcyBlock = 4;
     829        return 8;
     830
     831    case SVGA3D_ATI1:
     832        *pcxBlock = 4;
     833        *pcyBlock = 4;
     834        return 8;
     835
     836    case SVGA3D_BC4_SNORM:
     837        *pcxBlock = 4;
     838        *pcyBlock = 4;
     839        return 8;
     840
     841    case SVGA3D_BC5_TYPELESS:
     842        *pcxBlock = 4;
     843        *pcyBlock = 4;
     844        return 16;
     845
     846    case SVGA3D_ATI2:
     847        *pcxBlock = 4;
     848        *pcyBlock = 4;
     849        return 16;
     850
     851    case SVGA3D_BC5_SNORM:
     852        *pcxBlock = 4;
     853        *pcyBlock = 4;
     854        return 16;
     855
     856    case SVGA3D_R10G10B10_XR_BIAS_A2_UNORM:
     857        *pcxBlock = 1;
     858        *pcyBlock = 1;
     859        return 4;
     860
     861    case SVGA3D_B8G8R8A8_TYPELESS:
     862        *pcxBlock = 1;
     863        *pcyBlock = 1;
     864        return 4;
     865
     866    case SVGA3D_B8G8R8A8_UNORM_SRGB:
     867        *pcxBlock = 1;
     868        *pcyBlock = 1;
     869        return 4;
     870
     871    case SVGA3D_B8G8R8X8_TYPELESS:
     872        *pcxBlock = 1;
     873        *pcyBlock = 1;
     874        return 4;
     875
     876    case SVGA3D_B8G8R8X8_UNORM_SRGB:
     877        *pcxBlock = 1;
     878        *pcyBlock = 1;
     879        return 4;
     880
     881    case SVGA3D_Z_DF16:
     882        *pcxBlock = 1;
     883        *pcyBlock = 1;
     884        return 2;
     885
     886    case SVGA3D_Z_DF24:
     887        *pcxBlock = 1;
     888        *pcyBlock = 1;
     889        return 4;
     890
     891    case SVGA3D_Z_D24S8_INT:
     892        *pcxBlock = 1;
     893        *pcyBlock = 1;
     894        return 4;
     895
     896    case SVGA3D_YV12:
     897        *pcxBlock = 2;
     898        *pcyBlock = 2;
     899        return 6;
     900
     901    case SVGA3D_R32G32B32A32_FLOAT:
     902        *pcxBlock = 1;
     903        *pcyBlock = 1;
     904        return 16;
     905
     906    case SVGA3D_R16G16B16A16_FLOAT:
     907        *pcxBlock = 1;
     908        *pcyBlock = 1;
     909        return 8;
     910
     911    case SVGA3D_R16G16B16A16_UNORM:
     912        *pcxBlock = 1;
     913        *pcyBlock = 1;
     914        return 8;
     915
     916    case SVGA3D_R32G32_FLOAT:
     917        *pcxBlock = 1;
     918        *pcyBlock = 1;
     919        return 8;
     920
     921    case SVGA3D_R10G10B10A2_UNORM:
     922        *pcxBlock = 1;
     923        *pcyBlock = 1;
     924        return 4;
     925
    444926    case SVGA3D_R8G8B8A8_SNORM:
    445927        *pcxBlock = 1;
    446928        *pcyBlock = 1;
    447929        return 4;
     930
     931    case SVGA3D_R16G16_FLOAT:
     932        *pcxBlock = 1;
     933        *pcyBlock = 1;
     934        return 4;
     935
    448936    case SVGA3D_R16G16_UNORM:
     937        *pcxBlock = 1;
     938        *pcyBlock = 1;
     939        return 4;
     940
     941    case SVGA3D_R16G16_SNORM:
     942        *pcxBlock = 1;
     943        *pcyBlock = 1;
     944        return 4;
     945
     946    case SVGA3D_R32_FLOAT:
     947        *pcxBlock = 1;
     948        *pcyBlock = 1;
     949        return 4;
     950
     951    case SVGA3D_R8G8_SNORM:
     952        *pcxBlock = 1;
     953        *pcyBlock = 1;
     954        return 2;
     955
     956    case SVGA3D_R16_FLOAT:
     957        *pcxBlock = 1;
     958        *pcyBlock = 1;
     959        return 2;
     960
     961    case SVGA3D_D16_UNORM:
     962        *pcxBlock = 1;
     963        *pcyBlock = 1;
     964        return 2;
     965
     966    case SVGA3D_A8_UNORM:
     967        *pcxBlock = 1;
     968        *pcyBlock = 1;
     969        return 1;
     970
     971    case SVGA3D_BC1_UNORM:
     972        *pcxBlock = 4;
     973        *pcyBlock = 4;
     974        return 8;
     975
     976    case SVGA3D_BC2_UNORM:
     977        *pcxBlock = 4;
     978        *pcyBlock = 4;
     979        return 16;
     980
     981    case SVGA3D_BC3_UNORM:
     982        *pcxBlock = 4;
     983        *pcyBlock = 4;
     984        return 16;
     985
     986    case SVGA3D_B5G6R5_UNORM:
     987        *pcxBlock = 1;
     988        *pcyBlock = 1;
     989        return 2;
     990
     991    case SVGA3D_B5G5R5A1_UNORM:
     992        *pcxBlock = 1;
     993        *pcyBlock = 1;
     994        return 2;
     995
     996    case SVGA3D_B8G8R8A8_UNORM:
     997        *pcxBlock = 1;
     998        *pcyBlock = 1;
     999        return 4;
     1000
     1001    case SVGA3D_B8G8R8X8_UNORM:
     1002        *pcxBlock = 1;
     1003        *pcyBlock = 1;
     1004        return 4;
     1005
     1006    case SVGA3D_BC4_UNORM:
     1007        *pcxBlock = 4;
     1008        *pcyBlock = 4;
     1009        return 8;
     1010
     1011    case SVGA3D_BC5_UNORM:
     1012        *pcxBlock = 4;
     1013        *pcyBlock = 4;
     1014        return 16;
     1015
     1016    case SVGA3D_B4G4R4A4_UNORM:
     1017        *pcxBlock = 1;
     1018        *pcyBlock = 1;
     1019        return 2;
     1020
     1021    case SVGA3D_BC6H_TYPELESS:
     1022        *pcxBlock = 4;
     1023        *pcyBlock = 4;
     1024        return 16;
     1025
     1026    case SVGA3D_BC6H_UF16:
     1027        *pcxBlock = 4;
     1028        *pcyBlock = 4;
     1029        return 16;
     1030
     1031    case SVGA3D_BC6H_SF16:
     1032        *pcxBlock = 4;
     1033        *pcyBlock = 4;
     1034        return 16;
     1035
     1036    case SVGA3D_BC7_TYPELESS:
     1037        *pcxBlock = 4;
     1038        *pcyBlock = 4;
     1039        return 16;
     1040
     1041    case SVGA3D_BC7_UNORM:
     1042        *pcxBlock = 4;
     1043        *pcyBlock = 4;
     1044        return 16;
     1045
     1046    case SVGA3D_BC7_UNORM_SRGB:
     1047        *pcxBlock = 4;
     1048        *pcyBlock = 4;
     1049        return 16;
     1050
     1051    case SVGA3D_AYUV:
    4491052        *pcxBlock = 1;
    4501053        *pcyBlock = 1;
  • trunk/src/VBox/Devices/Graphics/DevVGA-SVGA3d-win-dx.cpp

    r86905 r88787  
    3939#include "DevVGA-SVGA3d.h"
    4040#include "DevVGA-SVGA3d-internal.h"
     41#include "DevVGA-SVGA3d-dx-shader.h"
    4142
    4243#include <d3d11.h>
    4344
     45#define DX_RELEASE_ARRAY(a_Count, a_papArray) do { \
     46    for (uint32_t i = 0; i < (a_Count); ++i) \
     47        D3D_RELEASE((a_papArray)[i]); \
     48} while (0)
     49
     50typedef struct DXDEVICE
     51{
     52    ID3D11Device               *pDevice;               /* Device. */
     53    ID3D11DeviceContext        *pImmediateContext;     /* Corresponding context. */
     54    IDXGIFactory               *pDxgiFactory;          /* DXGI Factory. */
     55    D3D_FEATURE_LEVEL           FeatureLevel;
     56} DXDEVICE;
    4457
    4558/* What kind of resource has been created for the VMSVGA3D surface. */
     
    5265    VMSVGA3D_RESTYPE_CUBE_TEXTURE   = 4,
    5366    VMSVGA3D_RESTYPE_VOLUME_TEXTURE = 5,
    54     VMSVGA3D_RESTYPE_VERTEX_BUFFER  = 6,
    55     VMSVGA3D_RESTYPE_INDEX_BUFFER   = 7,
     67    VMSVGA3D_RESTYPE_BUFFER         = 6,
    5668} VMSVGA3DBACKRESTYPE;
    5769
    58 struct VMSVGA3DBACKENDSURFACE
     70typedef struct VMSVGA3DBACKENDSURFACE
    5971{
    6072    VMSVGA3DBACKRESTYPE enmResType;
     73    DXGI_FORMAT enmDxgiFormat;
    6174    union
    6275    {
     
    6982        struct
    7083        {
     84            ID3D11Texture2D    *pTexture;         /* The texture for the screen content. */
     85            ID3D11Texture2D    *pDynamicTexture;  /* For screen updates from memory. */ /** @todo One for all screens. */
     86            ID3D11Texture2D    *pStagingTexture;  /* For Reading the screen content. */ /** @todo One for all screens. */
    7187        } Texture;
     88        struct
     89        {
     90             ID3D11Buffer      *pBuffer;
     91        } Buffer;
    7292    } u;
    7393} VMSVGA3DBACKENDSURFACE;
     
    82102} VMSVGAHWSCREEN;
    83103
    84 struct VMSVGA3DBACKEND
     104
     105typedef struct DXELEMENTLAYOUT
     106{
     107    ID3D11InputLayout          *pElementLayout;
     108    uint32_t                    cElementDesc;
     109    D3D11_INPUT_ELEMENT_DESC    aElementDesc[32];
     110} DXELEMENTLAYOUT;
     111
     112typedef struct DXSHADER
     113{
     114    SVGA3dShaderType enmShaderType;
     115    union
     116    {
     117        ID3D11DeviceChild    *pShader;            /* All. */
     118        ID3D11VertexShader   *pVertexShader;      /* SVGA3D_SHADERTYPE_VS */
     119        ID3D11PixelShader    *pPixelShader;       /* SVGA3D_SHADERTYPE_PS */
     120        ID3D11GeometryShader *pGeometryShader;    /* SVGA3D_SHADERTYPE_GS */
     121        ID3D11HullShader     *pHullShader;        /* SVGA3D_SHADERTYPE_HS */
     122        ID3D11DomainShader   *pDomainShader;      /* SVGA3D_SHADERTYPE_DS */
     123        ID3D11ComputeShader  *pComputeShader;     /* SVGA3D_SHADERTYPE_CS */
     124    };
     125    void *pvDXBC;
     126    uint32_t cbDXBC;
     127} DXSHADER;
     128
     129typedef struct VMSVGA3DBACKENDDXCONTEXT
     130{
     131    DXDEVICE                    device;                /* Device for the this context operation. */
     132
     133    /* Arrays for Context-Object Tables. Number of entries depends on COTable size. */
     134    uint32_t                   cBlendState;            /* Number of entries in the papBlendState array. */
     135    uint32_t                   cDepthStencilState;     /* papDepthStencilState */
     136    uint32_t                   cSamplerState;          /* papSamplerState */
     137    uint32_t                   cRasterizerState;       /* papRasterizerState */
     138    uint32_t                   cElementLayout;         /* papElementLayout */
     139    uint32_t                   cRenderTargetView;      /* papRenderTargetView */
     140    uint32_t                   cDepthStencilView;      /* papDepthStencilView */
     141    uint32_t                   cShaderResourceView;    /* papShaderResourceView */
     142    uint32_t                   cQuery;                 /* papQuery */
     143    uint32_t                   cShader;                /* papShader */
     144    ID3D11BlendState         **papBlendState;
     145    ID3D11DepthStencilState  **papDepthStencilState;
     146    ID3D11SamplerState       **papSamplerState;
     147    ID3D11RasterizerState    **papRasterizerState;
     148    DXELEMENTLAYOUT           *paElementLayout;
     149    ID3D11RenderTargetView   **papRenderTargetView;
     150    ID3D11DepthStencilView   **papDepthStencilView;
     151    ID3D11ShaderResourceView **papShaderResourceView;
     152    ID3D11Query              **papQuery;
     153    DXSHADER                 *paShader;
     154} VMSVGA3DBACKENDDXCONTEXT;
     155
     156typedef struct VMSVGA3DBACKEND
    85157{
    86158    RTLDRMOD                    hD3D11;
     
    98170    switch (format)
    99171    {
    100         /** @todo More formats required? */
     172        /** @todo More formats. */
    101173        case SVGA3D_X8R8G8B8:                   return DXGI_FORMAT_B8G8R8A8_UNORM;
    102174        case SVGA3D_A8R8G8B8:                   return DXGI_FORMAT_B8G8R8A8_UNORM;
     175        case SVGA3D_B8G8R8X8_UNORM:             return DXGI_FORMAT_B8G8R8A8_UNORM;
    103176        default:
    104177            AssertFailed();
     
    486559        case SVGA3D_DEVCAP_DXFMT_BC4_UNORM:                     return SVGA3D_BC4_UNORM;
    487560        case SVGA3D_DEVCAP_DXFMT_BC5_UNORM:                     return SVGA3D_BC5_UNORM;
     561        case SVGA3D_DEVCAP_DXFMT_BC6H_TYPELESS:                 return SVGA3D_BC6H_TYPELESS;
     562        case SVGA3D_DEVCAP_DXFMT_BC6H_UF16:                     return SVGA3D_BC6H_UF16;
     563        case SVGA3D_DEVCAP_DXFMT_BC6H_SF16:                     return SVGA3D_BC6H_SF16;
     564        case SVGA3D_DEVCAP_DXFMT_BC7_TYPELESS:                  return SVGA3D_BC7_TYPELESS;
     565        case SVGA3D_DEVCAP_DXFMT_BC7_UNORM:                     return SVGA3D_BC7_UNORM;
     566        case SVGA3D_DEVCAP_DXFMT_BC7_UNORM_SRGB:                return SVGA3D_BC7_UNORM_SRGB;
    488567        default:
    489568            AssertFailed();
     
    557636        }
    558637        else
    559             rc = VERR_NOT_SUPPORTED;
     638            AssertFailedStmt(rc = VERR_NOT_SUPPORTED);
    560639    }
    561640    else
    562641        rc = VERR_NOT_SUPPORTED;
    563642    return rc;
     643}
     644
     645
     646static int dxDeviceCreate(PVMSVGA3DBACKEND pBackend, DXDEVICE *pDevice)
     647{
     648    int rc = VINF_SUCCESS;
     649
     650    IDXGIAdapter *pAdapter = NULL; /* Default adapter. */
     651    static D3D_FEATURE_LEVEL const s_aFeatureLevels[] =
     652    {
     653        /// @todo Requires a Windows 8+ _SDKS: D3D_FEATURE_LEVEL_11_1,
     654        D3D_FEATURE_LEVEL_11_0
     655    };
     656    UINT Flags = D3D11_CREATE_DEVICE_BGRA_SUPPORT;
     657#ifdef DEBUG
     658    Flags |= D3D11_CREATE_DEVICE_DEBUG;
     659#endif
     660
     661    HRESULT hr = pBackend->pfnD3D11CreateDevice(pAdapter,
     662                                                D3D_DRIVER_TYPE_HARDWARE,
     663                                                NULL,
     664                                                Flags,
     665                                                s_aFeatureLevels,
     666                                                RT_ELEMENTS(s_aFeatureLevels),
     667                                                D3D11_SDK_VERSION,
     668                                                &pDevice->pDevice,
     669                                                &pDevice->FeatureLevel,
     670                                                &pDevice->pImmediateContext);
     671    if (SUCCEEDED(hr))
     672    {
     673        LogRel(("VMSVGA: Feature level %#x\n", pDevice->FeatureLevel));
     674
     675        IDXGIDevice *pDxgiDevice = 0;
     676        hr = pBackend->pDevice->QueryInterface(__uuidof(IDXGIDevice), (void**)&pDxgiDevice);
     677        if (SUCCEEDED(hr))
     678        {
     679            IDXGIAdapter *pDxgiAdapter = 0;
     680            hr = pDxgiDevice->GetParent(__uuidof(IDXGIAdapter), (void**)&pDxgiAdapter);
     681            if (SUCCEEDED(hr))
     682            {
     683                hr = pDxgiAdapter->GetParent(__uuidof(IDXGIFactory), (void**)&pDevice->pDxgiFactory);
     684                D3D_RELEASE(pDxgiAdapter);
     685            }
     686
     687            D3D_RELEASE(pDxgiDevice);
     688        }
     689    }
     690
     691    if (FAILED(hr))
     692        rc = VERR_NOT_SUPPORTED;
     693
     694    return rc;
     695}
     696
     697
     698static void dxDeviceDestroy(PVMSVGA3DBACKEND pBackend, DXDEVICE *pDevice)
     699{
     700    RT_NOREF(pBackend);
     701    D3D_RELEASE(pDevice->pDevice);
     702    D3D_RELEASE(pDevice->pImmediateContext);
     703    D3D_RELEASE(pDevice->pDxgiFactory);
     704    RT_ZERO(*pDevice);
     705}
     706
     707
     708/** @todo AssertCompile for types like D3D11_COMPARISON_FUNC and SVGA3dComparisonFunc */
     709static HRESULT dxBlendStateCreate(DXDEVICE *pDevice, SVGACOTableDXBlendStateEntry const *pEntry, ID3D11BlendState **pp)
     710{
     711    D3D11_BLEND_DESC BlendDesc;
     712    BlendDesc.AlphaToCoverageEnable = RT_BOOL(pEntry->alphaToCoverageEnable);
     713    BlendDesc.IndependentBlendEnable = RT_BOOL(pEntry->independentBlendEnable);
     714    for (int i = 0; i < SVGA3D_MAX_RENDER_TARGETS; ++i)
     715    {
     716        BlendDesc.RenderTarget[i].BlendEnable           = RT_BOOL(pEntry->perRT[i].blendEnable);
     717        BlendDesc.RenderTarget[i].SrcBlend              = (D3D11_BLEND)pEntry->perRT[i].srcBlend;
     718        BlendDesc.RenderTarget[i].DestBlend             = (D3D11_BLEND)pEntry->perRT[i].destBlend;
     719        BlendDesc.RenderTarget[i].BlendOp               = (D3D11_BLEND_OP)pEntry->perRT[i].blendOp;
     720        BlendDesc.RenderTarget[i].SrcBlendAlpha         = (D3D11_BLEND)pEntry->perRT[i].srcBlendAlpha;
     721        BlendDesc.RenderTarget[i].DestBlendAlpha        = (D3D11_BLEND)pEntry->perRT[i].destBlendAlpha;
     722        BlendDesc.RenderTarget[i].BlendOpAlpha          = (D3D11_BLEND_OP)pEntry->perRT[i].blendOpAlpha;
     723        BlendDesc.RenderTarget[i].RenderTargetWriteMask = pEntry->perRT[i].renderTargetWriteMask;
     724        /** @todo logicOpEnable and logicOp */
     725    }
     726
     727    HRESULT hr = pDevice->pDevice->CreateBlendState(&BlendDesc, pp);
     728    Assert(SUCCEEDED(hr));
     729    return hr;
     730}
     731
     732
     733static HRESULT dxDepthStencilStateCreate(DXDEVICE *pDevice, SVGACOTableDXDepthStencilEntry const *pEntry, ID3D11DepthStencilState **pp)
     734{
     735    D3D11_DEPTH_STENCIL_DESC desc;
     736    desc.DepthEnable                  = pEntry->depthEnable;
     737    desc.DepthWriteMask               = (D3D11_DEPTH_WRITE_MASK)pEntry->depthWriteMask;
     738    desc.DepthFunc                    = (D3D11_COMPARISON_FUNC)pEntry->depthFunc;
     739    desc.StencilEnable                = pEntry->stencilEnable;
     740    desc.StencilReadMask              = pEntry->stencilReadMask;
     741    desc.StencilWriteMask             = pEntry->stencilWriteMask;
     742    desc.FrontFace.StencilFailOp      = (D3D11_STENCIL_OP)pEntry->frontStencilFailOp;
     743    desc.FrontFace.StencilDepthFailOp = (D3D11_STENCIL_OP)pEntry->frontStencilDepthFailOp;
     744    desc.FrontFace.StencilPassOp      = (D3D11_STENCIL_OP)pEntry->frontStencilPassOp;
     745    desc.FrontFace.StencilFunc        = (D3D11_COMPARISON_FUNC)pEntry->frontStencilFunc;
     746    desc.BackFace.StencilFailOp       = (D3D11_STENCIL_OP)pEntry->backStencilFailOp;
     747    desc.BackFace.StencilDepthFailOp  = (D3D11_STENCIL_OP)pEntry->backStencilDepthFailOp;
     748    desc.BackFace.StencilPassOp       = (D3D11_STENCIL_OP)pEntry->backStencilPassOp;
     749    desc.BackFace.StencilFunc         = (D3D11_COMPARISON_FUNC)pEntry->backStencilFunc;
     750    /** @todo frontEnable, backEnable */
     751
     752    HRESULT hr = pDevice->pDevice->CreateDepthStencilState(&desc, pp);
     753    Assert(SUCCEEDED(hr));
     754    return hr;
     755}
     756
     757
     758static HRESULT dxSamplerStateCreate(DXDEVICE *pDevice, SVGACOTableDXSamplerEntry const *pEntry, ID3D11SamplerState **pp)
     759{
     760    D3D11_SAMPLER_DESC desc;
     761    desc.Filter         = (D3D11_FILTER)pEntry->filter;
     762    desc.AddressU       = (D3D11_TEXTURE_ADDRESS_MODE)pEntry->addressU;
     763    desc.AddressV       = (D3D11_TEXTURE_ADDRESS_MODE)pEntry->addressV;
     764    desc.AddressW       = (D3D11_TEXTURE_ADDRESS_MODE)pEntry->addressW;
     765    desc.MipLODBias     = pEntry->mipLODBias;
     766    desc.MaxAnisotropy  = RT_CLAMP(pEntry->maxAnisotropy, 1, 16); /* "Valid values are between 1 and 16" */
     767    desc.ComparisonFunc = (D3D11_COMPARISON_FUNC)pEntry->comparisonFunc;
     768    desc.BorderColor[0] = pEntry->borderColor.value[0];
     769    desc.BorderColor[1] = pEntry->borderColor.value[1];
     770    desc.BorderColor[2] = pEntry->borderColor.value[2];
     771    desc.BorderColor[3] = pEntry->borderColor.value[3];
     772    desc.MinLOD         = pEntry->minLOD;
     773    desc.MaxLOD         = pEntry->maxLOD;
     774
     775    HRESULT hr = pDevice->pDevice->CreateSamplerState(&desc, pp);
     776    Assert(SUCCEEDED(hr));
     777    return hr;
     778}
     779
     780
     781static HRESULT dxRasterizerStateCreate(DXDEVICE *pDevice, SVGACOTableDXRasterizerStateEntry const *pEntry, ID3D11RasterizerState **pp)
     782{
     783    D3D11_RASTERIZER_DESC desc;
     784    desc.FillMode              = (D3D11_FILL_MODE)pEntry->fillMode;
     785    desc.CullMode              = (D3D11_CULL_MODE)pEntry->cullMode;
     786    desc.FrontCounterClockwise = pEntry->frontCounterClockwise;
     787    /** provokingVertexLast */
     788    desc.DepthBias             = pEntry->depthBias;
     789    desc.DepthBiasClamp        = pEntry->depthBiasClamp;
     790    desc.SlopeScaledDepthBias  = pEntry->slopeScaledDepthBias;
     791    desc.DepthClipEnable       = pEntry->depthClipEnable;
     792    desc.ScissorEnable         = pEntry->scissorEnable;
     793    desc.MultisampleEnable     = pEntry->multisampleEnable;
     794    desc.AntialiasedLineEnable = pEntry->antialiasedLineEnable;
     795    /** @todo lineWidth lineStippleEnable lineStippleFactor lineStipplePattern forcedSampleCount */
     796
     797    HRESULT hr = pDevice->pDevice->CreateRasterizerState(&desc, pp);
     798    Assert(SUCCEEDED(hr));
     799    return hr;
     800}
     801
     802
     803static HRESULT dxRenderTargetViewCreate(DXDEVICE *pDevice, SVGACOTableDXRTViewEntry const *pEntry, VMSVGA3DBACKENDSURFACE *pBackendSurface, ID3D11RenderTargetView **pp)
     804{
     805    ID3D11Resource *pResource = pBackendSurface->u.Texture.pTexture;
     806
     807    D3D11_RENDER_TARGET_VIEW_DESC desc;
     808    RT_ZERO(desc);
     809    desc.Format = vmsvgaDXSurfaceFormat2Dxgi(pEntry->format);
     810    AssertReturn(desc.Format != DXGI_FORMAT_UNKNOWN, E_FAIL);
     811    switch (pEntry->resourceDimension)
     812    {
     813        case SVGA3D_RESOURCE_BUFFER:
     814            desc.ViewDimension = D3D11_RTV_DIMENSION_BUFFER;
     815            desc.Buffer.FirstElement = pEntry->desc.buffer.firstElement;
     816            desc.Buffer.NumElements = pEntry->desc.buffer.numElements;
     817            break;
     818        case SVGA3D_RESOURCE_TEXTURE1D:
     819            if (pEntry->desc.tex.arraySize <= 1)
     820            {
     821                desc.ViewDimension = D3D11_RTV_DIMENSION_TEXTURE1D;
     822                desc.Texture1D.MipSlice = pEntry->desc.tex.mipSlice;
     823            }
     824            else
     825            {
     826                desc.ViewDimension = D3D11_RTV_DIMENSION_TEXTURE1DARRAY;
     827                desc.Texture1DArray.MipSlice = pEntry->desc.tex.mipSlice;
     828                desc.Texture1DArray.FirstArraySlice = pEntry->desc.tex.firstArraySlice;
     829                desc.Texture1DArray.ArraySize = pEntry->desc.tex.arraySize;
     830            }
     831            break;
     832        case SVGA3D_RESOURCE_TEXTURE2D:
     833            if (pEntry->desc.tex.arraySize <= 1)
     834            {
     835                desc.ViewDimension = D3D11_RTV_DIMENSION_TEXTURE2D;
     836                desc.Texture2D.MipSlice = pEntry->desc.tex.mipSlice;
     837            }
     838            else
     839            {
     840                desc.ViewDimension = D3D11_RTV_DIMENSION_TEXTURE2DARRAY;
     841                desc.Texture2DArray.MipSlice = pEntry->desc.tex.mipSlice;
     842                desc.Texture2DArray.FirstArraySlice = pEntry->desc.tex.firstArraySlice;
     843                desc.Texture2DArray.ArraySize = pEntry->desc.tex.arraySize;
     844            }
     845            break;
     846        case SVGA3D_RESOURCE_TEXTURE3D:
     847            desc.ViewDimension = D3D11_RTV_DIMENSION_TEXTURE3D;
     848            desc.Texture3D.MipSlice = pEntry->desc.tex3D.mipSlice;
     849            desc.Texture3D.FirstWSlice = pEntry->desc.tex3D.firstW;
     850            desc.Texture3D.WSize = pEntry->desc.tex3D.wSize;
     851            break;
     852        case SVGA3D_RESOURCE_TEXTURECUBE:
     853            AssertFailed(); /** @todo test. Probably not applicable to a render target view. */
     854            desc.ViewDimension = D3D11_RTV_DIMENSION_TEXTURE2DARRAY;
     855            desc.Texture2DArray.MipSlice = pEntry->desc.tex.mipSlice;
     856            desc.Texture2DArray.FirstArraySlice = 0;
     857            desc.Texture2DArray.ArraySize = 6;
     858            break;
     859        case SVGA3D_RESOURCE_BUFFEREX:
     860            AssertFailed(); /** @todo test. Probably not applicable to a render target view. */
     861            desc.ViewDimension = D3D11_RTV_DIMENSION_BUFFER;
     862            desc.Buffer.FirstElement = pEntry->desc.buffer.firstElement;
     863            desc.Buffer.NumElements = pEntry->desc.buffer.numElements;
     864            break;
     865        default:
     866            ASSERT_GUEST_FAILED_RETURN(E_INVALIDARG);
     867    }
     868
     869    HRESULT hr = pDevice->pDevice->CreateRenderTargetView(pResource, &desc, pp);
     870    Assert(SUCCEEDED(hr));
     871    return hr;
     872}
     873
     874
     875static HRESULT dxShaderResourceViewCreate(DXDEVICE *pDevice, SVGACOTableDXSRViewEntry const *pEntry, VMSVGA3DBACKENDSURFACE *pBackendSurface, ID3D11ShaderResourceView **pp)
     876{
     877    ID3D11Resource *pResource = pBackendSurface->u.Texture.pTexture;
     878
     879    D3D11_SHADER_RESOURCE_VIEW_DESC desc;
     880    RT_ZERO(desc);
     881    desc.Format = vmsvgaDXSurfaceFormat2Dxgi(pEntry->format);
     882    AssertReturn(desc.Format != DXGI_FORMAT_UNKNOWN, E_FAIL);
     883
     884    switch (pEntry->resourceDimension)
     885    {
     886        case SVGA3D_RESOURCE_BUFFER:
     887            desc.ViewDimension = D3D11_SRV_DIMENSION_BUFFER;
     888            desc.Buffer.FirstElement = pEntry->desc.buffer.firstElement;
     889            desc.Buffer.NumElements = pEntry->desc.buffer.numElements;
     890            break;
     891        case SVGA3D_RESOURCE_TEXTURE1D:
     892            if (pEntry->desc.tex.arraySize <= 1)
     893            {
     894                desc.ViewDimension = D3D11_SRV_DIMENSION_TEXTURE1D;
     895                desc.Texture1D.MostDetailedMip = pEntry->desc.tex.mostDetailedMip;
     896                desc.Texture1D.MipLevels = pEntry->desc.tex.mipLevels;
     897            }
     898            else
     899            {
     900                desc.ViewDimension = D3D11_SRV_DIMENSION_TEXTURE1DARRAY;
     901                desc.Texture1DArray.MostDetailedMip = pEntry->desc.tex.mostDetailedMip;
     902                desc.Texture1DArray.MipLevels = pEntry->desc.tex.mipLevels;
     903                desc.Texture1DArray.FirstArraySlice = pEntry->desc.tex.firstArraySlice;
     904                desc.Texture1DArray.ArraySize = pEntry->desc.tex.arraySize;
     905            }
     906            break;
     907        case SVGA3D_RESOURCE_TEXTURE2D:
     908            if (pEntry->desc.tex.arraySize <= 1)
     909            {
     910                desc.ViewDimension = D3D11_SRV_DIMENSION_TEXTURE2D;
     911                desc.Texture2D.MostDetailedMip = pEntry->desc.tex.mostDetailedMip;
     912                desc.Texture2D.MipLevels = pEntry->desc.tex.mipLevels;
     913            }
     914            else
     915            {
     916                desc.ViewDimension = D3D11_SRV_DIMENSION_TEXTURE2DARRAY;
     917                desc.Texture2DArray.MostDetailedMip = pEntry->desc.tex.mostDetailedMip;
     918                desc.Texture2DArray.MipLevels = pEntry->desc.tex.mipLevels;
     919                desc.Texture2DArray.FirstArraySlice = pEntry->desc.tex.firstArraySlice;
     920                desc.Texture2DArray.ArraySize = pEntry->desc.tex.arraySize;
     921            }
     922            break;
     923        case SVGA3D_RESOURCE_TEXTURE3D:
     924            desc.ViewDimension = D3D11_SRV_DIMENSION_TEXTURE3D;
     925            desc.Texture3D.MostDetailedMip = pEntry->desc.tex.mostDetailedMip;
     926            desc.Texture3D.MipLevels = pEntry->desc.tex.mipLevels;
     927            break;
     928        case SVGA3D_RESOURCE_TEXTURECUBE:
     929            AssertFailed(); /** @todo test. */
     930            desc.ViewDimension = D3D11_SRV_DIMENSION_TEXTURECUBE;
     931            desc.TextureCube.MostDetailedMip = pEntry->desc.tex.mostDetailedMip;
     932            desc.TextureCube.MipLevels = pEntry->desc.tex.mipLevels;
     933            break;
     934        case SVGA3D_RESOURCE_BUFFEREX:
     935            AssertFailed(); /** @todo test. */
     936            desc.ViewDimension = D3D11_SRV_DIMENSION_BUFFEREX;
     937            desc.BufferEx.FirstElement = pEntry->desc.bufferex.firstElement;
     938            desc.BufferEx.NumElements = pEntry->desc.bufferex.numElements;
     939            desc.BufferEx.Flags = pEntry->desc.bufferex.flags;
     940            break;
     941        default:
     942            ASSERT_GUEST_FAILED_RETURN(E_INVALIDARG);
     943    }
     944
     945    HRESULT hr = pDevice->pDevice->CreateShaderResourceView(pResource, &desc, pp);
     946    Assert(SUCCEEDED(hr));
     947    return hr;
     948}
     949
     950
     951static HRESULT dxShaderCreate(DXDEVICE *pDevice, PVMSVGA3DSHADER pShader, DXSHADER *pDXShader)
     952{
     953    HRESULT hr = S_OK;
     954
     955    switch (pShader->type)
     956    {
     957        case SVGA3D_SHADERTYPE_VS:
     958            hr = pDevice->pDevice->CreateVertexShader(pDXShader->pvDXBC, pDXShader->cbDXBC, NULL, &pDXShader->pVertexShader);
     959            Assert(SUCCEEDED(hr));
     960            break;
     961        case SVGA3D_SHADERTYPE_PS:
     962            hr = pDevice->pDevice->CreatePixelShader(pDXShader->pvDXBC, pDXShader->cbDXBC, NULL, &pDXShader->pPixelShader);
     963            Assert(SUCCEEDED(hr));
     964            break;
     965        case SVGA3D_SHADERTYPE_GS:
     966        case SVGA3D_SHADERTYPE_HS:
     967        case SVGA3D_SHADERTYPE_DS:
     968        case SVGA3D_SHADERTYPE_CS:
     969        default:
     970            ASSERT_GUEST_FAILED_RETURN(E_INVALIDARG);
     971    }
     972
     973    return hr;
     974}
     975
     976
     977static void dxShaderSet(DXDEVICE *pDevice, PVMSVGA3DSHADER pShader, DXSHADER *pDXShader)
     978{
     979    switch (pShader->type)
     980    {
     981        case SVGA3D_SHADERTYPE_VS:
     982            pDevice->pImmediateContext->VSSetShader(pDXShader->pVertexShader, NULL, 0);
     983            break;
     984        case SVGA3D_SHADERTYPE_PS:
     985            pDevice->pImmediateContext->PSSetShader(pDXShader->pPixelShader, NULL, 0);
     986            break;
     987        case SVGA3D_SHADERTYPE_GS:
     988        case SVGA3D_SHADERTYPE_HS:
     989        case SVGA3D_SHADERTYPE_DS:
     990        case SVGA3D_SHADERTYPE_CS:
     991        default:
     992            ASSERT_GUEST_FAILED_RETURN_VOID();
     993    }
     994}
     995
     996
     997static void dxConstantBufferSet(DXDEVICE *pDevice, uint32_t slot, SVGA3dShaderType type, ID3D11Buffer *pConstantBuffer)
     998{
     999    switch (type)
     1000    {
     1001        case SVGA3D_SHADERTYPE_VS:
     1002            pDevice->pImmediateContext->VSSetConstantBuffers(slot, 1, &pConstantBuffer);
     1003            break;
     1004        case SVGA3D_SHADERTYPE_PS:
     1005            pDevice->pImmediateContext->PSSetConstantBuffers(slot, 1, &pConstantBuffer);
     1006            break;
     1007        case SVGA3D_SHADERTYPE_GS:
     1008        case SVGA3D_SHADERTYPE_HS:
     1009        case SVGA3D_SHADERTYPE_DS:
     1010        case SVGA3D_SHADERTYPE_CS:
     1011        default:
     1012            ASSERT_GUEST_FAILED_RETURN_VOID();
     1013    }
     1014}
     1015
     1016
     1017static void dxSamplerSet(DXDEVICE *pDevice, SVGA3dShaderType type, uint32_t startSampler, uint32_t cSampler, ID3D11SamplerState * const *papSampler)
     1018{
     1019    switch (type)
     1020    {
     1021        case SVGA3D_SHADERTYPE_VS:
     1022            pDevice->pImmediateContext->VSSetSamplers(startSampler, cSampler, papSampler);
     1023            break;
     1024        case SVGA3D_SHADERTYPE_PS:
     1025            pDevice->pImmediateContext->PSSetSamplers(startSampler, cSampler, papSampler);
     1026            break;
     1027        case SVGA3D_SHADERTYPE_GS:
     1028        case SVGA3D_SHADERTYPE_HS:
     1029        case SVGA3D_SHADERTYPE_DS:
     1030        case SVGA3D_SHADERTYPE_CS:
     1031        default:
     1032            ASSERT_GUEST_FAILED_RETURN_VOID();
     1033    }
     1034}
     1035
     1036
     1037static int vmsvga3dBackSurfaceCreateScreenTarget(PVMSVGA3DSTATE pState, PVMSVGA3DSURFACE pSurface)
     1038{
     1039    PVMSVGA3DBACKEND pBackend = pState->pBackend;
     1040    AssertReturn(pBackend, VERR_INVALID_STATE);
     1041    AssertReturn(pBackend->pDevice, VERR_INVALID_STATE);
     1042
     1043    /* Surface must have SCREEN_TARGET flag. */
     1044    ASSERT_GUEST_RETURN(RT_BOOL(pSurface->surfaceFlags & SVGA3D_SURFACE_SCREENTARGET), VERR_INVALID_PARAMETER);
     1045
     1046    if (VMSVGA3DSURFACE_HAS_HW_SURFACE(pSurface))
     1047    {
     1048        AssertFailed(); /* Should the function not be used like that? */
     1049        vmsvga3dBackSurfaceDestroy(pState, pSurface);
     1050    }
     1051
     1052    PVMSVGA3DBACKENDSURFACE pBackendSurface = (PVMSVGA3DBACKENDSURFACE)RTMemAllocZ(sizeof(VMSVGA3DBACKENDSURFACE));
     1053    AssertPtrReturn(pBackendSurface, VERR_NO_MEMORY);
     1054
     1055    D3D11_TEXTURE2D_DESC td;
     1056    RT_ZERO(td);
     1057    td.Width              = pSurface->paMipmapLevels[0].mipmapSize.width;
     1058    td.Height             = pSurface->paMipmapLevels[0].mipmapSize.height;
     1059    Assert(pSurface->cLevels == 1);
     1060    td.MipLevels          = 1;
     1061    td.ArraySize          = 1;
     1062    td.Format             = vmsvgaDXScreenTargetFormat2Dxgi(pSurface->format); // DXGI_FORMAT_B8G8R8A8_UNORM;
     1063    td.SampleDesc.Count   = 1;
     1064    td.SampleDesc.Quality = 0;
     1065    td.Usage              = D3D11_USAGE_DEFAULT;
     1066    td.BindFlags          = D3D11_BIND_RENDER_TARGET | D3D11_BIND_SHADER_RESOURCE;
     1067    td.CPUAccessFlags     = 0;
     1068    td.MiscFlags          = 0;
     1069
     1070    HRESULT hr = pBackend->pDevice->CreateTexture2D(&td, 0, &pBackendSurface->u.ScreenTarget.pTexture);
     1071    Assert(SUCCEEDED(hr));
     1072    if (SUCCEEDED(hr))
     1073    {
     1074        /* Map-able texture. */
     1075        td.Usage          = D3D11_USAGE_DYNAMIC;
     1076        td.BindFlags      = D3D11_BIND_SHADER_RESOURCE; /* Have to specify a supported flag, otherwise E_INVALIDARG will be returned. */
     1077        td.CPUAccessFlags = D3D11_CPU_ACCESS_WRITE;
     1078        td.MiscFlags      = 0;
     1079        hr = pBackend->pDevice->CreateTexture2D(&td, 0, &pBackendSurface->u.ScreenTarget.pDynamicTexture);
     1080        Assert(SUCCEEDED(hr));
     1081    }
     1082
     1083    if (SUCCEEDED(hr))
     1084    {
     1085        /* Staging texture. */
     1086        td.Usage          = D3D11_USAGE_STAGING;
     1087        td.BindFlags      = 0; /* No flags allowed. */
     1088        td.CPUAccessFlags = D3D11_CPU_ACCESS_READ;
     1089        td.MiscFlags      = 0;
     1090        hr = pBackend->pDevice->CreateTexture2D(&td, 0, &pBackendSurface->u.ScreenTarget.pStagingTexture);
     1091        Assert(SUCCEEDED(hr));
     1092    }
     1093
     1094    if (SUCCEEDED(hr))
     1095    {
     1096        /*
     1097         * Success.
     1098         */
     1099        pBackendSurface->enmResType = VMSVGA3D_RESTYPE_SCREEN_TARGET;
     1100        pBackendSurface->enmDxgiFormat = td.Format;
     1101        pSurface->pBackendSurface = pBackendSurface;
     1102        pSurface->idAssociatedContext = SVGA_ID_INVALID;
     1103        pSurface->fDirty = true;
     1104        return VINF_SUCCESS;
     1105    }
     1106
     1107    /* Failure. */
     1108    D3D_RELEASE(pBackendSurface->u.ScreenTarget.pStagingTexture);
     1109    D3D_RELEASE(pBackendSurface->u.ScreenTarget.pDynamicTexture);
     1110    D3D_RELEASE(pBackendSurface->u.ScreenTarget.pTexture);
     1111    RTMemFree(pBackendSurface);
     1112    return VERR_NO_MEMORY;
     1113}
     1114
     1115
     1116static int vmsvga3dBackSurfaceCreateRenderTarget(PVMSVGA3DSTATE p3dState, PVMSVGA3DDXCONTEXT pDXContext, PVMSVGA3DSURFACE pSurface)
     1117{
     1118    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     1119    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     1120
     1121    if (pSurface->pBackendSurface != NULL)
     1122    {
     1123        AssertFailed(); /** @todo Should the function not be used like that? */
     1124        vmsvga3dBackSurfaceDestroy(p3dState, pSurface);
     1125    }
     1126
     1127    /** @todo Various texture types. */
     1128
     1129    PVMSVGA3DBACKENDSURFACE pBackendSurface = (PVMSVGA3DBACKENDSURFACE)RTMemAllocZ(sizeof(VMSVGA3DBACKENDSURFACE));
     1130    AssertPtrReturn(pBackendSurface, VERR_NO_MEMORY);
     1131
     1132    D3D11_TEXTURE2D_DESC td;
     1133    RT_ZERO(td);
     1134    td.Width              = pSurface->paMipmapLevels[0].mipmapSize.width;
     1135    td.Height             = pSurface->paMipmapLevels[0].mipmapSize.height;
     1136    Assert(pSurface->cLevels == 1);
     1137    td.MipLevels          = 1;
     1138    td.ArraySize          = 1;
     1139    td.Format             = vmsvgaDXSurfaceFormat2Dxgi(pSurface->format); // DXGI_FORMAT_B8G8R8A8_UNORM;
     1140    AssertReturn(td.Format != DXGI_FORMAT_UNKNOWN, E_FAIL);
     1141    td.SampleDesc.Count   = 1;
     1142    td.SampleDesc.Quality = 0;
     1143    td.Usage              = D3D11_USAGE_DEFAULT;
     1144    td.BindFlags          = D3D11_BIND_RENDER_TARGET | D3D11_BIND_SHADER_RESOURCE;
     1145    td.CPUAccessFlags     = 0;
     1146    td.MiscFlags          = 0;
     1147
     1148    HRESULT hr = pDevice->pDevice->CreateTexture2D(&td, 0, &pBackendSurface->u.Texture.pTexture);
     1149    Assert(SUCCEEDED(hr));
     1150    if (SUCCEEDED(hr))
     1151    {
     1152        /* Map-able texture. */
     1153        td.Usage          = D3D11_USAGE_DYNAMIC;
     1154        td.BindFlags      = D3D11_BIND_SHADER_RESOURCE; /* Have to specify a supported flag, otherwise E_INVALIDARG will be returned. */
     1155        td.CPUAccessFlags = D3D11_CPU_ACCESS_WRITE;
     1156        td.MiscFlags      = 0;
     1157        hr = pDevice->pDevice->CreateTexture2D(&td, 0, &pBackendSurface->u.Texture.pDynamicTexture);
     1158        Assert(SUCCEEDED(hr));
     1159    }
     1160
     1161    if (SUCCEEDED(hr))
     1162    {
     1163        /* Staging texture. */
     1164        td.Usage          = D3D11_USAGE_STAGING;
     1165        td.BindFlags      = 0; /* No flags allowed. */
     1166        td.CPUAccessFlags = D3D11_CPU_ACCESS_READ;
     1167        td.MiscFlags      = 0;
     1168        hr = pDevice->pDevice->CreateTexture2D(&td, 0, &pBackendSurface->u.Texture.pStagingTexture);
     1169        Assert(SUCCEEDED(hr));
     1170    }
     1171
     1172    if (SUCCEEDED(hr))
     1173    {
     1174        /*
     1175         * Success.
     1176         */
     1177        pBackendSurface->enmResType = VMSVGA3D_RESTYPE_TEXTURE;
     1178        pBackendSurface->enmDxgiFormat = td.Format;
     1179        pSurface->pBackendSurface = pBackendSurface;
     1180        pSurface->idAssociatedContext = pDXContext->cid;
     1181        pSurface->fDirty = true;
     1182        return VINF_SUCCESS;
     1183    }
     1184
     1185    /* Failure. */
     1186    D3D_RELEASE(pBackendSurface->u.Texture.pStagingTexture);
     1187    D3D_RELEASE(pBackendSurface->u.Texture.pDynamicTexture);
     1188    D3D_RELEASE(pBackendSurface->u.Texture.pTexture);
     1189    RTMemFree(pBackendSurface);
     1190    return VERR_NO_MEMORY;
     1191}
     1192
     1193
     1194static int vmsvga3dBackSurfaceCreateTexture(PVMSVGA3DSTATE p3dState, PVMSVGA3DDXCONTEXT pDXContext, PVMSVGA3DSURFACE pSurface)
     1195{
     1196    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     1197    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     1198
     1199    if (pSurface->pBackendSurface != NULL)
     1200    {
     1201        AssertFailed(); /** @todo Should the function not be used like that? */
     1202        vmsvga3dBackSurfaceDestroy(p3dState, pSurface);
     1203    }
     1204
     1205    /** @todo Various texture types. */
     1206
     1207    PVMSVGA3DBACKENDSURFACE pBackendSurface = (PVMSVGA3DBACKENDSURFACE)RTMemAllocZ(sizeof(VMSVGA3DBACKENDSURFACE));
     1208    AssertPtrReturn(pBackendSurface, VERR_NO_MEMORY);
     1209
     1210    RTMemFree(pBackendSurface);
     1211    return VERR_NOT_IMPLEMENTED;
     1212}
     1213
     1214
     1215static int vmsvga3dBackSurfaceCreateBuffer(PVMSVGA3DSTATE p3dState, PVMSVGA3DDXCONTEXT pDXContext, PVMSVGA3DSURFACE pSurface)
     1216{
     1217    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     1218    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     1219
     1220    /* Buffers should be created as such. */
     1221    AssertReturn(RT_BOOL(pSurface->surfaceFlags & (  SVGA3D_SURFACE_HINT_INDEXBUFFER
     1222                                                   | SVGA3D_SURFACE_HINT_VERTEXBUFFER
     1223                                                   | SVGA3D_SURFACE_BIND_VERTEX_BUFFER
     1224                                                   | SVGA3D_SURFACE_BIND_INDEX_BUFFER
     1225                                                   /// @todo only for constant buffers| SVGA3D_SURFACE_BIND_CONSTANT_BUFFER
     1226                                                   //| SVGA3D_SURFACE_BIND_STREAM_OUTPUT
     1227                        )), VERR_INVALID_PARAMETER);
     1228
     1229    if (pSurface->pBackendSurface != NULL)
     1230    {
     1231        AssertFailed(); /** @todo Should the function not be used like that? */
     1232        vmsvga3dBackSurfaceDestroy(p3dState, pSurface);
     1233    }
     1234
     1235    PVMSVGA3DBACKENDSURFACE pBackendSurface = (PVMSVGA3DBACKENDSURFACE)RTMemAllocZ(sizeof(VMSVGA3DBACKENDSURFACE));
     1236    AssertPtrReturn(pBackendSurface, VERR_NO_MEMORY);
     1237
     1238    D3D11_BUFFER_DESC bd;
     1239    RT_ZERO(bd);
     1240    bd.ByteWidth = pSurface->paMipmapLevels[0].cbSurface;
     1241    bd.Usage = D3D11_USAGE_DYNAMIC;
     1242    bd.BindFlags           = D3D11_BIND_VERTEX_BUFFER
     1243                           | D3D11_BIND_INDEX_BUFFER
     1244                           //| D3D11_BIND_CONSTANT_BUFFER
     1245                           //| D3D11_BIND_STREAM_OUTPUT
     1246                           ;
     1247    bd.CPUAccessFlags      = D3D11_CPU_ACCESS_WRITE;
     1248    bd.MiscFlags           = 0;
     1249    bd.StructureByteStride = 0;
     1250
     1251    HRESULT hr = pDevice->pDevice->CreateBuffer(&bd, 0, &pBackendSurface->u.Buffer.pBuffer);
     1252    if (SUCCEEDED(hr))
     1253    {
     1254        /*
     1255         * Success.
     1256         */
     1257        pBackendSurface->enmResType = VMSVGA3D_RESTYPE_BUFFER;
     1258        pBackendSurface->enmDxgiFormat = DXGI_FORMAT_UNKNOWN;
     1259        pSurface->pBackendSurface = pBackendSurface;
     1260        pSurface->idAssociatedContext = pDXContext->cid;
     1261        pSurface->fDirty = true;
     1262        return VINF_SUCCESS;
     1263    }
     1264
     1265    /* Failure. */
     1266    D3D_RELEASE(pBackendSurface->u.Buffer.pBuffer);
     1267    RTMemFree(pBackendSurface);
     1268    return VERR_NO_MEMORY;
     1269}
     1270
     1271
     1272static int vmsvga3dBackSurfaceCreateConstantBuffer(PVMSVGA3DSTATE p3dState, PVMSVGA3DDXCONTEXT pDXContext, PVMSVGA3DSURFACE pSurface)
     1273{
     1274    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     1275    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     1276
     1277    /* Buffers should be created as such. */
     1278    AssertReturn(RT_BOOL(pSurface->surfaceFlags & ( SVGA3D_SURFACE_BIND_CONSTANT_BUFFER)), VERR_INVALID_PARAMETER);
     1279
     1280    if (pSurface->pBackendSurface != NULL)
     1281    {
     1282        AssertFailed(); /** @todo Should the function not be used like that? */
     1283        vmsvga3dBackSurfaceDestroy(p3dState, pSurface);
     1284    }
     1285
     1286    PVMSVGA3DBACKENDSURFACE pBackendSurface = (PVMSVGA3DBACKENDSURFACE)RTMemAllocZ(sizeof(VMSVGA3DBACKENDSURFACE));
     1287    AssertPtrReturn(pBackendSurface, VERR_NO_MEMORY);
     1288
     1289    D3D11_BUFFER_DESC bd;
     1290    RT_ZERO(bd);
     1291    bd.ByteWidth = pSurface->paMipmapLevels[0].cbSurface;
     1292    bd.Usage = D3D11_USAGE_DYNAMIC;
     1293    bd.BindFlags           = D3D11_BIND_CONSTANT_BUFFER;
     1294    bd.CPUAccessFlags      = D3D11_CPU_ACCESS_WRITE;
     1295    bd.MiscFlags           = 0;
     1296    bd.StructureByteStride = 0;
     1297
     1298    HRESULT hr = pDevice->pDevice->CreateBuffer(&bd, 0, &pBackendSurface->u.Buffer.pBuffer);
     1299    if (SUCCEEDED(hr))
     1300    {
     1301        /*
     1302         * Success.
     1303         */
     1304        pBackendSurface->enmResType = VMSVGA3D_RESTYPE_BUFFER;
     1305        pBackendSurface->enmDxgiFormat = DXGI_FORMAT_UNKNOWN;
     1306        pSurface->pBackendSurface = pBackendSurface;
     1307        pSurface->idAssociatedContext = pDXContext->cid;
     1308        pSurface->fDirty = true;
     1309        return VINF_SUCCESS;
     1310    }
     1311
     1312    /* Failure. */
     1313    D3D_RELEASE(pBackendSurface->u.Buffer.pBuffer);
     1314    RTMemFree(pBackendSurface);
     1315    return VERR_NO_MEMORY;
    5641316}
    5651317
     
    9161668    if (!pBackendSurface)
    9171669        return VERR_INVALID_PARAMETER;
     1670
     1671    PVMSVGA3DDXCONTEXT pDXContext;
     1672    vmsvga3dDXContextFromCid(pState, pSurface->idAssociatedContext, &pDXContext);
     1673
     1674    DXDEVICE *pDevice = NULL;
     1675    if (pDXContext)
     1676    {
     1677        pDevice = &pDXContext->pBackendDXContext->device;
     1678        AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     1679    }
    9181680
    9191681    SVGA3dBox clipBox;
     
    9811743            rc = VERR_NOT_SUPPORTED;
    9821744    }
     1745    else if (pBackendSurface->enmResType == VMSVGA3D_RESTYPE_TEXTURE)
     1746    {
     1747        AssertReturn(pDevice && pDevice->pDevice, VERR_INTERNAL_ERROR);
     1748ASMBreakpoint();
     1749        ID3D11Texture2D *pMappedTexture;
     1750        if (enmMapType == VMSVGA3D_SURFACE_MAP_READ)
     1751        {
     1752            pMappedTexture = pBackendSurface->u.ScreenTarget.pStagingTexture;
     1753
     1754            /* Copy the texture content to the staging texture. */
     1755            pDevice->pImmediateContext->CopyResource(pBackendSurface->u.ScreenTarget.pStagingTexture, pBackendSurface->u.ScreenTarget.pTexture);
     1756        }
     1757        else
     1758            pMappedTexture = pBackendSurface->u.ScreenTarget.pDynamicTexture;
     1759
     1760        UINT const Subresource = 0; /* Screen target surfaces have only one subresource. */
     1761        HRESULT hr = pDevice->pImmediateContext->Map(pMappedTexture, Subresource,
     1762                                                     d3d11MapType, /* MapFlags =  */ 0, &mappedResource);
     1763        if (SUCCEEDED(hr))
     1764        {
     1765            pMap->enmMapType   = enmMapType;
     1766            pMap->box          = clipBox;
     1767            pMap->cbPixel      = pSurface->cbBlock;
     1768            pMap->cbRowPitch   = mappedResource.RowPitch;
     1769            pMap->cbDepthPitch = mappedResource.DepthPitch;
     1770            pMap->pvData       = (uint8_t *)mappedResource.pData
     1771                               + pMap->box.x * pMap->cbPixel
     1772                               + pMap->box.y * pMap->cbRowPitch
     1773                               + pMap->box.z * pMap->cbDepthPitch;
     1774        }
     1775        else
     1776            rc = VERR_NOT_SUPPORTED;
     1777    }
     1778    else if (pBackendSurface->enmResType == VMSVGA3D_RESTYPE_BUFFER)
     1779    {
     1780        UINT const Subresource = 0; /* Buffers have only one subresource. */
     1781        HRESULT hr = pDevice->pImmediateContext->Map(pSurface->pBackendSurface->u.Buffer.pBuffer, Subresource,
     1782                                                     d3d11MapType, /* MapFlags =  */ 0, &mappedResource);
     1783        if (SUCCEEDED(hr))
     1784        {
     1785            pMap->enmMapType   = enmMapType;
     1786            pMap->box          = clipBox;
     1787            pMap->cbPixel      = pSurface->cbBlock;
     1788            pMap->cbRowPitch   = mappedResource.RowPitch;
     1789            pMap->cbDepthPitch = mappedResource.DepthPitch;
     1790            pMap->pvData       = (uint8_t *)mappedResource.pData
     1791                               + pMap->box.x * pMap->cbPixel
     1792                               + pMap->box.y * pMap->cbRowPitch
     1793                               + pMap->box.z * pMap->cbDepthPitch;
     1794        }
     1795        else
     1796            rc = VERR_NOT_SUPPORTED;
     1797    }
    9831798    else
    9841799    {
     
    10091824    PVMSVGA3DBACKENDSURFACE pBackendSurface = pSurface->pBackendSurface;
    10101825    AssertReturn(pBackendSurface, VERR_INVALID_PARAMETER);
     1826
     1827    PVMSVGA3DDXCONTEXT pDXContext;
     1828    vmsvga3dDXContextFromCid(pState, pSurface->idAssociatedContext, &pDXContext);
     1829
     1830    DXDEVICE *pDevice = NULL;
     1831    if (pDXContext)
     1832    {
     1833        pDevice = &pDXContext->pBackendDXContext->device;
     1834        AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     1835    }
    10111836
    10121837    if (pBackendSurface->enmResType == VMSVGA3D_RESTYPE_SCREEN_TARGET)
     
    10441869        }
    10451870    }
     1871    else if (pBackendSurface->enmResType == VMSVGA3D_RESTYPE_TEXTURE)
     1872    {
     1873        AssertReturn(pDevice && pDevice->pDevice, VERR_INTERNAL_ERROR);
     1874ASMBreakpoint();
     1875        ID3D11Texture2D *pMappedTexture;
     1876        if (pMap->enmMapType == VMSVGA3D_SURFACE_MAP_READ)
     1877            pMappedTexture = pBackendSurface->u.ScreenTarget.pStagingTexture;
     1878        else
     1879            pMappedTexture = pBackendSurface->u.ScreenTarget.pDynamicTexture;
     1880
     1881        UINT const Subresource = 0; /* Screen target surfaces have only one subresource. */
     1882        pDevice->pImmediateContext->Unmap(pMappedTexture, Subresource);
     1883
     1884        if (   fWritten
     1885            && (   pMap->enmMapType == VMSVGA3D_SURFACE_MAP_WRITE
     1886                || pMap->enmMapType == VMSVGA3D_SURFACE_MAP_READ_WRITE
     1887                || pMap->enmMapType == VMSVGA3D_SURFACE_MAP_WRITE_DISCARD))
     1888        {
     1889            ID3D11Resource *pDstResource = pBackendSurface->u.ScreenTarget.pTexture;
     1890            UINT DstSubresource = Subresource;
     1891            UINT DstX = pMap->box.x;
     1892            UINT DstY = pMap->box.y;
     1893            UINT DstZ = pMap->box.z;
     1894            ID3D11Resource *pSrcResource = pBackendSurface->u.ScreenTarget.pDynamicTexture;
     1895            UINT SrcSubresource = Subresource;
     1896            D3D11_BOX SrcBox;
     1897            SrcBox.left   = pMap->box.x;
     1898            SrcBox.top    = pMap->box.y;
     1899            SrcBox.front  = pMap->box.z;
     1900            SrcBox.right  = pMap->box.x + pMap->box.w;
     1901            SrcBox.bottom = pMap->box.y + pMap->box.h;
     1902            SrcBox.back   = pMap->box.z + pMap->box.d;
     1903            pDevice->pImmediateContext->CopySubresourceRegion(pDstResource, DstSubresource, DstX, DstY, DstZ,
     1904                                                              pSrcResource, SrcSubresource, &SrcBox);
     1905        }
     1906    }
     1907    else if (pBackendSurface->enmResType == VMSVGA3D_RESTYPE_BUFFER)
     1908    {
     1909        UINT const Subresource = 0; /* Buffers have only one subresource. */
     1910        pDevice->pImmediateContext->Unmap(pBackendSurface->u.Buffer.pBuffer, Subresource);
     1911    }
    10461912    else
    10471913    {
     
    10511917
    10521918    return rc;
    1053 }
    1054 
    1055 
    1056 int vmsvga3dBackSurfaceCreateScreenTarget(PVMSVGA3DSTATE pState, PVMSVGA3DSURFACE pSurface)
    1057 {
    1058     PVMSVGA3DBACKEND pBackend = pState->pBackend;
    1059     AssertReturn(pBackend, VERR_INVALID_STATE);
    1060     AssertReturn(pBackend->pDevice, VERR_INVALID_STATE);
    1061 
    1062     /* Surface must have SCREEN_TARGET flag. */
    1063     ASSERT_GUEST_RETURN(RT_BOOL(pSurface->surfaceFlags & SVGA3D_SURFACE_SCREENTARGET), VERR_INVALID_PARAMETER);
    1064 
    1065     if (VMSVGA3DSURFACE_HAS_HW_SURFACE(pSurface))
    1066     {
    1067         AssertFailed(); /* Should the function not be used like that? */
    1068         vmsvga3dBackSurfaceDestroy(pState, pSurface);
    1069     }
    1070 
    1071     PVMSVGA3DBACKENDSURFACE pBackendSurface = (PVMSVGA3DBACKENDSURFACE)RTMemAllocZ(sizeof(VMSVGA3DBACKENDSURFACE));
    1072     AssertPtrReturn(pBackendSurface, VERR_NO_MEMORY);
    1073 
    1074     D3D11_TEXTURE2D_DESC td;
    1075     RT_ZERO(td);
    1076     td.Width              = pSurface->paMipmapLevels[0].mipmapSize.width;
    1077     td.Height             = pSurface->paMipmapLevels[0].mipmapSize.height;
    1078     Assert(pSurface->cLevels == 1);
    1079     td.MipLevels          = 1;
    1080     td.ArraySize          = 1;
    1081     td.Format             = vmsvgaDXScreenTargetFormat2Dxgi(pSurface->format); // DXGI_FORMAT_B8G8R8A8_UNORM;
    1082     td.SampleDesc.Count   = 1;
    1083     td.SampleDesc.Quality = 0;
    1084     td.Usage              = D3D11_USAGE_DEFAULT;
    1085     td.BindFlags          = D3D11_BIND_RENDER_TARGET | D3D11_BIND_SHADER_RESOURCE;
    1086     td.CPUAccessFlags     = 0;
    1087     td.MiscFlags          = 0;
    1088 
    1089     HRESULT hr = pBackend->pDevice->CreateTexture2D(&td, 0, &pBackendSurface->u.ScreenTarget.pTexture);
    1090 
    1091     if (SUCCEEDED(hr))
    1092     {
    1093         /* Map-able texture. */
    1094         td.Usage          = D3D11_USAGE_DYNAMIC;
    1095         td.BindFlags      = D3D11_BIND_SHADER_RESOURCE; /* Have to specify a supported flag, otherwise E_INVALIDARG will be returned. */
    1096         td.CPUAccessFlags = D3D11_CPU_ACCESS_WRITE;
    1097         td.MiscFlags      = 0;
    1098         hr = pBackend->pDevice->CreateTexture2D(&td, 0, &pBackendSurface->u.ScreenTarget.pDynamicTexture);
    1099     }
    1100 
    1101     if (SUCCEEDED(hr))
    1102     {
    1103         /* Staging texture. */
    1104         td.Usage          = D3D11_USAGE_STAGING;
    1105         td.BindFlags      = 0; /* No flags allowed. */
    1106         td.CPUAccessFlags = D3D11_CPU_ACCESS_READ;
    1107         td.MiscFlags      = 0;
    1108         hr = pBackend->pDevice->CreateTexture2D(&td, 0, &pBackendSurface->u.ScreenTarget.pStagingTexture);
    1109     }
    1110 
    1111     if (SUCCEEDED(hr))
    1112     {
    1113         /*
    1114          * Success.
    1115          */
    1116         pBackendSurface->enmResType = VMSVGA3D_RESTYPE_SCREEN_TARGET;
    1117         pSurface->pBackendSurface = pBackendSurface;
    1118         return VINF_SUCCESS;
    1119     }
    1120 
    1121     /* Failure. */
    1122     D3D_RELEASE(pBackendSurface->u.ScreenTarget.pStagingTexture);
    1123     D3D_RELEASE(pBackendSurface->u.ScreenTarget.pDynamicTexture);
    1124     D3D_RELEASE(pBackendSurface->u.ScreenTarget.pTexture);
    1125     RTMemFree(pBackendSurface);
    1126     return VERR_NO_MEMORY;
    11271919}
    11281920
     
    21102902    /* The caller should not use the function for system memory surfaces. */
    21112903    PVMSVGA3DBACKENDSURFACE pBackendSurface = pSurface->pBackendSurface;
    2112     AssertReturnVoid(pBackendSurface);
     2904    if (!pBackendSurface)
     2905        return;
    21132906    pSurface->pBackendSurface = NULL;
    21142907
     
    21182911        D3D_RELEASE(pBackendSurface->u.ScreenTarget.pDynamicTexture);
    21192912        D3D_RELEASE(pBackendSurface->u.ScreenTarget.pTexture);
     2913    }
     2914    else if (pBackendSurface->enmResType == VMSVGA3D_RESTYPE_TEXTURE)
     2915    {
     2916        D3D_RELEASE(pBackendSurface->u.Texture.pStagingTexture);
     2917        D3D_RELEASE(pBackendSurface->u.Texture.pDynamicTexture);
     2918        D3D_RELEASE(pBackendSurface->u.Texture.pTexture);
     2919    }
     2920    else if (pBackendSurface->enmResType == VMSVGA3D_RESTYPE_BUFFER)
     2921    {
     2922        D3D_RELEASE(pBackendSurface->u.Buffer.pBuffer);
    21202923    }
    21212924    else
     
    23363139
    23373140
    2338 static DECLCALLBACK(void) vmsvga3dDXDefineContext(PVMSVGA3DSTATE p3dState)
    2339 {
    2340     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2341 
     3141/*
     3142 * DX callbacks.
     3143 */
     3144
     3145static DECLCALLBACK(int) vmsvga3dBackDXDefineContext(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3146{
     3147    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3148
     3149    /* Allocate a backend specific context structure. */
     3150    PVMSVGA3DBACKENDDXCONTEXT pBackendDXContext = (PVMSVGA3DBACKENDDXCONTEXT)RTMemAllocZ(sizeof(VMSVGA3DBACKENDDXCONTEXT));
     3151    AssertPtrReturn(pBackendDXContext, VERR_NO_MEMORY);
     3152    pDXContext->pBackendDXContext = pBackendDXContext;
     3153
     3154    int rc = dxDeviceCreate(pBackend, &pBackendDXContext->device);
     3155    return rc;
     3156}
     3157
     3158
     3159static DECLCALLBACK(int) vmsvga3dBackDXDestroyContext(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3160{
     3161    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3162
     3163    if (pDXContext->pBackendDXContext)
     3164    {
     3165        dxDeviceDestroy(pBackend, &pDXContext->pBackendDXContext->device);
     3166
     3167        RTMemFree(pDXContext->pBackendDXContext);
     3168        pDXContext->pBackendDXContext = NULL;
     3169    }
     3170    return VINF_SUCCESS;
     3171}
     3172
     3173
     3174static DECLCALLBACK(int) vmsvga3dBackDXBindContext(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3175{
     3176    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3177    RT_NOREF(pBackend, pDXContext);
     3178    return VINF_SUCCESS;
     3179}
     3180
     3181
     3182static DECLCALLBACK(int) vmsvga3dBackDXReadbackContext(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3183{
     3184    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3185
     3186    RT_NOREF(pBackend, pDXContext);
     3187    AssertFailed(); /** @todo Implement */
     3188    return VERR_NOT_IMPLEMENTED;
     3189}
     3190
     3191
     3192static DECLCALLBACK(int) vmsvga3dBackDXInvalidateContext(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3193{
     3194    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3195
     3196    RT_NOREF(pBackend, pDXContext);
     3197    AssertFailed(); /** @todo Implement */
     3198    return VERR_NOT_IMPLEMENTED;
     3199}
     3200
     3201
     3202static DECLCALLBACK(int) vmsvga3dBackDXSetSingleConstantBuffer(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, uint32_t slot, SVGA3dShaderType type, SVGA3dSurfaceId sid, uint32_t offsetInBytes, uint32_t sizeInBytes)
     3203{
     3204    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
    23423205    RT_NOREF(pBackend);
    2343     AssertFailed(); /** @todo Implement */
    2344 }
    2345 
    2346 
    2347 static DECLCALLBACK(void) vmsvga3dDXDestroyContext(PVMSVGA3DSTATE p3dState)
    2348 {
    2349     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2350 
     3206
     3207    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     3208    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     3209
     3210    PVMSVGA3DSURFACE pSurface;
     3211    int rc = vmsvga3dSurfaceFromSid(pThisCC->svga.p3dState, sid, &pSurface);
     3212    AssertRCReturn(rc, rc);
     3213
     3214    uint32_t const cbSurface = pSurface->paMipmapLevels[0].cbSurface;
     3215    ASSERT_GUEST_RETURN(   offsetInBytes < cbSurface
     3216                        && sizeInBytes <= cbSurface - offsetInBytes, VERR_INVALID_PARAMETER);
     3217
     3218    if (pSurface->pBackendSurface == NULL)
     3219    {
     3220        /* Create the resource. */
     3221        rc = vmsvga3dBackSurfaceCreateConstantBuffer(pThisCC->svga.p3dState, pDXContext, pSurface);
     3222        AssertRCReturn(rc, rc);
     3223    }
     3224
     3225    if (pSurface->fDirty)
     3226    {
     3227        /* Get mobid for the surface and read from the MOB. */
     3228        SVGA3dSurfaceImageId imageId;
     3229        imageId.sid = sid;
     3230        imageId.face = 0;
     3231        imageId.mipmap = 0;
     3232
     3233        SVGA3dPoint ptSrc;
     3234        ptSrc.x = offsetInBytes / pSurface->cbBlock;
     3235        ptSrc.y = 0;
     3236        ptSrc.z = 0;
     3237
     3238        SVGA3dBox boxDst;
     3239        boxDst.x = 0;
     3240        boxDst.y = 0;
     3241        boxDst.z = 0;
     3242        boxDst.w = sizeInBytes / pSurface->cbBlock;
     3243        boxDst.h = 1;
     3244        boxDst.d = 1;
     3245
     3246        rc = vmsvgaR3UpdateGBSurfaceEx(pThisCC, &imageId, &boxDst, &ptSrc);
     3247        AssertRCReturn(rc, rc);
     3248    }
     3249
     3250    dxConstantBufferSet(pDevice, slot, type, pSurface->pBackendSurface->u.Buffer.pBuffer);
     3251
     3252    uint32_t const idxShaderState = type - SVGA3D_SHADERTYPE_MIN;
     3253    SVGA3dConstantBufferBinding *pCBB = &pDXContext->svgaDXContext.shaderState[idxShaderState].constantBuffers[slot];
     3254    pCBB->sid           = sid;
     3255    pCBB->offsetInBytes = offsetInBytes;
     3256    pCBB->sizeInBytes   = sizeInBytes;
     3257    return VINF_SUCCESS;
     3258}
     3259
     3260
     3261static DECLCALLBACK(int) vmsvga3dBackDXSetShaderResources(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3262{
     3263    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3264
     3265    RT_NOREF(pBackend, pDXContext);
     3266    AssertFailed(); /** @todo Implement */
     3267    return VERR_NOT_IMPLEMENTED;
     3268}
     3269
     3270
     3271static DECLCALLBACK(int) vmsvga3dBackDXSetShader(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, PVMSVGA3DSHADER pShader)
     3272{
     3273    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
    23513274    RT_NOREF(pBackend);
    2352     AssertFailed(); /** @todo Implement */
    2353 }
    2354 
    2355 
    2356 static DECLCALLBACK(void) vmsvga3dDXBindContext(PVMSVGA3DSTATE p3dState)
    2357 {
    2358     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2359 
     3275
     3276    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     3277    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     3278
     3279    DXSHADER *pDXShader = &pDXContext->pBackendDXContext->paShader[pShader->id];
     3280    uint32_t const idxShaderState = pDXShader->enmShaderType - SVGA3D_SHADERTYPE_MIN;
     3281    pDXContext->svgaDXContext.shaderState[idxShaderState].shaderId = pShader->id;
     3282
     3283    dxShaderSet(pDevice, pShader, pDXShader);
     3284    return VINF_SUCCESS;
     3285}
     3286
     3287
     3288static DECLCALLBACK(int) vmsvga3dBackDXSetSamplers(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, uint32_t startSampler, SVGA3dShaderType type, uint32_t cSamplerId, SVGA3dSamplerId const *paSamplerId)
     3289{
     3290    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
    23603291    RT_NOREF(pBackend);
    2361     AssertFailed(); /** @todo Implement */
    2362 }
    2363 
    2364 
    2365 static DECLCALLBACK(void) vmsvga3dDXReadbackContext(PVMSVGA3DSTATE p3dState)
    2366 {
    2367     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2368 
     3292
     3293    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     3294    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     3295
     3296    uint32_t const idxShaderState = type - SVGA3D_SHADERTYPE_MIN;
     3297    ID3D11SamplerState *aSamplerState[SVGA3D_DX_MAX_SAMPLERS];
     3298    for (uint32_t i = 0; i < cSamplerId; ++i)
     3299    {
     3300        SVGA3dSamplerId samplerId = paSamplerId[i];
     3301        if (samplerId != SVGA3D_INVALID_ID)
     3302        {
     3303            ASSERT_GUEST_RETURN(samplerId < pDXContext->pBackendDXContext->cSamplerState, VERR_INVALID_PARAMETER);
     3304            aSamplerState[i] = pDXContext->pBackendDXContext->papSamplerState[samplerId];
     3305        }
     3306        else
     3307            aSamplerState[i] = NULL;
     3308
     3309        pDXContext->svgaDXContext.shaderState[idxShaderState].samplers[startSampler + i] = samplerId;
     3310    }
     3311
     3312    dxSamplerSet(pDevice, type, startSampler, cSamplerId, aSamplerState);
     3313    return VINF_SUCCESS;
     3314}
     3315
     3316
     3317static DECLCALLBACK(int) vmsvga3dBackDXDraw(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, uint32_t vertexCount, uint32_t startVertexLocation)
     3318{
     3319    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
    23693320    RT_NOREF(pBackend);
    2370     AssertFailed(); /** @todo Implement */
    2371 }
    2372 
    2373 
    2374 static DECLCALLBACK(void) vmsvga3dDXInvalidateContext(PVMSVGA3DSTATE p3dState)
    2375 {
    2376     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2377 
     3321
     3322    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     3323    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     3324
     3325    pDevice->pImmediateContext->Draw(vertexCount, startVertexLocation);
     3326    return VINF_SUCCESS;
     3327}
     3328
     3329
     3330static DECLCALLBACK(int) vmsvga3dBackDXDrawIndexed(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, uint32_t indexCount, uint32_t startIndexLocation, int32_t baseVertexLocation)
     3331{
     3332    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
    23783333    RT_NOREF(pBackend);
    2379     AssertFailed(); /** @todo Implement */
    2380 }
    2381 
    2382 
    2383 static DECLCALLBACK(void) vmsvga3dDXSetSingleConstantBuffer(PVMSVGA3DSTATE p3dState)
    2384 {
    2385     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2386 
     3334
     3335    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     3336    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     3337
     3338    pDevice->pImmediateContext->DrawIndexed(indexCount, startIndexLocation, baseVertexLocation);
     3339    return VINF_SUCCESS;
     3340}
     3341
     3342
     3343static DECLCALLBACK(int) vmsvga3dBackDXDrawInstanced(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3344{
     3345    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3346
     3347    RT_NOREF(pBackend, pDXContext);
     3348    AssertFailed(); /** @todo Implement */
     3349    return VERR_NOT_IMPLEMENTED;
     3350}
     3351
     3352
     3353static DECLCALLBACK(int) vmsvga3dBackDXDrawIndexedInstanced(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3354{
     3355    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3356
     3357    RT_NOREF(pBackend, pDXContext);
     3358    AssertFailed(); /** @todo Implement */
     3359    return VERR_NOT_IMPLEMENTED;
     3360}
     3361
     3362
     3363static DECLCALLBACK(int) vmsvga3dBackDXDrawAuto(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3364{
     3365    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3366
     3367    RT_NOREF(pBackend, pDXContext);
     3368    AssertFailed(); /** @todo Implement */
     3369    return VERR_NOT_IMPLEMENTED;
     3370}
     3371
     3372
     3373static DECLCALLBACK(int) vmsvga3dBackDXSetInputLayout(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dElementLayoutId elementLayoutId)
     3374{
     3375    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
    23873376    RT_NOREF(pBackend);
    2388     AssertFailed(); /** @todo Implement */
    2389 }
    2390 
    2391 
    2392 static DECLCALLBACK(void) vmsvga3dDXSetShaderResources(PVMSVGA3DSTATE p3dState)
    2393 {
    2394     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2395 
     3377
     3378    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     3379    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     3380
     3381    pDXContext->svgaDXContext.inputAssembly.layoutId = elementLayoutId;
     3382
     3383    DXELEMENTLAYOUT *pDXElementLayout = &pDXContext->pBackendDXContext->paElementLayout[elementLayoutId];
     3384    if (!pDXElementLayout->pElementLayout)
     3385    {
     3386        uint32_t const idxShaderState = SVGA3D_SHADERTYPE_VS - SVGA3D_SHADERTYPE_MIN;
     3387        uint32_t const shid = pDXContext->svgaDXContext.shaderState[idxShaderState].shaderId;
     3388        AssertReturnStmt(shid < pDXContext->pBackendDXContext->cShader,
     3389                         LogRelMax(16, ("VMSVGA: DX shader is not set in DXSetInputLayout: shid = 0x%x\n", shid)),
     3390                         VERR_INVALID_STATE);
     3391        DXSHADER *pDXShader = &pDXContext->pBackendDXContext->paShader[shid];
     3392        AssertReturnStmt(pDXShader->pvDXBC,
     3393                         LogRelMax(16, ("VMSVGA: DX shader bytecode is not available in DXSetInputLayout: shid = %u\n", shid)),
     3394                         VERR_INVALID_STATE);
     3395        HRESULT hr = pDevice->pDevice->CreateInputLayout(pDXElementLayout->aElementDesc,
     3396                                                         pDXElementLayout->cElementDesc,
     3397                                                         pDXShader->pvDXBC,
     3398                                                         pDXShader->cbDXBC,
     3399                                                         &pDXElementLayout->pElementLayout);
     3400        AssertReturn(SUCCEEDED(hr), VERR_NO_MEMORY);
     3401    }
     3402
     3403    pDevice->pImmediateContext->IASetInputLayout(pDXElementLayout->pElementLayout);
     3404    return VINF_SUCCESS;
     3405}
     3406
     3407
     3408static DECLCALLBACK(int) vmsvga3dBackDXSetVertexBuffers(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, uint32_t startBuffer, uint32_t cVertexBuffer, SVGA3dVertexBuffer const *paVertexBuffer)
     3409{
     3410    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
    23963411    RT_NOREF(pBackend);
    2397     AssertFailed(); /** @todo Implement */
    2398 }
    2399 
    2400 
    2401 static DECLCALLBACK(void) vmsvga3dDXSetShader(PVMSVGA3DSTATE p3dState)
    2402 {
    2403     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2404 
     3412
     3413    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     3414    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     3415
     3416    /* For each paVertexBuffer[i]:
     3417     *   If the vertex buffer object does not exist then create it.
     3418     *   If the surface has been updated by the guest then update the buffer object.
     3419     * Use IASetVertexBuffers to set the buffers.
     3420     */
     3421
     3422    ID3D11Buffer *paResources[SVGA3D_DX_MAX_VERTEXBUFFERS];
     3423    UINT paStride[SVGA3D_DX_MAX_VERTEXBUFFERS];
     3424    UINT paOffset[SVGA3D_DX_MAX_VERTEXBUFFERS];
     3425
     3426    for (uint32_t i = 0; i < cVertexBuffer; ++i)
     3427    {
     3428        uint32_t const idxVertexBuffer = startBuffer + i;
     3429
     3430        /* Get corresponding resource. Create the buffer if does not yet exist. */
     3431        if (paVertexBuffer[i].sid != SVGA_ID_INVALID)
     3432        {
     3433            PVMSVGA3DSURFACE pSurface;
     3434            int rc = vmsvga3dSurfaceFromSid(pThisCC->svga.p3dState, paVertexBuffer[i].sid, &pSurface);
     3435            AssertRCReturn(rc, rc);
     3436
     3437            if (pSurface->pBackendSurface == NULL)
     3438            {
     3439                /* Create the resource. */
     3440                rc = vmsvga3dBackSurfaceCreateBuffer(pThisCC->svga.p3dState, pDXContext, pSurface);
     3441                AssertRCReturn(rc, rc);
     3442            }
     3443
     3444            if (pSurface->fDirty)
     3445            {
     3446                /* Get mobid for the surface and read from the MOB. */
     3447                SVGA3dSurfaceImageId imageId;
     3448                imageId.sid = paVertexBuffer[i].sid;
     3449                imageId.face = 0;
     3450                imageId.mipmap = 0;
     3451
     3452                SVGA3dBox box;
     3453                box.x = 0;
     3454                box.y = 0;
     3455                box.z = 0;
     3456                box.w = pSurface->paMipmapLevels[0].mipmapSize.width;
     3457                box.h = 1;
     3458                box.d = 1;
     3459
     3460                rc = vmsvgaR3UpdateGBSurface(pThisCC, &imageId, &box);
     3461                AssertRCReturn(rc, rc);
     3462            }
     3463
     3464            paResources[idxVertexBuffer] = pSurface->pBackendSurface->u.Buffer.pBuffer;
     3465            paStride[idxVertexBuffer] = paVertexBuffer[i].stride;
     3466            paOffset[idxVertexBuffer] = paVertexBuffer[i].offset;
     3467        }
     3468        else
     3469        {
     3470            paResources[idxVertexBuffer] = NULL;
     3471            paStride[idxVertexBuffer] = 0;
     3472            paOffset[idxVertexBuffer] = 0;
     3473        }
     3474
     3475        pDXContext->svgaDXContext.inputAssembly.vertexBuffers[idxVertexBuffer].bufferId = paVertexBuffer[i].sid;
     3476        pDXContext->svgaDXContext.inputAssembly.vertexBuffers[idxVertexBuffer].stride = paVertexBuffer[i].stride;
     3477        pDXContext->svgaDXContext.inputAssembly.vertexBuffers[idxVertexBuffer].offset = paVertexBuffer[i].offset;
     3478    }
     3479
     3480    pDevice->pImmediateContext->IASetVertexBuffers(startBuffer, cVertexBuffer, paResources, paStride, paOffset);
     3481
     3482    return VINF_SUCCESS;
     3483}
     3484
     3485
     3486static DECLCALLBACK(int) vmsvga3dBackDXSetIndexBuffer(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dSurfaceId sid, SVGA3dSurfaceFormat format, uint32_t offset)
     3487{
     3488    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
    24053489    RT_NOREF(pBackend);
    2406     AssertFailed(); /** @todo Implement */
    2407 }
    2408 
    2409 
    2410 static DECLCALLBACK(void) vmsvga3dDXSetSamplers(PVMSVGA3DSTATE p3dState)
    2411 {
    2412     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2413 
     3490
     3491    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     3492    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     3493
     3494    /* Get corresponding resource. Create the buffer if does not yet exist. */
     3495    ID3D11Buffer *pResource;
     3496    DXGI_FORMAT enmDxgiFormat;
     3497
     3498    if (sid != SVGA_ID_INVALID)
     3499    {
     3500        PVMSVGA3DSURFACE pSurface;
     3501        int rc = vmsvga3dSurfaceFromSid(pThisCC->svga.p3dState, sid, &pSurface);
     3502        AssertRCReturn(rc, rc);
     3503
     3504        if (pSurface->pBackendSurface == NULL)
     3505        {
     3506            /* Create the resource. */
     3507            rc = vmsvga3dBackSurfaceCreateBuffer(pThisCC->svga.p3dState, pDXContext, pSurface);
     3508            AssertRCReturn(rc, rc);
     3509        }
     3510
     3511        if (pSurface->fDirty)
     3512        {
     3513            /* Get mobid for the surface and read from the MOB. */
     3514            SVGA3dSurfaceImageId imageId;
     3515            imageId.sid = sid;
     3516            imageId.face = 0;
     3517            imageId.mipmap = 0;
     3518
     3519            SVGA3dBox box;
     3520            box.x = 0;
     3521            box.y = 0;
     3522            box.z = 0;
     3523            box.w = pSurface->paMipmapLevels[0].mipmapSize.width;
     3524            box.h = 1;
     3525            box.d = 1;
     3526
     3527            rc = vmsvgaR3UpdateGBSurface(pThisCC, &imageId, &box);
     3528            AssertRCReturn(rc, rc);
     3529        }
     3530
     3531        pResource = pSurface->pBackendSurface->u.Buffer.pBuffer;
     3532        enmDxgiFormat = vmsvgaDXSurfaceFormat2Dxgi(format);
     3533        AssertReturn(enmDxgiFormat == DXGI_FORMAT_R16_UINT || enmDxgiFormat == DXGI_FORMAT_R32_UINT, VERR_INVALID_PARAMETER);
     3534    }
     3535    else
     3536    {
     3537        pResource = NULL;
     3538        enmDxgiFormat = DXGI_FORMAT_UNKNOWN;
     3539    }
     3540
     3541    pDevice->pImmediateContext->IASetIndexBuffer(pResource, enmDxgiFormat, offset);
     3542
     3543    pDXContext->svgaDXContext.inputAssembly.indexBufferSid = sid;
     3544    pDXContext->svgaDXContext.inputAssembly.indexBufferOffset = offset;
     3545    pDXContext->svgaDXContext.inputAssembly.indexBufferFormat = format;
     3546
     3547    return VINF_SUCCESS;
     3548}
     3549
     3550static D3D11_PRIMITIVE_TOPOLOGY dxTopology(SVGA3dPrimitiveType primitiveType)
     3551{
     3552    static D3D11_PRIMITIVE_TOPOLOGY const aD3D11PrimitiveTopology[SVGA3D_PRIMITIVE_MAX] =
     3553    {
     3554        D3D11_PRIMITIVE_TOPOLOGY_UNDEFINED,
     3555        D3D11_PRIMITIVE_TOPOLOGY_TRIANGLELIST,
     3556        D3D11_PRIMITIVE_TOPOLOGY_POINTLIST,
     3557        D3D11_PRIMITIVE_TOPOLOGY_LINELIST,
     3558        D3D11_PRIMITIVE_TOPOLOGY_LINESTRIP,
     3559        D3D11_PRIMITIVE_TOPOLOGY_TRIANGLESTRIP,
     3560        D3D11_PRIMITIVE_TOPOLOGY_TRIANGLESTRIP, /* SVGA3D_PRIMITIVE_TRIANGLEFAN: No FAN in D3D11 */
     3561        D3D11_PRIMITIVE_TOPOLOGY_LINELIST_ADJ,
     3562        D3D11_PRIMITIVE_TOPOLOGY_LINESTRIP_ADJ,
     3563        D3D11_PRIMITIVE_TOPOLOGY_TRIANGLELIST_ADJ,
     3564        D3D11_PRIMITIVE_TOPOLOGY_TRIANGLESTRIP_ADJ,
     3565        D3D11_PRIMITIVE_TOPOLOGY_1_CONTROL_POINT_PATCHLIST,
     3566        D3D11_PRIMITIVE_TOPOLOGY_2_CONTROL_POINT_PATCHLIST,
     3567        D3D11_PRIMITIVE_TOPOLOGY_3_CONTROL_POINT_PATCHLIST,
     3568        D3D11_PRIMITIVE_TOPOLOGY_4_CONTROL_POINT_PATCHLIST,
     3569        D3D11_PRIMITIVE_TOPOLOGY_5_CONTROL_POINT_PATCHLIST,
     3570        D3D11_PRIMITIVE_TOPOLOGY_6_CONTROL_POINT_PATCHLIST,
     3571        D3D11_PRIMITIVE_TOPOLOGY_7_CONTROL_POINT_PATCHLIST,
     3572        D3D11_PRIMITIVE_TOPOLOGY_8_CONTROL_POINT_PATCHLIST,
     3573        D3D11_PRIMITIVE_TOPOLOGY_9_CONTROL_POINT_PATCHLIST,
     3574        D3D11_PRIMITIVE_TOPOLOGY_10_CONTROL_POINT_PATCHLIST,
     3575        D3D11_PRIMITIVE_TOPOLOGY_11_CONTROL_POINT_PATCHLIST,
     3576        D3D11_PRIMITIVE_TOPOLOGY_12_CONTROL_POINT_PATCHLIST,
     3577        D3D11_PRIMITIVE_TOPOLOGY_13_CONTROL_POINT_PATCHLIST,
     3578        D3D11_PRIMITIVE_TOPOLOGY_14_CONTROL_POINT_PATCHLIST,
     3579        D3D11_PRIMITIVE_TOPOLOGY_15_CONTROL_POINT_PATCHLIST,
     3580        D3D11_PRIMITIVE_TOPOLOGY_16_CONTROL_POINT_PATCHLIST,
     3581        D3D11_PRIMITIVE_TOPOLOGY_17_CONTROL_POINT_PATCHLIST,
     3582        D3D11_PRIMITIVE_TOPOLOGY_18_CONTROL_POINT_PATCHLIST,
     3583        D3D11_PRIMITIVE_TOPOLOGY_19_CONTROL_POINT_PATCHLIST,
     3584        D3D11_PRIMITIVE_TOPOLOGY_20_CONTROL_POINT_PATCHLIST,
     3585        D3D11_PRIMITIVE_TOPOLOGY_21_CONTROL_POINT_PATCHLIST,
     3586        D3D11_PRIMITIVE_TOPOLOGY_22_CONTROL_POINT_PATCHLIST,
     3587        D3D11_PRIMITIVE_TOPOLOGY_23_CONTROL_POINT_PATCHLIST,
     3588        D3D11_PRIMITIVE_TOPOLOGY_24_CONTROL_POINT_PATCHLIST,
     3589        D3D11_PRIMITIVE_TOPOLOGY_25_CONTROL_POINT_PATCHLIST,
     3590        D3D11_PRIMITIVE_TOPOLOGY_26_CONTROL_POINT_PATCHLIST,
     3591        D3D11_PRIMITIVE_TOPOLOGY_27_CONTROL_POINT_PATCHLIST,
     3592        D3D11_PRIMITIVE_TOPOLOGY_28_CONTROL_POINT_PATCHLIST,
     3593        D3D11_PRIMITIVE_TOPOLOGY_29_CONTROL_POINT_PATCHLIST,
     3594        D3D11_PRIMITIVE_TOPOLOGY_30_CONTROL_POINT_PATCHLIST,
     3595        D3D11_PRIMITIVE_TOPOLOGY_31_CONTROL_POINT_PATCHLIST,
     3596        D3D11_PRIMITIVE_TOPOLOGY_32_CONTROL_POINT_PATCHLIST,
     3597    };
     3598    return aD3D11PrimitiveTopology[primitiveType];
     3599}
     3600
     3601static DECLCALLBACK(int) vmsvga3dBackDXSetTopology(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dPrimitiveType topology)
     3602{
     3603    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
    24143604    RT_NOREF(pBackend);
    2415     AssertFailed(); /** @todo Implement */
    2416 }
    2417 
    2418 
    2419 static DECLCALLBACK(void) vmsvga3dDXDraw(PVMSVGA3DSTATE p3dState)
    2420 {
    2421     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2422 
     3605
     3606    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     3607    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     3608
     3609    D3D11_PRIMITIVE_TOPOLOGY enmTopology = dxTopology(topology);
     3610    pDevice->pImmediateContext->IASetPrimitiveTopology(enmTopology);
     3611    pDXContext->svgaDXContext.inputAssembly.topology = topology;
     3612    return VINF_SUCCESS;
     3613}
     3614
     3615
     3616static DECLCALLBACK(int) vmsvga3dBackDXSetRenderTargets(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dDepthStencilViewId depthStencilViewId, uint32_t cRenderTargetViewId, SVGA3dRenderTargetViewId const *paRenderTargetViewId)
     3617{
     3618    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
    24233619    RT_NOREF(pBackend);
    2424     AssertFailed(); /** @todo Implement */
    2425 }
    2426 
    2427 
    2428 static DECLCALLBACK(void) vmsvga3dDXDrawIndexed(PVMSVGA3DSTATE p3dState)
    2429 {
    2430     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2431 
     3620
     3621    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     3622    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     3623
     3624    ID3D11RenderTargetView *aRenderTargetViews[SVGA3D_MAX_RENDER_TARGETS];
     3625    for (uint32_t i = 0; i < cRenderTargetViewId; ++i)
     3626    {
     3627        SVGA3dRenderTargetViewId renderTargetViewId = paRenderTargetViewId[i];
     3628        if (renderTargetViewId != SVGA3D_INVALID_ID)
     3629        {
     3630            ASSERT_GUEST_RETURN(renderTargetViewId < pDXContext->pBackendDXContext->cRenderTargetView, VERR_INVALID_PARAMETER);
     3631            aRenderTargetViews[i] = pDXContext->pBackendDXContext->papRenderTargetView[renderTargetViewId];
     3632        }
     3633        else
     3634            aRenderTargetViews[i] = NULL;
     3635    }
     3636
     3637    ID3D11DepthStencilView *pDepthStencilView;
     3638    if (depthStencilViewId != SVGA_ID_INVALID)
     3639        pDepthStencilView = pDXContext->pBackendDXContext->papDepthStencilView[depthStencilViewId];
     3640    else
     3641        pDepthStencilView = NULL;
     3642
     3643    pDevice->pImmediateContext->OMSetRenderTargets(cRenderTargetViewId, aRenderTargetViews, pDepthStencilView);
     3644    return VINF_SUCCESS;
     3645}
     3646
     3647
     3648static DECLCALLBACK(int) vmsvga3dBackDXSetBlendState(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dBlendStateId blendId, float const blendFactor[4], uint32_t sampleMask)
     3649{
     3650    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
    24323651    RT_NOREF(pBackend);
    2433     AssertFailed(); /** @todo Implement */
    2434 }
    2435 
    2436 
    2437 static DECLCALLBACK(void) vmsvga3dDXDrawInstanced(PVMSVGA3DSTATE p3dState)
    2438 {
    2439     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2440 
     3652
     3653    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     3654    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     3655
     3656    ID3D11BlendState *pBlendState = pDXContext->pBackendDXContext->papBlendState[blendId];
     3657    pDevice->pImmediateContext->OMSetBlendState(pBlendState, blendFactor, sampleMask);
     3658
     3659    pDXContext->svgaDXContext.renderState.blendStateId = blendId;
     3660    memcpy(pDXContext->svgaDXContext.renderState.blendFactor, blendFactor, sizeof(blendFactor));
     3661    pDXContext->svgaDXContext.renderState.sampleMask = sampleMask;
     3662
     3663    return VINF_SUCCESS;
     3664}
     3665
     3666
     3667static DECLCALLBACK(int) vmsvga3dBackDXSetDepthStencilState(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dDepthStencilStateId depthStencilId, uint32_t stencilRef)
     3668{
     3669    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
    24413670    RT_NOREF(pBackend);
    2442     AssertFailed(); /** @todo Implement */
    2443 }
    2444 
    2445 
    2446 static DECLCALLBACK(void) vmsvga3dDXDrawIndexedInstanced(PVMSVGA3DSTATE p3dState)
    2447 {
    2448     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
     3671
     3672    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     3673    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     3674
     3675    ID3D11DepthStencilState *pDepthStencilState = pDXContext->pBackendDXContext->papDepthStencilState[depthStencilId];
     3676    pDevice->pImmediateContext->OMSetDepthStencilState(pDepthStencilState, stencilRef);
     3677
     3678    pDXContext->svgaDXContext.renderState.depthStencilStateId = depthStencilId;
     3679    pDXContext->svgaDXContext.renderState.stencilRef = stencilRef;
     3680
     3681    return VINF_SUCCESS;
     3682}
     3683
     3684
     3685static DECLCALLBACK(int) vmsvga3dBackDXSetRasterizerState(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dRasterizerStateId rasterizerId)
     3686{
     3687    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3688    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     3689    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
    24493690
    24503691    RT_NOREF(pBackend);
    2451     AssertFailed(); /** @todo Implement */
    2452 }
    2453 
    2454 
    2455 static DECLCALLBACK(void) vmsvga3dDXDrawAuto(PVMSVGA3DSTATE p3dState)
    2456 {
    2457     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
     3692
     3693    pDevice->pImmediateContext->RSSetState(pDXContext->pBackendDXContext->papRasterizerState[rasterizerId]);
     3694    return VINF_SUCCESS;
     3695}
     3696
     3697
     3698static DECLCALLBACK(int) vmsvga3dBackDXDefineQuery(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3699{
     3700    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3701
     3702    RT_NOREF(pBackend, pDXContext);
     3703    AssertFailed(); /** @todo Implement */
     3704    return VERR_NOT_IMPLEMENTED;
     3705}
     3706
     3707
     3708static DECLCALLBACK(int) vmsvga3dBackDXDestroyQuery(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3709{
     3710    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3711
     3712    RT_NOREF(pBackend, pDXContext);
     3713    AssertFailed(); /** @todo Implement */
     3714    return VERR_NOT_IMPLEMENTED;
     3715}
     3716
     3717
     3718static DECLCALLBACK(int) vmsvga3dBackDXBindQuery(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3719{
     3720    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3721
     3722    RT_NOREF(pBackend, pDXContext);
     3723    AssertFailed(); /** @todo Implement */
     3724    return VERR_NOT_IMPLEMENTED;
     3725}
     3726
     3727
     3728static DECLCALLBACK(int) vmsvga3dBackDXSetQueryOffset(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3729{
     3730    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3731
     3732    RT_NOREF(pBackend, pDXContext);
     3733    AssertFailed(); /** @todo Implement */
     3734    return VERR_NOT_IMPLEMENTED;
     3735}
     3736
     3737
     3738static DECLCALLBACK(int) vmsvga3dBackDXBeginQuery(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3739{
     3740    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3741
     3742    RT_NOREF(pBackend, pDXContext);
     3743    AssertFailed(); /** @todo Implement */
     3744    return VERR_NOT_IMPLEMENTED;
     3745}
     3746
     3747
     3748static DECLCALLBACK(int) vmsvga3dBackDXEndQuery(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3749{
     3750    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3751
     3752    RT_NOREF(pBackend, pDXContext);
     3753    AssertFailed(); /** @todo Implement */
     3754    return VERR_NOT_IMPLEMENTED;
     3755}
     3756
     3757
     3758static DECLCALLBACK(int) vmsvga3dBackDXReadbackQuery(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3759{
     3760    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3761
     3762    RT_NOREF(pBackend, pDXContext);
     3763    AssertFailed(); /** @todo Implement */
     3764    return VERR_NOT_IMPLEMENTED;
     3765}
     3766
     3767
     3768static DECLCALLBACK(int) vmsvga3dBackDXSetPredication(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3769{
     3770    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3771
     3772    RT_NOREF(pBackend, pDXContext);
     3773    AssertFailed(); /** @todo Implement */
     3774    return VERR_NOT_IMPLEMENTED;
     3775}
     3776
     3777
     3778static DECLCALLBACK(int) vmsvga3dBackDXSetSOTargets(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3779{
     3780    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3781
     3782    RT_NOREF(pBackend, pDXContext);
     3783    AssertFailed(); /** @todo Implement */
     3784    return VERR_NOT_IMPLEMENTED;
     3785}
     3786
     3787
     3788static DECLCALLBACK(int) vmsvga3dBackDXSetViewports(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, uint32_t cViewport, SVGA3dViewport const *paViewport)
     3789{
     3790    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3791    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     3792    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
    24583793
    24593794    RT_NOREF(pBackend);
    2460     AssertFailed(); /** @todo Implement */
    2461 }
    2462 
    2463 
    2464 static DECLCALLBACK(void) vmsvga3dDXSetInputLayout(PVMSVGA3DSTATE p3dState)
    2465 {
    2466     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
     3795
     3796    /* D3D11_VIEWPORT is identical to SVGA3dViewport. */
     3797    D3D11_VIEWPORT *pViewports = (D3D11_VIEWPORT *)paViewport;
     3798
     3799    pDevice->pImmediateContext->RSSetViewports(cViewport, pViewports);
     3800    return VINF_SUCCESS;
     3801}
     3802
     3803
     3804static DECLCALLBACK(int) vmsvga3dBackDXSetScissorRects(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, uint32_t cRect, SVGASignedRect const *paRect)
     3805{
     3806    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3807    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     3808    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
    24673809
    24683810    RT_NOREF(pBackend);
    2469     AssertFailed(); /** @todo Implement */
    2470 }
    2471 
    2472 
    2473 static DECLCALLBACK(void) vmsvga3dDXSetVertexBuffers(PVMSVGA3DSTATE p3dState)
    2474 {
    2475     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2476 
     3811
     3812    /* D3D11_RECT is identical to SVGASignedRect. */
     3813    D3D11_RECT *pRects = (D3D11_RECT *)paRect;
     3814
     3815    pDevice->pImmediateContext->RSSetScissorRects(cRect, pRects);
     3816    return VINF_SUCCESS;
     3817}
     3818
     3819
     3820static DECLCALLBACK(int) vmsvga3dBackDXClearRenderTargetView(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3821{
     3822    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3823
     3824    RT_NOREF(pBackend, pDXContext);
     3825    AssertFailed(); /** @todo Implement */
     3826    return VERR_NOT_IMPLEMENTED;
     3827}
     3828
     3829
     3830static DECLCALLBACK(int) vmsvga3dBackDXClearDepthStencilView(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3831{
     3832    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3833
     3834    RT_NOREF(pBackend, pDXContext);
     3835    AssertFailed(); /** @todo Implement */
     3836    return VERR_NOT_IMPLEMENTED;
     3837}
     3838
     3839
     3840static DECLCALLBACK(int) vmsvga3dBackDXPredCopyRegion(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3841{
     3842    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3843
     3844    RT_NOREF(pBackend, pDXContext);
     3845    AssertFailed(); /** @todo Implement */
     3846    return VERR_NOT_IMPLEMENTED;
     3847}
     3848
     3849
     3850static DECLCALLBACK(int) vmsvga3dBackDXPredCopy(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3851{
     3852    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3853
     3854    RT_NOREF(pBackend, pDXContext);
     3855    AssertFailed(); /** @todo Implement */
     3856    return VERR_NOT_IMPLEMENTED;
     3857}
     3858
     3859
     3860static DECLCALLBACK(int) vmsvga3dBackDXPresentBlt(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3861{
     3862    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3863
     3864    RT_NOREF(pBackend, pDXContext);
     3865    AssertFailed(); /** @todo Implement */
     3866    return VERR_NOT_IMPLEMENTED;
     3867}
     3868
     3869
     3870static DECLCALLBACK(int) vmsvga3dBackDXGenMips(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3871{
     3872    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3873
     3874    RT_NOREF(pBackend, pDXContext);
     3875    AssertFailed(); /** @todo Implement */
     3876    return VERR_NOT_IMPLEMENTED;
     3877}
     3878
     3879
     3880static DECLCALLBACK(int) vmsvga3dBackDXUpdateSubResource(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3881{
     3882    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3883
     3884    RT_NOREF(pBackend, pDXContext);
     3885    AssertFailed(); /** @todo Implement */
     3886    return VERR_NOT_IMPLEMENTED;
     3887}
     3888
     3889
     3890static DECLCALLBACK(int) vmsvga3dBackDXReadbackSubResource(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3891{
     3892    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3893
     3894    RT_NOREF(pBackend, pDXContext);
     3895    AssertFailed(); /** @todo Implement */
     3896    return VERR_NOT_IMPLEMENTED;
     3897}
     3898
     3899
     3900static DECLCALLBACK(int) vmsvga3dBackDXInvalidateSubResource(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3901{
     3902    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3903
     3904    RT_NOREF(pBackend, pDXContext);
     3905    AssertFailed(); /** @todo Implement */
     3906    return VERR_NOT_IMPLEMENTED;
     3907}
     3908
     3909
     3910static DECLCALLBACK(int) vmsvga3dBackDXDefineShaderResourceView(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dShaderResourceViewId shaderResourceViewId, SVGACOTableDXSRViewEntry const *pEntry)
     3911{
     3912    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
    24773913    RT_NOREF(pBackend);
    2478     AssertFailed(); /** @todo Implement */
    2479 }
    2480 
    2481 
    2482 static DECLCALLBACK(void) vmsvga3dDXSetIndexBuffer(PVMSVGA3DSTATE p3dState)
    2483 {
    2484     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2485 
     3914
     3915    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     3916    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     3917
     3918    /* Get corresponding resource for pEntry->sid. Create the surface if does not yet exist. */
     3919    PVMSVGA3DSURFACE pSurface;
     3920    int rc = vmsvga3dSurfaceFromSid(pThisCC->svga.p3dState, pEntry->sid, &pSurface);
     3921    AssertRCReturn(rc, rc);
     3922
     3923    if (pSurface->pBackendSurface == NULL)
     3924    {
     3925        /* Create the actual texture. */
     3926        rc = vmsvga3dBackSurfaceCreateTexture(pThisCC->svga.p3dState, pDXContext, pSurface);
     3927        AssertRCReturn(rc, rc);
     3928    }
     3929
     3930    HRESULT hr = dxShaderResourceViewCreate(pDevice, pEntry, pSurface->pBackendSurface, &pDXContext->pBackendDXContext->papShaderResourceView[shaderResourceViewId]);
     3931    if (SUCCEEDED(hr))
     3932        return VINF_SUCCESS;
     3933    return VERR_INVALID_STATE;
     3934}
     3935
     3936
     3937static DECLCALLBACK(int) vmsvga3dBackDXDestroyShaderResourceView(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3938{
     3939    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3940
     3941    RT_NOREF(pBackend, pDXContext);
     3942    AssertFailed(); /** @todo Implement */
     3943    return VERR_NOT_IMPLEMENTED;
     3944}
     3945
     3946
     3947static DECLCALLBACK(int) vmsvga3dBackDXDefineRenderTargetView(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dRenderTargetViewId renderTargetViewId, SVGACOTableDXRTViewEntry const *pEntry)
     3948{
     3949    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
    24863950    RT_NOREF(pBackend);
    2487     AssertFailed(); /** @todo Implement */
    2488 }
    2489 
    2490 
    2491 static DECLCALLBACK(void) vmsvga3dDXSetTopology(PVMSVGA3DSTATE p3dState)
    2492 {
    2493     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
     3951
     3952    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     3953    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     3954
     3955    /* Get corresponding resource for pEntry->sid. Create the surface if does not yet exist. */
     3956    PVMSVGA3DSURFACE pSurface;
     3957    int rc = vmsvga3dSurfaceFromSid(pThisCC->svga.p3dState, pEntry->sid, &pSurface);
     3958    AssertRCReturn(rc, rc);
     3959
     3960    if (pSurface->pBackendSurface == NULL)
     3961    {
     3962        /* Create the actual texture. */
     3963        rc = vmsvga3dBackSurfaceCreateRenderTarget(pThisCC->svga.p3dState, pDXContext, pSurface);
     3964        AssertRCReturn(rc, rc);
     3965    }
     3966
     3967    HRESULT hr = dxRenderTargetViewCreate(pDevice, pEntry, pSurface->pBackendSurface, &pDXContext->pBackendDXContext->papRenderTargetView[renderTargetViewId]);
     3968    if (SUCCEEDED(hr))
     3969        return VINF_SUCCESS;
     3970    return VERR_INVALID_STATE;
     3971}
     3972
     3973
     3974static DECLCALLBACK(int) vmsvga3dBackDXDestroyRenderTargetView(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3975{
     3976    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3977
     3978    RT_NOREF(pBackend, pDXContext);
     3979    AssertFailed(); /** @todo Implement */
     3980    return VERR_NOT_IMPLEMENTED;
     3981}
     3982
     3983
     3984static DECLCALLBACK(int) vmsvga3dBackDXDefineDepthStencilView(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3985{
     3986    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3987
     3988    RT_NOREF(pBackend, pDXContext);
     3989    AssertFailed(); /** @todo Implement */
     3990    return VERR_NOT_IMPLEMENTED;
     3991}
     3992
     3993
     3994static DECLCALLBACK(int) vmsvga3dBackDXDestroyDepthStencilView(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     3995{
     3996    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     3997
     3998    RT_NOREF(pBackend, pDXContext);
     3999    AssertFailed(); /** @todo Implement */
     4000    return VERR_NOT_IMPLEMENTED;
     4001}
     4002
     4003
     4004static DECLCALLBACK(int) vmsvga3dBackDXDefineElementLayout(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dElementLayoutId elementLayoutId, SVGACOTableDXElementLayoutEntry const *pEntry)
     4005{
     4006    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4007    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     4008    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
     4009
     4010    RT_NOREF(pBackend, elementLayoutId, pEntry);
     4011
     4012    /* Not much can be done here because ID3D11Device::CreateInputLayout requires
     4013     * a pShaderBytecodeWithInputSignature which is not known at this moment.
     4014     * InputLayout object will be created in SVGA_3D_CMD_DX_SET_INPUT_LAYOUT.
     4015     */
     4016
     4017    DXELEMENTLAYOUT *pDXElementLayout = &pDXContext->pBackendDXContext->paElementLayout[pEntry->elid];
     4018    D3D_RELEASE(pDXElementLayout->pElementLayout);
     4019
     4020    /* Semantic name is not interpreted by D3D, therefore arbitrary names can be used
     4021     * if they are consistent between the element layout and shader input signature.
     4022     * "In general, data passed between pipeline stages is completely generic and is not uniquely
     4023     * interpreted by the system; arbitrary semantics are allowed ..."
     4024     *
     4025     * However D3D runtime insists that "SemanticName string ("POSITIO1") cannot end with a number."
     4026     *
     4027     * System-Value semantics ("SV_*") between shaders require proper names of course.
     4028     * But they are irrelevant for input attributes.
     4029     */
     4030    pDXElementLayout->cElementDesc = pEntry->numDescs;
     4031    for (uint32_t i = 0; i < pEntry->numDescs; ++i)
     4032    {
     4033        D3D11_INPUT_ELEMENT_DESC *pDst = &pDXElementLayout->aElementDesc[i];
     4034        SVGA3dInputElementDesc const *pSrc = &pEntry->descs[i];
     4035        pDst->SemanticName         = "ATTRIB";
     4036        pDst->SemanticIndex        = i; /// @todo 'pSrc->inputRegister' is unused, maybe it should somehow.
     4037        pDst->Format               = vmsvgaDXSurfaceFormat2Dxgi(pSrc->format);
     4038        AssertReturn(pDst->Format != DXGI_FORMAT_UNKNOWN, VERR_NOT_IMPLEMENTED);
     4039        pDst->InputSlot            = pSrc->inputSlot;
     4040        pDst->AlignedByteOffset    = pSrc->alignedByteOffset;
     4041        pDst->InputSlotClass       = (D3D11_INPUT_CLASSIFICATION)pSrc->inputSlotClass;
     4042        pDst->InstanceDataStepRate = pSrc->instanceDataStepRate;
     4043    }
     4044
     4045    return VINF_SUCCESS;
     4046}
     4047
     4048
     4049static DECLCALLBACK(int) vmsvga3dBackDXDestroyElementLayout(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4050{
     4051    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4052
     4053    RT_NOREF(pBackend, pDXContext);
     4054    AssertFailed(); /** @todo Implement */
     4055    return VERR_NOT_IMPLEMENTED;
     4056}
     4057
     4058
     4059static DECLCALLBACK(int) vmsvga3dBackDXDefineBlendState(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext,
     4060                                                        SVGA3dBlendStateId blendId, SVGACOTableDXBlendStateEntry const *pEntry)
     4061{
     4062    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4063    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     4064    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
    24944065
    24954066    RT_NOREF(pBackend);
    2496     AssertFailed(); /** @todo Implement */
    2497 }
    2498 
    2499 
    2500 static DECLCALLBACK(void) vmsvga3dDXSetRenderTargets(PVMSVGA3DSTATE p3dState)
    2501 {
    2502     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
     4067
     4068    HRESULT hr = dxBlendStateCreate(pDevice, pEntry, &pDXContext->pBackendDXContext->papBlendState[blendId]);
     4069    if (SUCCEEDED(hr))
     4070        return VINF_SUCCESS;
     4071    return VERR_INVALID_STATE;
     4072}
     4073
     4074
     4075static DECLCALLBACK(int) vmsvga3dBackDXDestroyBlendState(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4076{
     4077    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4078
     4079    RT_NOREF(pBackend, pDXContext);
     4080    AssertFailed(); /** @todo Implement */
     4081    return VERR_NOT_IMPLEMENTED;
     4082}
     4083
     4084
     4085static DECLCALLBACK(int) vmsvga3dBackDXDefineDepthStencilState(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dDepthStencilStateId depthStencilId, SVGACOTableDXDepthStencilEntry *pEntry)
     4086{
     4087    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4088    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     4089    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
    25034090
    25044091    RT_NOREF(pBackend);
    2505     AssertFailed(); /** @todo Implement */
    2506 }
    2507 
    2508 
    2509 static DECLCALLBACK(void) vmsvga3dDXSetBlendState(PVMSVGA3DSTATE p3dState)
    2510 {
    2511     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
     4092
     4093    HRESULT hr = dxDepthStencilStateCreate(pDevice, pEntry, &pDXContext->pBackendDXContext->papDepthStencilState[depthStencilId]);
     4094    if (SUCCEEDED(hr))
     4095        return VINF_SUCCESS;
     4096    return VERR_INVALID_STATE;
     4097}
     4098
     4099
     4100static DECLCALLBACK(int) vmsvga3dBackDXDestroyDepthStencilState(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4101{
     4102    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4103
     4104    RT_NOREF(pBackend, pDXContext);
     4105    AssertFailed(); /** @todo Implement */
     4106    return VERR_NOT_IMPLEMENTED;
     4107}
     4108
     4109
     4110static DECLCALLBACK(int) vmsvga3dBackDXDefineRasterizerState(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dRasterizerStateId rasterizerId, SVGACOTableDXRasterizerStateEntry const *pEntry)
     4111{
     4112    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4113    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     4114    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
    25124115
    25134116    RT_NOREF(pBackend);
    2514     AssertFailed(); /** @todo Implement */
    2515 }
    2516 
    2517 
    2518 static DECLCALLBACK(void) vmsvga3dDXSetDepthStencilState(PVMSVGA3DSTATE p3dState)
    2519 {
    2520     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
     4117
     4118    HRESULT hr = dxRasterizerStateCreate(pDevice, pEntry, &pDXContext->pBackendDXContext->papRasterizerState[rasterizerId]);
     4119    if (SUCCEEDED(hr))
     4120        return VINF_SUCCESS;
     4121    return VERR_INVALID_STATE;
     4122}
     4123
     4124
     4125static DECLCALLBACK(int) vmsvga3dBackDXDestroyRasterizerState(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4126{
     4127    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4128
     4129    RT_NOREF(pBackend, pDXContext);
     4130    AssertFailed(); /** @todo Implement */
     4131    return VERR_NOT_IMPLEMENTED;
     4132}
     4133
     4134
     4135static DECLCALLBACK(int) vmsvga3dBackDXDefineSamplerState(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dSamplerId samplerId, SVGACOTableDXSamplerEntry const *pEntry)
     4136{
     4137    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4138    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     4139    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
    25214140
    25224141    RT_NOREF(pBackend);
    2523     AssertFailed(); /** @todo Implement */
    2524 }
    2525 
    2526 
    2527 static DECLCALLBACK(void) vmsvga3dDXSetRasterizerState(PVMSVGA3DSTATE p3dState)
    2528 {
    2529     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
     4142
     4143    HRESULT hr = dxSamplerStateCreate(pDevice, pEntry, &pDXContext->pBackendDXContext->papSamplerState[samplerId]);
     4144    if (SUCCEEDED(hr))
     4145        return VINF_SUCCESS;
     4146    return VERR_INVALID_STATE;
     4147}
     4148
     4149
     4150static DECLCALLBACK(int) vmsvga3dBackDXDestroySamplerState(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4151{
     4152    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4153
     4154    RT_NOREF(pBackend, pDXContext);
     4155    AssertFailed(); /** @todo Implement */
     4156    return VERR_NOT_IMPLEMENTED;
     4157}
     4158
     4159
     4160static DECLCALLBACK(int) vmsvga3dBackDXDefineShader(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, PVMSVGA3DSHADER pShader)
     4161{
     4162    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
    25304163
    25314164    RT_NOREF(pBackend);
    2532     AssertFailed(); /** @todo Implement */
    2533 }
    2534 
    2535 
    2536 static DECLCALLBACK(void) vmsvga3dDXDefineQuery(PVMSVGA3DSTATE p3dState)
    2537 {
    2538     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
     4165
     4166    DXSHADER *pDXShader = &pDXContext->pBackendDXContext->paShader[pShader->id];
     4167    D3D_RELEASE(pDXShader->pShader);
     4168    pDXShader->enmShaderType = pShader->type;
     4169    pShader->u.pvBackendShader = pDXShader;
     4170    return VINF_SUCCESS;
     4171}
     4172
     4173
     4174static DECLCALLBACK(int) vmsvga3dBackDXDestroyShader(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4175{
     4176    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4177
     4178    RT_NOREF(pBackend, pDXContext);
     4179    AssertFailed(); /** @todo Implement */
     4180    return VERR_NOT_IMPLEMENTED;
     4181}
     4182
     4183
     4184static DECLCALLBACK(int) vmsvga3dBackDXBindShader(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, PVMSVGA3DSHADER pShader, void const *pvShaderBytecode)
     4185{
     4186    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4187    DXDEVICE *pDevice = &pDXContext->pBackendDXContext->device;
     4188    AssertReturn(pDevice->pDevice, VERR_INVALID_STATE);
    25394189
    25404190    RT_NOREF(pBackend);
    2541     AssertFailed(); /** @todo Implement */
    2542 }
    2543 
    2544 
    2545 static DECLCALLBACK(void) vmsvga3dDXDestroyQuery(PVMSVGA3DSTATE p3dState)
    2546 {
    2547     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2548 
    2549     RT_NOREF(pBackend);
    2550     AssertFailed(); /** @todo Implement */
    2551 }
    2552 
    2553 
    2554 static DECLCALLBACK(void) vmsvga3dDXBindQuery(PVMSVGA3DSTATE p3dState)
    2555 {
    2556     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2557 
    2558     RT_NOREF(pBackend);
    2559     AssertFailed(); /** @todo Implement */
    2560 }
    2561 
    2562 
    2563 static DECLCALLBACK(void) vmsvga3dDXSetQueryOffset(PVMSVGA3DSTATE p3dState)
    2564 {
    2565     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2566 
    2567     RT_NOREF(pBackend);
    2568     AssertFailed(); /** @todo Implement */
    2569 }
    2570 
    2571 
    2572 static DECLCALLBACK(void) vmsvga3dDXBeginQuery(PVMSVGA3DSTATE p3dState)
    2573 {
    2574     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2575 
    2576     RT_NOREF(pBackend);
    2577     AssertFailed(); /** @todo Implement */
    2578 }
    2579 
    2580 
    2581 static DECLCALLBACK(void) vmsvga3dDXEndQuery(PVMSVGA3DSTATE p3dState)
    2582 {
    2583     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2584 
    2585     RT_NOREF(pBackend);
    2586     AssertFailed(); /** @todo Implement */
    2587 }
    2588 
    2589 
    2590 static DECLCALLBACK(void) vmsvga3dDXReadbackQuery(PVMSVGA3DSTATE p3dState)
    2591 {
    2592     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2593 
    2594     RT_NOREF(pBackend);
    2595     AssertFailed(); /** @todo Implement */
    2596 }
    2597 
    2598 
    2599 static DECLCALLBACK(void) vmsvga3dDXSetPredication(PVMSVGA3DSTATE p3dState)
    2600 {
    2601     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2602 
    2603     RT_NOREF(pBackend);
    2604     AssertFailed(); /** @todo Implement */
    2605 }
    2606 
    2607 
    2608 static DECLCALLBACK(void) vmsvga3dDXSetSOTargets(PVMSVGA3DSTATE p3dState)
    2609 {
    2610     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2611 
    2612     RT_NOREF(pBackend);
    2613     AssertFailed(); /** @todo Implement */
    2614 }
    2615 
    2616 
    2617 static DECLCALLBACK(void) vmsvga3dDXSetViewports(PVMSVGA3DSTATE p3dState)
    2618 {
    2619     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2620 
    2621     RT_NOREF(pBackend);
    2622     AssertFailed(); /** @todo Implement */
    2623 }
    2624 
    2625 
    2626 static DECLCALLBACK(void) vmsvga3dDXSetScissorRects(PVMSVGA3DSTATE p3dState)
    2627 {
    2628     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2629 
    2630     RT_NOREF(pBackend);
    2631     AssertFailed(); /** @todo Implement */
    2632 }
    2633 
    2634 
    2635 static DECLCALLBACK(void) vmsvga3dDXClearRenderTargetView(PVMSVGA3DSTATE p3dState)
    2636 {
    2637     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2638 
    2639     RT_NOREF(pBackend);
    2640     AssertFailed(); /** @todo Implement */
    2641 }
    2642 
    2643 
    2644 static DECLCALLBACK(void) vmsvga3dDXClearDepthStencilView(PVMSVGA3DSTATE p3dState)
    2645 {
    2646     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2647 
    2648     RT_NOREF(pBackend);
    2649     AssertFailed(); /** @todo Implement */
    2650 }
    2651 
    2652 
    2653 static DECLCALLBACK(void) vmsvga3dDXPredCopyRegion(PVMSVGA3DSTATE p3dState)
    2654 {
    2655     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2656 
    2657     RT_NOREF(pBackend);
    2658     AssertFailed(); /** @todo Implement */
    2659 }
    2660 
    2661 
    2662 static DECLCALLBACK(void) vmsvga3dDXPredCopy(PVMSVGA3DSTATE p3dState)
    2663 {
    2664     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2665 
    2666     RT_NOREF(pBackend);
    2667     AssertFailed(); /** @todo Implement */
    2668 }
    2669 
    2670 
    2671 static DECLCALLBACK(void) vmsvga3dDXPresentBlt(PVMSVGA3DSTATE p3dState)
    2672 {
    2673     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2674 
    2675     RT_NOREF(pBackend);
    2676     AssertFailed(); /** @todo Implement */
    2677 }
    2678 
    2679 
    2680 static DECLCALLBACK(void) vmsvga3dDXGenMips(PVMSVGA3DSTATE p3dState)
    2681 {
    2682     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2683 
    2684     RT_NOREF(pBackend);
    2685     AssertFailed(); /** @todo Implement */
    2686 }
    2687 
    2688 
    2689 static DECLCALLBACK(void) vmsvga3dDXUpdateSubResource(PVMSVGA3DSTATE p3dState)
    2690 {
    2691     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2692 
    2693     RT_NOREF(pBackend);
    2694     AssertFailed(); /** @todo Implement */
    2695 }
    2696 
    2697 
    2698 static DECLCALLBACK(void) vmsvga3dDXReadbackSubResource(PVMSVGA3DSTATE p3dState)
    2699 {
    2700     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2701 
    2702     RT_NOREF(pBackend);
    2703     AssertFailed(); /** @todo Implement */
    2704 }
    2705 
    2706 
    2707 static DECLCALLBACK(void) vmsvga3dDXInvalidateSubResource(PVMSVGA3DSTATE p3dState)
    2708 {
    2709     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2710 
    2711     RT_NOREF(pBackend);
    2712     AssertFailed(); /** @todo Implement */
    2713 }
    2714 
    2715 
    2716 static DECLCALLBACK(void) vmsvga3dDXDefineShaderResourceView(PVMSVGA3DSTATE p3dState)
    2717 {
    2718     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2719 
    2720     RT_NOREF(pBackend);
    2721     AssertFailed(); /** @todo Implement */
    2722 }
    2723 
    2724 
    2725 static DECLCALLBACK(void) vmsvga3dDXDestroyShaderResourceView(PVMSVGA3DSTATE p3dState)
    2726 {
    2727     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2728 
    2729     RT_NOREF(pBackend);
    2730     AssertFailed(); /** @todo Implement */
    2731 }
    2732 
    2733 
    2734 static DECLCALLBACK(void) vmsvga3dDXDefineRenderTargetView(PVMSVGA3DSTATE p3dState)
    2735 {
    2736     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2737 
    2738     RT_NOREF(pBackend);
    2739     AssertFailed(); /** @todo Implement */
    2740 }
    2741 
    2742 
    2743 static DECLCALLBACK(void) vmsvga3dDXDestroyRenderTargetView(PVMSVGA3DSTATE p3dState)
    2744 {
    2745     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2746 
    2747     RT_NOREF(pBackend);
    2748     AssertFailed(); /** @todo Implement */
    2749 }
    2750 
    2751 
    2752 static DECLCALLBACK(void) vmsvga3dDXDefineDepthStencilView(PVMSVGA3DSTATE p3dState)
    2753 {
    2754     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2755 
    2756     RT_NOREF(pBackend);
    2757     AssertFailed(); /** @todo Implement */
    2758 }
    2759 
    2760 
    2761 static DECLCALLBACK(void) vmsvga3dDXDestroyDepthStencilView(PVMSVGA3DSTATE p3dState)
    2762 {
    2763     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2764 
    2765     RT_NOREF(pBackend);
    2766     AssertFailed(); /** @todo Implement */
    2767 }
    2768 
    2769 
    2770 static DECLCALLBACK(void) vmsvga3dDXDefineElementLayout(PVMSVGA3DSTATE p3dState)
    2771 {
    2772     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2773 
    2774     RT_NOREF(pBackend);
    2775     AssertFailed(); /** @todo Implement */
    2776 }
    2777 
    2778 
    2779 static DECLCALLBACK(void) vmsvga3dDXDestroyElementLayout(PVMSVGA3DSTATE p3dState)
    2780 {
    2781     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2782 
    2783     RT_NOREF(pBackend);
    2784     AssertFailed(); /** @todo Implement */
    2785 }
    2786 
    2787 
    2788 static DECLCALLBACK(void) vmsvga3dDXDefineBlendState(PVMSVGA3DSTATE p3dState)
    2789 {
    2790     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2791 
    2792     RT_NOREF(pBackend);
    2793     AssertFailed(); /** @todo Implement */
    2794 }
    2795 
    2796 
    2797 static DECLCALLBACK(void) vmsvga3dDXDestroyBlendState(PVMSVGA3DSTATE p3dState)
    2798 {
    2799     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2800 
    2801     RT_NOREF(pBackend);
    2802     AssertFailed(); /** @todo Implement */
    2803 }
    2804 
    2805 
    2806 static DECLCALLBACK(void) vmsvga3dDXDefineDepthStencilState(PVMSVGA3DSTATE p3dState)
    2807 {
    2808     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2809 
    2810     RT_NOREF(pBackend);
    2811     AssertFailed(); /** @todo Implement */
    2812 }
    2813 
    2814 
    2815 static DECLCALLBACK(void) vmsvga3dDXDestroyDepthStencilState(PVMSVGA3DSTATE p3dState)
    2816 {
    2817     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2818 
    2819     RT_NOREF(pBackend);
    2820     AssertFailed(); /** @todo Implement */
    2821 }
    2822 
    2823 
    2824 static DECLCALLBACK(void) vmsvga3dDXDefineRasterizerState(PVMSVGA3DSTATE p3dState)
    2825 {
    2826     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2827 
    2828     RT_NOREF(pBackend);
    2829     AssertFailed(); /** @todo Implement */
    2830 }
    2831 
    2832 
    2833 static DECLCALLBACK(void) vmsvga3dDXDestroyRasterizerState(PVMSVGA3DSTATE p3dState)
    2834 {
    2835     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2836 
    2837     RT_NOREF(pBackend);
    2838     AssertFailed(); /** @todo Implement */
    2839 }
    2840 
    2841 
    2842 static DECLCALLBACK(void) vmsvga3dDXDefineSamplerState(PVMSVGA3DSTATE p3dState)
    2843 {
    2844     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2845 
    2846     RT_NOREF(pBackend);
    2847     AssertFailed(); /** @todo Implement */
    2848 }
    2849 
    2850 
    2851 static DECLCALLBACK(void) vmsvga3dDXDestroySamplerState(PVMSVGA3DSTATE p3dState)
    2852 {
    2853     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2854 
    2855     RT_NOREF(pBackend);
    2856     AssertFailed(); /** @todo Implement */
    2857 }
    2858 
    2859 
    2860 static DECLCALLBACK(void) vmsvga3dDXDefineShader(PVMSVGA3DSTATE p3dState)
    2861 {
    2862     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2863 
    2864     RT_NOREF(pBackend);
    2865     AssertFailed(); /** @todo Implement */
    2866 }
    2867 
    2868 
    2869 static DECLCALLBACK(void) vmsvga3dDXDestroyShader(PVMSVGA3DSTATE p3dState)
    2870 {
    2871     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2872 
    2873     RT_NOREF(pBackend);
    2874     AssertFailed(); /** @todo Implement */
    2875 }
    2876 
    2877 
    2878 static DECLCALLBACK(void) vmsvga3dDXBindShader(PVMSVGA3DSTATE p3dState)
    2879 {
    2880     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2881 
    2882     RT_NOREF(pBackend);
    2883     AssertFailed(); /** @todo Implement */
    2884 }
    2885 
    2886 
    2887 static DECLCALLBACK(void) vmsvga3dDXDefineStreamOutput(PVMSVGA3DSTATE p3dState)
    2888 {
    2889     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2890 
    2891     RT_NOREF(pBackend);
    2892     AssertFailed(); /** @todo Implement */
    2893 }
    2894 
    2895 
    2896 static DECLCALLBACK(void) vmsvga3dDXDestroyStreamOutput(PVMSVGA3DSTATE p3dState)
    2897 {
    2898     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2899 
    2900     RT_NOREF(pBackend);
    2901     AssertFailed(); /** @todo Implement */
    2902 }
    2903 
    2904 
    2905 static DECLCALLBACK(void) vmsvga3dDXSetStreamOutput(PVMSVGA3DSTATE p3dState)
    2906 {
    2907     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2908 
    2909     RT_NOREF(pBackend);
    2910     AssertFailed(); /** @todo Implement */
    2911 }
    2912 
    2913 
    2914 static DECLCALLBACK(void) vmsvga3dDXSetCOTable(PVMSVGA3DSTATE p3dState)
    2915 {
    2916     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2917 
    2918     RT_NOREF(pBackend);
    2919     AssertFailed(); /** @todo Implement */
    2920 }
    2921 
    2922 
    2923 static DECLCALLBACK(void) vmsvga3dDXReadbackCOTable(PVMSVGA3DSTATE p3dState)
    2924 {
    2925     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2926 
    2927     RT_NOREF(pBackend);
    2928     AssertFailed(); /** @todo Implement */
    2929 }
    2930 
    2931 
    2932 static DECLCALLBACK(void) vmsvga3dDXBufferCopy(PVMSVGA3DSTATE p3dState)
    2933 {
    2934     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2935 
    2936     RT_NOREF(pBackend);
    2937     AssertFailed(); /** @todo Implement */
    2938 }
    2939 
    2940 
    2941 static DECLCALLBACK(void) vmsvga3dDXTransferFromBuffer(PVMSVGA3DSTATE p3dState)
    2942 {
    2943     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2944 
    2945     RT_NOREF(pBackend);
    2946     AssertFailed(); /** @todo Implement */
    2947 }
    2948 
    2949 
    2950 static DECLCALLBACK(void) vmsvga3dDXSurfaceCopyAndReadback(PVMSVGA3DSTATE p3dState)
    2951 {
    2952     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2953 
    2954     RT_NOREF(pBackend);
    2955     AssertFailed(); /** @todo Implement */
    2956 }
    2957 
    2958 
    2959 static DECLCALLBACK(void) vmsvga3dDXMoveQuery(PVMSVGA3DSTATE p3dState)
    2960 {
    2961     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2962 
    2963     RT_NOREF(pBackend);
    2964     AssertFailed(); /** @todo Implement */
    2965 }
    2966 
    2967 
    2968 static DECLCALLBACK(void) vmsvga3dDXBindAllQuery(PVMSVGA3DSTATE p3dState)
    2969 {
    2970     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2971 
    2972     RT_NOREF(pBackend);
    2973     AssertFailed(); /** @todo Implement */
    2974 }
    2975 
    2976 
    2977 static DECLCALLBACK(void) vmsvga3dDXReadbackAllQuery(PVMSVGA3DSTATE p3dState)
    2978 {
    2979     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2980 
    2981     RT_NOREF(pBackend);
    2982     AssertFailed(); /** @todo Implement */
    2983 }
    2984 
    2985 
    2986 static DECLCALLBACK(void) vmsvga3dDXPredTransferFromBuffer(PVMSVGA3DSTATE p3dState)
    2987 {
    2988     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2989 
    2990     RT_NOREF(pBackend);
    2991     AssertFailed(); /** @todo Implement */
    2992 }
    2993 
    2994 
    2995 static DECLCALLBACK(void) vmsvga3dDXMobFence64(PVMSVGA3DSTATE p3dState)
    2996 {
    2997     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    2998 
    2999     RT_NOREF(pBackend);
    3000     AssertFailed(); /** @todo Implement */
    3001 }
    3002 
    3003 
    3004 static DECLCALLBACK(void) vmsvga3dDXBindAllShader(PVMSVGA3DSTATE p3dState)
    3005 {
    3006     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3007 
    3008     RT_NOREF(pBackend);
    3009     AssertFailed(); /** @todo Implement */
    3010 }
    3011 
    3012 
    3013 static DECLCALLBACK(void) vmsvga3dDXHint(PVMSVGA3DSTATE p3dState)
    3014 {
    3015     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3016 
    3017     RT_NOREF(pBackend);
    3018     AssertFailed(); /** @todo Implement */
    3019 }
    3020 
    3021 
    3022 static DECLCALLBACK(void) vmsvga3dDXBufferUpdate(PVMSVGA3DSTATE p3dState)
    3023 {
    3024     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3025 
    3026     RT_NOREF(pBackend);
    3027     AssertFailed(); /** @todo Implement */
    3028 }
    3029 
    3030 
    3031 static DECLCALLBACK(void) vmsvga3dDXSetVSConstantBufferOffset(PVMSVGA3DSTATE p3dState)
    3032 {
    3033     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3034 
    3035     RT_NOREF(pBackend);
    3036     AssertFailed(); /** @todo Implement */
    3037 }
    3038 
    3039 
    3040 static DECLCALLBACK(void) vmsvga3dDXSetPSConstantBufferOffset(PVMSVGA3DSTATE p3dState)
    3041 {
    3042     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3043 
    3044     RT_NOREF(pBackend);
    3045     AssertFailed(); /** @todo Implement */
    3046 }
    3047 
    3048 
    3049 static DECLCALLBACK(void) vmsvga3dDXSetGSConstantBufferOffset(PVMSVGA3DSTATE p3dState)
    3050 {
    3051     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3052 
    3053     RT_NOREF(pBackend);
    3054     AssertFailed(); /** @todo Implement */
    3055 }
    3056 
    3057 
    3058 static DECLCALLBACK(void) vmsvga3dDXSetHSConstantBufferOffset(PVMSVGA3DSTATE p3dState)
    3059 {
    3060     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3061 
    3062     RT_NOREF(pBackend);
    3063     AssertFailed(); /** @todo Implement */
    3064 }
    3065 
    3066 
    3067 static DECLCALLBACK(void) vmsvga3dDXSetDSConstantBufferOffset(PVMSVGA3DSTATE p3dState)
    3068 {
    3069     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3070 
    3071     RT_NOREF(pBackend);
    3072     AssertFailed(); /** @todo Implement */
    3073 }
    3074 
    3075 
    3076 static DECLCALLBACK(void) vmsvga3dDXSetCSConstantBufferOffset(PVMSVGA3DSTATE p3dState)
    3077 {
    3078     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3079 
    3080     RT_NOREF(pBackend);
    3081     AssertFailed(); /** @todo Implement */
    3082 }
    3083 
    3084 
    3085 static DECLCALLBACK(void) vmsvga3dDXCondBindAllShader(PVMSVGA3DSTATE p3dState)
    3086 {
    3087     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3088 
    3089     RT_NOREF(pBackend);
    3090     AssertFailed(); /** @todo Implement */
    3091 }
    3092 
    3093 
    3094 static DECLCALLBACK(void) vmsvga3dScreenCopy(PVMSVGA3DSTATE p3dState)
    3095 {
    3096     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3097 
    3098     RT_NOREF(pBackend);
    3099     AssertFailed(); /** @todo Implement */
    3100 }
    3101 
    3102 
    3103 static DECLCALLBACK(void) vmsvga3dGrowOTable(PVMSVGA3DSTATE p3dState)
    3104 {
    3105     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3106 
    3107     RT_NOREF(pBackend);
    3108     AssertFailed(); /** @todo Implement */
    3109 }
    3110 
    3111 
    3112 static DECLCALLBACK(void) vmsvga3dDXGrowCOTable(PVMSVGA3DSTATE p3dState)
    3113 {
    3114     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3115 
    3116     RT_NOREF(pBackend);
    3117     AssertFailed(); /** @todo Implement */
    3118 }
    3119 
    3120 
    3121 static DECLCALLBACK(void) vmsvga3dIntraSurfaceCopy(PVMSVGA3DSTATE p3dState)
    3122 {
    3123     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3124 
    3125     RT_NOREF(pBackend);
    3126     AssertFailed(); /** @todo Implement */
    3127 }
    3128 
    3129 
    3130 static DECLCALLBACK(void) vmsvga3dDefineGBSurface_v3(PVMSVGA3DSTATE p3dState)
    3131 {
    3132     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3133 
    3134     RT_NOREF(pBackend);
    3135     AssertFailed(); /** @todo Implement */
    3136 }
    3137 
    3138 
    3139 static DECLCALLBACK(void) vmsvga3dDXResolveCopy(PVMSVGA3DSTATE p3dState)
    3140 {
    3141     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3142 
    3143     RT_NOREF(pBackend);
    3144     AssertFailed(); /** @todo Implement */
    3145 }
    3146 
    3147 
    3148 static DECLCALLBACK(void) vmsvga3dDXPredResolveCopy(PVMSVGA3DSTATE p3dState)
    3149 {
    3150     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3151 
    3152     RT_NOREF(pBackend);
    3153     AssertFailed(); /** @todo Implement */
    3154 }
    3155 
    3156 
    3157 static DECLCALLBACK(void) vmsvga3dDXPredConvertRegion(PVMSVGA3DSTATE p3dState)
    3158 {
    3159     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3160 
    3161     RT_NOREF(pBackend);
    3162     AssertFailed(); /** @todo Implement */
    3163 }
    3164 
    3165 
    3166 static DECLCALLBACK(void) vmsvga3dDXPredConvert(PVMSVGA3DSTATE p3dState)
    3167 {
    3168     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3169 
    3170     RT_NOREF(pBackend);
    3171     AssertFailed(); /** @todo Implement */
    3172 }
    3173 
    3174 
    3175 static DECLCALLBACK(void) vmsvga3dWholeSurfaceCopy(PVMSVGA3DSTATE p3dState)
    3176 {
    3177     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3178 
    3179     RT_NOREF(pBackend);
    3180     AssertFailed(); /** @todo Implement */
    3181 }
    3182 
    3183 
    3184 static DECLCALLBACK(void) vmsvga3dDXDefineUAView(PVMSVGA3DSTATE p3dState)
    3185 {
    3186     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3187 
    3188     RT_NOREF(pBackend);
    3189     AssertFailed(); /** @todo Implement */
    3190 }
    3191 
    3192 
    3193 static DECLCALLBACK(void) vmsvga3dDXDestroyUAView(PVMSVGA3DSTATE p3dState)
    3194 {
    3195     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3196 
    3197     RT_NOREF(pBackend);
    3198     AssertFailed(); /** @todo Implement */
    3199 }
    3200 
    3201 
    3202 static DECLCALLBACK(void) vmsvga3dDXClearUAViewUint(PVMSVGA3DSTATE p3dState)
    3203 {
    3204     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3205 
    3206     RT_NOREF(pBackend);
    3207     AssertFailed(); /** @todo Implement */
    3208 }
    3209 
    3210 
    3211 static DECLCALLBACK(void) vmsvga3dDXClearUAViewFloat(PVMSVGA3DSTATE p3dState)
    3212 {
    3213     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3214 
    3215     RT_NOREF(pBackend);
    3216     AssertFailed(); /** @todo Implement */
    3217 }
    3218 
    3219 
    3220 static DECLCALLBACK(void) vmsvga3dDXCopyStructureCount(PVMSVGA3DSTATE p3dState)
    3221 {
    3222     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3223 
    3224     RT_NOREF(pBackend);
    3225     AssertFailed(); /** @todo Implement */
    3226 }
    3227 
    3228 
    3229 static DECLCALLBACK(void) vmsvga3dDXSetUAViews(PVMSVGA3DSTATE p3dState)
    3230 {
    3231     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3232 
    3233     RT_NOREF(pBackend);
    3234     AssertFailed(); /** @todo Implement */
    3235 }
    3236 
    3237 
    3238 static DECLCALLBACK(void) vmsvga3dDXDrawIndexedInstancedIndirect(PVMSVGA3DSTATE p3dState)
    3239 {
    3240     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3241 
    3242     RT_NOREF(pBackend);
    3243     AssertFailed(); /** @todo Implement */
    3244 }
    3245 
    3246 
    3247 static DECLCALLBACK(void) vmsvga3dDXDrawInstancedIndirect(PVMSVGA3DSTATE p3dState)
    3248 {
    3249     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3250 
    3251     RT_NOREF(pBackend);
    3252     AssertFailed(); /** @todo Implement */
    3253 }
    3254 
    3255 
    3256 static DECLCALLBACK(void) vmsvga3dDXDispatch(PVMSVGA3DSTATE p3dState)
    3257 {
    3258     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3259 
    3260     RT_NOREF(pBackend);
    3261     AssertFailed(); /** @todo Implement */
    3262 }
    3263 
    3264 
    3265 static DECLCALLBACK(void) vmsvga3dDXDispatchIndirect(PVMSVGA3DSTATE p3dState)
    3266 {
    3267     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3268 
    3269     RT_NOREF(pBackend);
    3270     AssertFailed(); /** @todo Implement */
    3271 }
    3272 
    3273 
    3274 static DECLCALLBACK(void) vmsvga3dWriteZeroSurface(PVMSVGA3DSTATE p3dState)
    3275 {
    3276     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3277 
    3278     RT_NOREF(pBackend);
    3279     AssertFailed(); /** @todo Implement */
    3280 }
    3281 
    3282 
    3283 static DECLCALLBACK(void) vmsvga3dHintZeroSurface(PVMSVGA3DSTATE p3dState)
    3284 {
    3285     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3286 
    3287     RT_NOREF(pBackend);
    3288     AssertFailed(); /** @todo Implement */
    3289 }
    3290 
    3291 
    3292 static DECLCALLBACK(void) vmsvga3dDXTransferToBuffer(PVMSVGA3DSTATE p3dState)
    3293 {
    3294     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3295 
    3296     RT_NOREF(pBackend);
    3297     AssertFailed(); /** @todo Implement */
    3298 }
    3299 
    3300 
    3301 static DECLCALLBACK(void) vmsvga3dDXSetStructureCount(PVMSVGA3DSTATE p3dState)
    3302 {
    3303     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3304 
    3305     RT_NOREF(pBackend);
    3306     AssertFailed(); /** @todo Implement */
    3307 }
    3308 
    3309 
    3310 static DECLCALLBACK(void) vmsvga3dLogicOpsBitBlt(PVMSVGA3DSTATE p3dState)
    3311 {
    3312     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3313 
    3314     RT_NOREF(pBackend);
    3315     AssertFailed(); /** @todo Implement */
    3316 }
    3317 
    3318 
    3319 static DECLCALLBACK(void) vmsvga3dLogicOpsTransBlt(PVMSVGA3DSTATE p3dState)
    3320 {
    3321     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3322 
    3323     RT_NOREF(pBackend);
    3324     AssertFailed(); /** @todo Implement */
    3325 }
    3326 
    3327 
    3328 static DECLCALLBACK(void) vmsvga3dLogicOpsStretchBlt(PVMSVGA3DSTATE p3dState)
    3329 {
    3330     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3331 
    3332     RT_NOREF(pBackend);
    3333     AssertFailed(); /** @todo Implement */
    3334 }
    3335 
    3336 
    3337 static DECLCALLBACK(void) vmsvga3dLogicOpsColorFill(PVMSVGA3DSTATE p3dState)
    3338 {
    3339     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3340 
    3341     RT_NOREF(pBackend);
    3342     AssertFailed(); /** @todo Implement */
    3343 }
    3344 
    3345 
    3346 static DECLCALLBACK(void) vmsvga3dLogicOpsAlphaBlend(PVMSVGA3DSTATE p3dState)
    3347 {
    3348     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3349 
    3350     RT_NOREF(pBackend);
    3351     AssertFailed(); /** @todo Implement */
    3352 }
    3353 
    3354 
    3355 static DECLCALLBACK(void) vmsvga3dLogicOpsClearTypeBlend(PVMSVGA3DSTATE p3dState)
    3356 {
    3357     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3358 
    3359     RT_NOREF(pBackend);
    3360     AssertFailed(); /** @todo Implement */
    3361 }
    3362 
    3363 
    3364 static DECLCALLBACK(void) vmsvga3dDefineGBSurface_v4(PVMSVGA3DSTATE p3dState)
    3365 {
    3366     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3367 
    3368     RT_NOREF(pBackend);
    3369     AssertFailed(); /** @todo Implement */
    3370 }
    3371 
    3372 
    3373 static DECLCALLBACK(void) vmsvga3dDXSetCSUAViews(PVMSVGA3DSTATE p3dState)
    3374 {
    3375     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3376 
    3377     RT_NOREF(pBackend);
    3378     AssertFailed(); /** @todo Implement */
    3379 }
    3380 
    3381 
    3382 static DECLCALLBACK(void) vmsvga3dDXSetMinLOD(PVMSVGA3DSTATE p3dState)
    3383 {
    3384     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3385 
    3386     RT_NOREF(pBackend);
    3387     AssertFailed(); /** @todo Implement */
    3388 }
    3389 
    3390 
    3391 static DECLCALLBACK(void) vmsvga3dDXDefineDepthStencilView_v2(PVMSVGA3DSTATE p3dState)
    3392 {
    3393     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3394 
    3395     RT_NOREF(pBackend);
    3396     AssertFailed(); /** @todo Implement */
    3397 }
    3398 
    3399 
    3400 static DECLCALLBACK(void) vmsvga3dDXDefineStreamOutputWithMob(PVMSVGA3DSTATE p3dState)
    3401 {
    3402     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3403 
    3404     RT_NOREF(pBackend);
    3405     AssertFailed(); /** @todo Implement */
    3406 }
    3407 
    3408 
    3409 static DECLCALLBACK(void) vmsvga3dDXSetShaderIface(PVMSVGA3DSTATE p3dState)
    3410 {
    3411     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3412 
    3413     RT_NOREF(pBackend);
    3414     AssertFailed(); /** @todo Implement */
    3415 }
    3416 
    3417 
    3418 static DECLCALLBACK(void) vmsvga3dDXBindStreamOutput(PVMSVGA3DSTATE p3dState)
    3419 {
    3420     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3421 
    3422     RT_NOREF(pBackend);
    3423     AssertFailed(); /** @todo Implement */
    3424 }
    3425 
    3426 
    3427 static DECLCALLBACK(void) vmsvga3dSurfaceStretchBltNonMSToMS(PVMSVGA3DSTATE p3dState)
    3428 {
    3429     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3430 
    3431     RT_NOREF(pBackend);
    3432     AssertFailed(); /** @todo Implement */
    3433 }
    3434 
    3435 
    3436 static DECLCALLBACK(void) vmsvga3dDXBindShaderIface(PVMSVGA3DSTATE p3dState)
    3437 {
    3438     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
    3439 
    3440     RT_NOREF(pBackend);
    3441     AssertFailed(); /** @todo Implement */
     4191
     4192    int rc = VINF_SUCCESS;
     4193
     4194    DXSHADER *pDXShader = &pDXContext->pBackendDXContext->paShader[pShader->id];
     4195    if (pDXShader->pvDXBC)
     4196    {
     4197        RTMemFree(pDXShader->pvDXBC);
     4198        pDXShader->pvDXBC = NULL;
     4199        pDXShader->cbDXBC = 0;
     4200    }
     4201
     4202    if (pvShaderBytecode)
     4203    {
     4204#ifdef LOG_ENABLED
     4205        Log(("Shader: cid=%u shid=%u type=%d:\n", pDXContext->cid, pShader->id, pDXShader->enmShaderType));
     4206        uint8_t *pu8 = (uint8_t *)pvShaderBytecode;
     4207        for (uint32_t i = 0; i < pShader->cbData; ++i)
     4208        {
     4209            if ((i % 16) == 0)
     4210            {
     4211                if (i > 0)
     4212                    Log((",\n"));
     4213
     4214                Log(("    %#04x", pu8[i]));
     4215            }
     4216            else
     4217            {
     4218                Log((", %#04x", pu8[i]));
     4219            }
     4220        }
     4221        Log(("\n"));
     4222#endif
     4223
     4224        rc = DXShaderCreateDXBC(&pShader->shaderInfo, pvShaderBytecode, pShader->cbData, &pDXShader->pvDXBC, &pDXShader->cbDXBC);
     4225        if (RT_SUCCESS(rc))
     4226        {
     4227            HRESULT hr = dxShaderCreate(pDevice, pShader, pDXShader);
     4228            if (FAILED(hr))
     4229                rc = VERR_INVALID_STATE;
     4230        }
     4231        else
     4232            rc = VERR_NO_MEMORY;
     4233    }
     4234
     4235    return rc;
     4236}
     4237
     4238
     4239static DECLCALLBACK(int) vmsvga3dBackDXDefineStreamOutput(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4240{
     4241    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4242
     4243    RT_NOREF(pBackend, pDXContext);
     4244    AssertFailed(); /** @todo Implement */
     4245    return VERR_NOT_IMPLEMENTED;
     4246}
     4247
     4248
     4249static DECLCALLBACK(int) vmsvga3dBackDXDestroyStreamOutput(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4250{
     4251    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4252
     4253    RT_NOREF(pBackend, pDXContext);
     4254    AssertFailed(); /** @todo Implement */
     4255    return VERR_NOT_IMPLEMENTED;
     4256}
     4257
     4258
     4259static DECLCALLBACK(int) vmsvga3dBackDXSetStreamOutput(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4260{
     4261    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4262
     4263    RT_NOREF(pBackend, pDXContext);
     4264    AssertFailed(); /** @todo Implement */
     4265    return VERR_NOT_IMPLEMENTED;
     4266}
     4267
     4268static DECLCALLBACK(int) vmsvga3dBackDXSetCOTable(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGACOTableType type, uint32_t cEntries)
     4269{
     4270    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4271    VMSVGA3DBACKENDDXCONTEXT *pBackendDXContext = pDXContext->pBackendDXContext;
     4272
     4273    RT_NOREF(pBackend, pDXContext, type);
     4274
     4275    int rc = VINF_SUCCESS;
     4276
     4277    /* Allocate paBlendState for example. */
     4278    switch (type)
     4279    {
     4280        case SVGA_COTABLE_RTVIEW:
     4281            if (pBackendDXContext->papRenderTargetView)
     4282            {
     4283                DX_RELEASE_ARRAY(pBackendDXContext->cRenderTargetView, pBackendDXContext->papRenderTargetView);
     4284                RTMemFree(pBackendDXContext->papRenderTargetView);
     4285                pBackendDXContext->papRenderTargetView = NULL;
     4286                pBackendDXContext->cRenderTargetView = 0;
     4287            }
     4288
     4289            if (cEntries)
     4290            {
     4291                pBackendDXContext->papRenderTargetView = (ID3D11RenderTargetView **)RTMemAllocZ(cEntries * sizeof(pBackendDXContext->papRenderTargetView[0]));
     4292                AssertBreakStmt(pBackendDXContext->papRenderTargetView, rc = VERR_NO_MEMORY);
     4293                pBackendDXContext->cRenderTargetView = cEntries;
     4294            }
     4295            break;
     4296        case SVGA_COTABLE_DSVIEW:
     4297            if (pBackendDXContext->papDepthStencilView)
     4298            {
     4299                DX_RELEASE_ARRAY(pBackendDXContext->cDepthStencilView, pBackendDXContext->papDepthStencilView);
     4300                RTMemFree(pBackendDXContext->papDepthStencilView);
     4301                pBackendDXContext->papDepthStencilView = NULL;
     4302                pBackendDXContext->cDepthStencilView = 0;
     4303            }
     4304
     4305            if (cEntries)
     4306            {
     4307                pBackendDXContext->papDepthStencilView = (ID3D11DepthStencilView **)RTMemAllocZ(cEntries * sizeof(pBackendDXContext->papDepthStencilView[0]));
     4308                AssertBreakStmt(pBackendDXContext->papDepthStencilView, rc = VERR_NO_MEMORY);
     4309                pBackendDXContext->cDepthStencilView = cEntries;
     4310            }
     4311            break;
     4312        case SVGA_COTABLE_SRVIEW:
     4313            if (pBackendDXContext->papShaderResourceView)
     4314            {
     4315                DX_RELEASE_ARRAY(pBackendDXContext->cShaderResourceView, pBackendDXContext->papShaderResourceView);
     4316                RTMemFree(pBackendDXContext->papShaderResourceView);
     4317                pBackendDXContext->papShaderResourceView = NULL;
     4318                pBackendDXContext->cShaderResourceView = 0;
     4319            }
     4320
     4321            if (cEntries)
     4322            {
     4323                pBackendDXContext->papShaderResourceView = (ID3D11ShaderResourceView **)RTMemAllocZ(cEntries * sizeof(pBackendDXContext->papShaderResourceView[0]));
     4324                AssertBreakStmt(pBackendDXContext->papShaderResourceView, rc = VERR_NO_MEMORY);
     4325                pBackendDXContext->cShaderResourceView = cEntries;
     4326            }
     4327            break;
     4328        case SVGA_COTABLE_ELEMENTLAYOUT:
     4329            if (pBackendDXContext->paElementLayout)
     4330            {
     4331                for (uint32_t i = 0; i < pBackendDXContext->cElementLayout; ++i)
     4332                    D3D_RELEASE(pBackendDXContext->paElementLayout[i].pElementLayout);
     4333                RTMemFree(pBackendDXContext->paElementLayout);
     4334                pBackendDXContext->paElementLayout = NULL;
     4335                pBackendDXContext->cElementLayout = 0;
     4336            }
     4337
     4338            if (cEntries)
     4339            {
     4340                pBackendDXContext->paElementLayout = (DXELEMENTLAYOUT *)RTMemAllocZ(cEntries * sizeof(pBackendDXContext->paElementLayout[0]));
     4341                AssertBreakStmt(pBackendDXContext->paElementLayout, rc = VERR_NO_MEMORY);
     4342                pBackendDXContext->cElementLayout = cEntries;
     4343            }
     4344            break;
     4345        case SVGA_COTABLE_BLENDSTATE:
     4346            if (pBackendDXContext->papBlendState)
     4347            {
     4348                DX_RELEASE_ARRAY(pBackendDXContext->cBlendState, pBackendDXContext->papBlendState);
     4349                RTMemFree(pBackendDXContext->papBlendState);
     4350                pBackendDXContext->papBlendState = NULL;
     4351                pBackendDXContext->cBlendState = 0;
     4352            }
     4353
     4354            if (cEntries)
     4355            {
     4356                pBackendDXContext->papBlendState = (ID3D11BlendState **)RTMemAllocZ(cEntries * sizeof(pBackendDXContext->papBlendState[0]));
     4357                AssertBreakStmt(pBackendDXContext->papBlendState, rc = VERR_NO_MEMORY);
     4358                pBackendDXContext->cBlendState = cEntries;
     4359            }
     4360            break;
     4361        case SVGA_COTABLE_DEPTHSTENCIL:
     4362            if (pBackendDXContext->papDepthStencilState)
     4363            {
     4364                DX_RELEASE_ARRAY(pBackendDXContext->cDepthStencilState, pBackendDXContext->papDepthStencilState);
     4365                RTMemFree(pBackendDXContext->papDepthStencilState);
     4366                pBackendDXContext->papDepthStencilState = NULL;
     4367                pBackendDXContext->cDepthStencilState = 0;
     4368            }
     4369
     4370            if (cEntries)
     4371            {
     4372                pBackendDXContext->papDepthStencilState = (ID3D11DepthStencilState **)RTMemAllocZ(cEntries * sizeof(pBackendDXContext->papDepthStencilState[0]));
     4373                AssertBreakStmt(pBackendDXContext->papDepthStencilState, rc = VERR_NO_MEMORY);
     4374                pBackendDXContext->cDepthStencilState = cEntries;
     4375            }
     4376            break;
     4377        case SVGA_COTABLE_RASTERIZERSTATE:
     4378            if (pBackendDXContext->papRasterizerState)
     4379            {
     4380                DX_RELEASE_ARRAY(pBackendDXContext->cRasterizerState, pBackendDXContext->papRasterizerState);
     4381                RTMemFree(pBackendDXContext->papRasterizerState);
     4382                pBackendDXContext->papRasterizerState = NULL;
     4383                pBackendDXContext->cRasterizerState = 0;
     4384            }
     4385
     4386            if (cEntries)
     4387            {
     4388                pBackendDXContext->papRasterizerState = (ID3D11RasterizerState **)RTMemAllocZ(cEntries * sizeof(pBackendDXContext->papRasterizerState[0]));
     4389                AssertBreakStmt(pBackendDXContext->papRasterizerState, rc = VERR_NO_MEMORY);
     4390                pBackendDXContext->cRasterizerState = cEntries;
     4391            }
     4392            break;
     4393        case SVGA_COTABLE_SAMPLER:
     4394            if (pBackendDXContext->papSamplerState)
     4395            {
     4396                DX_RELEASE_ARRAY(pBackendDXContext->cSamplerState, pBackendDXContext->papSamplerState);
     4397                RTMemFree(pBackendDXContext->papSamplerState);
     4398                pBackendDXContext->papSamplerState = NULL;
     4399                pBackendDXContext->cSamplerState = 0;
     4400            }
     4401
     4402            if (cEntries)
     4403            {
     4404                pBackendDXContext->papSamplerState = (ID3D11SamplerState **)RTMemAllocZ(cEntries * sizeof(pBackendDXContext->papSamplerState[0]));
     4405                AssertBreakStmt(pBackendDXContext->papSamplerState, rc = VERR_NO_MEMORY);
     4406                pBackendDXContext->cSamplerState = cEntries;
     4407            }
     4408            break;
     4409        case SVGA_COTABLE_STREAMOUTPUT:
     4410            //AssertFailed(); /** @todo Implement */
     4411            break;
     4412        case SVGA_COTABLE_DXQUERY:
     4413            if (pBackendDXContext->papQuery)
     4414            {
     4415                DX_RELEASE_ARRAY(pBackendDXContext->cQuery, pBackendDXContext->papQuery);
     4416                RTMemFree(pBackendDXContext->papQuery);
     4417                pBackendDXContext->papQuery = NULL;
     4418                pBackendDXContext->cQuery = 0;
     4419            }
     4420
     4421            if (cEntries)
     4422            {
     4423                pBackendDXContext->papQuery = (ID3D11Query **)RTMemAllocZ(cEntries * sizeof(pBackendDXContext->papQuery[0]));
     4424                AssertBreakStmt(pBackendDXContext->papQuery, rc = VERR_NO_MEMORY);
     4425                pBackendDXContext->cQuery = cEntries;
     4426            }
     4427            break;
     4428        case SVGA_COTABLE_DXSHADER:
     4429            if (pBackendDXContext->paShader)
     4430            {
     4431                for (uint32_t i = 0; i < pBackendDXContext->cShader; ++i)
     4432                    D3D_RELEASE(pBackendDXContext->paShader[i].pShader);
     4433                RTMemFree(pBackendDXContext->paShader);
     4434                pBackendDXContext->paShader = NULL;
     4435                pBackendDXContext->cShader = 0;
     4436            }
     4437
     4438            if (cEntries)
     4439            {
     4440                pBackendDXContext->paShader = (DXSHADER *)RTMemAllocZ(cEntries * sizeof(pBackendDXContext->paShader[0]));
     4441                AssertBreakStmt(pBackendDXContext->paShader, rc = VERR_NO_MEMORY);
     4442                pBackendDXContext->cShader = cEntries;
     4443            }
     4444            break;
     4445        case SVGA_COTABLE_UAVIEW:
     4446            AssertFailed(); /** @todo Implement */
     4447            break;
     4448        case SVGA_COTABLE_MAX: break; /* Compiler warning */
     4449    }
     4450    return rc;
     4451}
     4452
     4453
     4454static DECLCALLBACK(int) vmsvga3dBackDXReadbackCOTable(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4455{
     4456    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4457
     4458    RT_NOREF(pBackend, pDXContext);
     4459    AssertFailed(); /** @todo Implement */
     4460    return VERR_NOT_IMPLEMENTED;
     4461}
     4462
     4463
     4464static DECLCALLBACK(int) vmsvga3dBackDXBufferCopy(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4465{
     4466    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4467
     4468    RT_NOREF(pBackend, pDXContext);
     4469    AssertFailed(); /** @todo Implement */
     4470    return VERR_NOT_IMPLEMENTED;
     4471}
     4472
     4473
     4474static DECLCALLBACK(int) vmsvga3dBackDXTransferFromBuffer(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4475{
     4476    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4477
     4478    RT_NOREF(pBackend, pDXContext);
     4479    AssertFailed(); /** @todo Implement */
     4480    return VERR_NOT_IMPLEMENTED;
     4481}
     4482
     4483
     4484static DECLCALLBACK(int) vmsvga3dBackDXSurfaceCopyAndReadback(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4485{
     4486    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4487
     4488    RT_NOREF(pBackend, pDXContext);
     4489    AssertFailed(); /** @todo Implement */
     4490    return VERR_NOT_IMPLEMENTED;
     4491}
     4492
     4493
     4494static DECLCALLBACK(int) vmsvga3dBackDXMoveQuery(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4495{
     4496    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4497
     4498    RT_NOREF(pBackend, pDXContext);
     4499    AssertFailed(); /** @todo Implement */
     4500    return VERR_NOT_IMPLEMENTED;
     4501}
     4502
     4503
     4504static DECLCALLBACK(int) vmsvga3dBackDXBindAllQuery(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4505{
     4506    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4507
     4508    RT_NOREF(pBackend, pDXContext);
     4509    AssertFailed(); /** @todo Implement */
     4510    return VERR_NOT_IMPLEMENTED;
     4511}
     4512
     4513
     4514static DECLCALLBACK(int) vmsvga3dBackDXReadbackAllQuery(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4515{
     4516    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4517
     4518    RT_NOREF(pBackend, pDXContext);
     4519    AssertFailed(); /** @todo Implement */
     4520    return VERR_NOT_IMPLEMENTED;
     4521}
     4522
     4523
     4524static DECLCALLBACK(int) vmsvga3dBackDXPredTransferFromBuffer(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4525{
     4526    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4527
     4528    RT_NOREF(pBackend, pDXContext);
     4529    AssertFailed(); /** @todo Implement */
     4530    return VERR_NOT_IMPLEMENTED;
     4531}
     4532
     4533
     4534static DECLCALLBACK(int) vmsvga3dBackDXMobFence64(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4535{
     4536    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4537
     4538    RT_NOREF(pBackend, pDXContext);
     4539    AssertFailed(); /** @todo Implement */
     4540    return VERR_NOT_IMPLEMENTED;
     4541}
     4542
     4543
     4544static DECLCALLBACK(int) vmsvga3dBackDXBindAllShader(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4545{
     4546    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4547
     4548    RT_NOREF(pBackend, pDXContext);
     4549    AssertFailed(); /** @todo Implement */
     4550    return VERR_NOT_IMPLEMENTED;
     4551}
     4552
     4553
     4554static DECLCALLBACK(int) vmsvga3dBackDXHint(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4555{
     4556    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4557
     4558    RT_NOREF(pBackend, pDXContext);
     4559    AssertFailed(); /** @todo Implement */
     4560    return VERR_NOT_IMPLEMENTED;
     4561}
     4562
     4563
     4564static DECLCALLBACK(int) vmsvga3dBackDXBufferUpdate(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4565{
     4566    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4567
     4568    RT_NOREF(pBackend, pDXContext);
     4569    AssertFailed(); /** @todo Implement */
     4570    return VERR_NOT_IMPLEMENTED;
     4571}
     4572
     4573
     4574static DECLCALLBACK(int) vmsvga3dBackDXSetVSConstantBufferOffset(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4575{
     4576    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4577
     4578    RT_NOREF(pBackend, pDXContext);
     4579    AssertFailed(); /** @todo Implement */
     4580    return VERR_NOT_IMPLEMENTED;
     4581}
     4582
     4583
     4584static DECLCALLBACK(int) vmsvga3dBackDXSetPSConstantBufferOffset(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4585{
     4586    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4587
     4588    RT_NOREF(pBackend, pDXContext);
     4589    AssertFailed(); /** @todo Implement */
     4590    return VERR_NOT_IMPLEMENTED;
     4591}
     4592
     4593
     4594static DECLCALLBACK(int) vmsvga3dBackDXSetGSConstantBufferOffset(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4595{
     4596    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4597
     4598    RT_NOREF(pBackend, pDXContext);
     4599    AssertFailed(); /** @todo Implement */
     4600    return VERR_NOT_IMPLEMENTED;
     4601}
     4602
     4603
     4604static DECLCALLBACK(int) vmsvga3dBackDXSetHSConstantBufferOffset(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4605{
     4606    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4607
     4608    RT_NOREF(pBackend, pDXContext);
     4609    AssertFailed(); /** @todo Implement */
     4610    return VERR_NOT_IMPLEMENTED;
     4611}
     4612
     4613
     4614static DECLCALLBACK(int) vmsvga3dBackDXSetDSConstantBufferOffset(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4615{
     4616    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4617
     4618    RT_NOREF(pBackend, pDXContext);
     4619    AssertFailed(); /** @todo Implement */
     4620    return VERR_NOT_IMPLEMENTED;
     4621}
     4622
     4623
     4624static DECLCALLBACK(int) vmsvga3dBackDXSetCSConstantBufferOffset(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4625{
     4626    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4627
     4628    RT_NOREF(pBackend, pDXContext);
     4629    AssertFailed(); /** @todo Implement */
     4630    return VERR_NOT_IMPLEMENTED;
     4631}
     4632
     4633
     4634static DECLCALLBACK(int) vmsvga3dBackDXCondBindAllShader(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4635{
     4636    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4637
     4638    RT_NOREF(pBackend, pDXContext);
     4639    AssertFailed(); /** @todo Implement */
     4640    return VERR_NOT_IMPLEMENTED;
     4641}
     4642
     4643
     4644static DECLCALLBACK(int) vmsvga3dBackScreenCopy(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4645{
     4646    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4647
     4648    RT_NOREF(pBackend, pDXContext);
     4649    AssertFailed(); /** @todo Implement */
     4650    return VERR_NOT_IMPLEMENTED;
     4651}
     4652
     4653
     4654static DECLCALLBACK(int) vmsvga3dBackGrowOTable(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4655{
     4656    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4657
     4658    RT_NOREF(pBackend, pDXContext);
     4659    AssertFailed(); /** @todo Implement */
     4660    return VERR_NOT_IMPLEMENTED;
     4661}
     4662
     4663
     4664static DECLCALLBACK(int) vmsvga3dBackDXGrowCOTable(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4665{
     4666    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4667
     4668    RT_NOREF(pBackend, pDXContext);
     4669    AssertFailed(); /** @todo Implement */
     4670    return VERR_NOT_IMPLEMENTED;
     4671}
     4672
     4673
     4674static DECLCALLBACK(int) vmsvga3dBackIntraSurfaceCopy(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4675{
     4676    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4677
     4678    RT_NOREF(pBackend, pDXContext);
     4679    AssertFailed(); /** @todo Implement */
     4680    return VERR_NOT_IMPLEMENTED;
     4681}
     4682
     4683
     4684static DECLCALLBACK(int) vmsvga3dBackDefineGBSurface_v3(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4685{
     4686    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4687
     4688    RT_NOREF(pBackend, pDXContext);
     4689    AssertFailed(); /** @todo Implement */
     4690    return VERR_NOT_IMPLEMENTED;
     4691}
     4692
     4693
     4694static DECLCALLBACK(int) vmsvga3dBackDXResolveCopy(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4695{
     4696    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4697
     4698    RT_NOREF(pBackend, pDXContext);
     4699    AssertFailed(); /** @todo Implement */
     4700    return VERR_NOT_IMPLEMENTED;
     4701}
     4702
     4703
     4704static DECLCALLBACK(int) vmsvga3dBackDXPredResolveCopy(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4705{
     4706    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4707
     4708    RT_NOREF(pBackend, pDXContext);
     4709    AssertFailed(); /** @todo Implement */
     4710    return VERR_NOT_IMPLEMENTED;
     4711}
     4712
     4713
     4714static DECLCALLBACK(int) vmsvga3dBackDXPredConvertRegion(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4715{
     4716    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4717
     4718    RT_NOREF(pBackend, pDXContext);
     4719    AssertFailed(); /** @todo Implement */
     4720    return VERR_NOT_IMPLEMENTED;
     4721}
     4722
     4723
     4724static DECLCALLBACK(int) vmsvga3dBackDXPredConvert(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4725{
     4726    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4727
     4728    RT_NOREF(pBackend, pDXContext);
     4729    AssertFailed(); /** @todo Implement */
     4730    return VERR_NOT_IMPLEMENTED;
     4731}
     4732
     4733
     4734static DECLCALLBACK(int) vmsvga3dBackWholeSurfaceCopy(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4735{
     4736    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4737
     4738    RT_NOREF(pBackend, pDXContext);
     4739    AssertFailed(); /** @todo Implement */
     4740    return VERR_NOT_IMPLEMENTED;
     4741}
     4742
     4743
     4744static DECLCALLBACK(int) vmsvga3dBackDXDefineUAView(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4745{
     4746    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4747
     4748    RT_NOREF(pBackend, pDXContext);
     4749    AssertFailed(); /** @todo Implement */
     4750    return VERR_NOT_IMPLEMENTED;
     4751}
     4752
     4753
     4754static DECLCALLBACK(int) vmsvga3dBackDXDestroyUAView(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4755{
     4756    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4757
     4758    RT_NOREF(pBackend, pDXContext);
     4759    AssertFailed(); /** @todo Implement */
     4760    return VERR_NOT_IMPLEMENTED;
     4761}
     4762
     4763
     4764static DECLCALLBACK(int) vmsvga3dBackDXClearUAViewUint(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4765{
     4766    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4767
     4768    RT_NOREF(pBackend, pDXContext);
     4769    AssertFailed(); /** @todo Implement */
     4770    return VERR_NOT_IMPLEMENTED;
     4771}
     4772
     4773
     4774static DECLCALLBACK(int) vmsvga3dBackDXClearUAViewFloat(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4775{
     4776    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4777
     4778    RT_NOREF(pBackend, pDXContext);
     4779    AssertFailed(); /** @todo Implement */
     4780    return VERR_NOT_IMPLEMENTED;
     4781}
     4782
     4783
     4784static DECLCALLBACK(int) vmsvga3dBackDXCopyStructureCount(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4785{
     4786    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4787
     4788    RT_NOREF(pBackend, pDXContext);
     4789    AssertFailed(); /** @todo Implement */
     4790    return VERR_NOT_IMPLEMENTED;
     4791}
     4792
     4793
     4794static DECLCALLBACK(int) vmsvga3dBackDXSetUAViews(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4795{
     4796    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4797
     4798    RT_NOREF(pBackend, pDXContext);
     4799    AssertFailed(); /** @todo Implement */
     4800    return VERR_NOT_IMPLEMENTED;
     4801}
     4802
     4803
     4804static DECLCALLBACK(int) vmsvga3dBackDXDrawIndexedInstancedIndirect(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4805{
     4806    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4807
     4808    RT_NOREF(pBackend, pDXContext);
     4809    AssertFailed(); /** @todo Implement */
     4810    return VERR_NOT_IMPLEMENTED;
     4811}
     4812
     4813
     4814static DECLCALLBACK(int) vmsvga3dBackDXDrawInstancedIndirect(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4815{
     4816    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4817
     4818    RT_NOREF(pBackend, pDXContext);
     4819    AssertFailed(); /** @todo Implement */
     4820    return VERR_NOT_IMPLEMENTED;
     4821}
     4822
     4823
     4824static DECLCALLBACK(int) vmsvga3dBackDXDispatch(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4825{
     4826    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4827
     4828    RT_NOREF(pBackend, pDXContext);
     4829    AssertFailed(); /** @todo Implement */
     4830    return VERR_NOT_IMPLEMENTED;
     4831}
     4832
     4833
     4834static DECLCALLBACK(int) vmsvga3dBackDXDispatchIndirect(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4835{
     4836    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4837
     4838    RT_NOREF(pBackend, pDXContext);
     4839    AssertFailed(); /** @todo Implement */
     4840    return VERR_NOT_IMPLEMENTED;
     4841}
     4842
     4843
     4844static DECLCALLBACK(int) vmsvga3dBackWriteZeroSurface(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4845{
     4846    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4847
     4848    RT_NOREF(pBackend, pDXContext);
     4849    AssertFailed(); /** @todo Implement */
     4850    return VERR_NOT_IMPLEMENTED;
     4851}
     4852
     4853
     4854static DECLCALLBACK(int) vmsvga3dBackHintZeroSurface(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4855{
     4856    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4857
     4858    RT_NOREF(pBackend, pDXContext);
     4859    AssertFailed(); /** @todo Implement */
     4860    return VERR_NOT_IMPLEMENTED;
     4861}
     4862
     4863
     4864static DECLCALLBACK(int) vmsvga3dBackDXTransferToBuffer(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4865{
     4866    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4867
     4868    RT_NOREF(pBackend, pDXContext);
     4869    AssertFailed(); /** @todo Implement */
     4870    return VERR_NOT_IMPLEMENTED;
     4871}
     4872
     4873
     4874static DECLCALLBACK(int) vmsvga3dBackDXSetStructureCount(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4875{
     4876    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4877
     4878    RT_NOREF(pBackend, pDXContext);
     4879    AssertFailed(); /** @todo Implement */
     4880    return VERR_NOT_IMPLEMENTED;
     4881}
     4882
     4883
     4884static DECLCALLBACK(int) vmsvga3dBackLogicOpsBitBlt(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4885{
     4886    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4887
     4888    RT_NOREF(pBackend, pDXContext);
     4889    AssertFailed(); /** @todo Implement */
     4890    return VERR_NOT_IMPLEMENTED;
     4891}
     4892
     4893
     4894static DECLCALLBACK(int) vmsvga3dBackLogicOpsTransBlt(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4895{
     4896    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4897
     4898    RT_NOREF(pBackend, pDXContext);
     4899    AssertFailed(); /** @todo Implement */
     4900    return VERR_NOT_IMPLEMENTED;
     4901}
     4902
     4903
     4904static DECLCALLBACK(int) vmsvga3dBackLogicOpsStretchBlt(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4905{
     4906    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4907
     4908    RT_NOREF(pBackend, pDXContext);
     4909    AssertFailed(); /** @todo Implement */
     4910    return VERR_NOT_IMPLEMENTED;
     4911}
     4912
     4913
     4914static DECLCALLBACK(int) vmsvga3dBackLogicOpsColorFill(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4915{
     4916    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4917
     4918    RT_NOREF(pBackend, pDXContext);
     4919    AssertFailed(); /** @todo Implement */
     4920    return VERR_NOT_IMPLEMENTED;
     4921}
     4922
     4923
     4924static DECLCALLBACK(int) vmsvga3dBackLogicOpsAlphaBlend(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4925{
     4926    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4927
     4928    RT_NOREF(pBackend, pDXContext);
     4929    AssertFailed(); /** @todo Implement */
     4930    return VERR_NOT_IMPLEMENTED;
     4931}
     4932
     4933
     4934static DECLCALLBACK(int) vmsvga3dBackLogicOpsClearTypeBlend(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4935{
     4936    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4937
     4938    RT_NOREF(pBackend, pDXContext);
     4939    AssertFailed(); /** @todo Implement */
     4940    return VERR_NOT_IMPLEMENTED;
     4941}
     4942
     4943
     4944static DECLCALLBACK(int) vmsvga3dBackDefineGBSurface_v4(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4945{
     4946    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4947
     4948    RT_NOREF(pBackend, pDXContext);
     4949    AssertFailed(); /** @todo Implement */
     4950    return VERR_NOT_IMPLEMENTED;
     4951}
     4952
     4953
     4954static DECLCALLBACK(int) vmsvga3dBackDXSetCSUAViews(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4955{
     4956    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4957
     4958    RT_NOREF(pBackend, pDXContext);
     4959    AssertFailed(); /** @todo Implement */
     4960    return VERR_NOT_IMPLEMENTED;
     4961}
     4962
     4963
     4964static DECLCALLBACK(int) vmsvga3dBackDXSetMinLOD(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4965{
     4966    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4967
     4968    RT_NOREF(pBackend, pDXContext);
     4969    AssertFailed(); /** @todo Implement */
     4970    return VERR_NOT_IMPLEMENTED;
     4971}
     4972
     4973
     4974static DECLCALLBACK(int) vmsvga3dBackDXDefineDepthStencilView_v2(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4975{
     4976    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4977
     4978    RT_NOREF(pBackend, pDXContext);
     4979    AssertFailed(); /** @todo Implement */
     4980    return VERR_NOT_IMPLEMENTED;
     4981}
     4982
     4983
     4984static DECLCALLBACK(int) vmsvga3dBackDXDefineStreamOutputWithMob(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4985{
     4986    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4987
     4988    RT_NOREF(pBackend, pDXContext);
     4989    AssertFailed(); /** @todo Implement */
     4990    return VERR_NOT_IMPLEMENTED;
     4991}
     4992
     4993
     4994static DECLCALLBACK(int) vmsvga3dBackDXSetShaderIface(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     4995{
     4996    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     4997
     4998    RT_NOREF(pBackend, pDXContext);
     4999    AssertFailed(); /** @todo Implement */
     5000    return VERR_NOT_IMPLEMENTED;
     5001}
     5002
     5003
     5004static DECLCALLBACK(int) vmsvga3dBackDXBindStreamOutput(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     5005{
     5006    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     5007
     5008    RT_NOREF(pBackend, pDXContext);
     5009    AssertFailed(); /** @todo Implement */
     5010    return VERR_NOT_IMPLEMENTED;
     5011}
     5012
     5013
     5014static DECLCALLBACK(int) vmsvga3dBackSurfaceStretchBltNonMSToMS(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     5015{
     5016    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     5017
     5018    RT_NOREF(pBackend, pDXContext);
     5019    AssertFailed(); /** @todo Implement */
     5020    return VERR_NOT_IMPLEMENTED;
     5021}
     5022
     5023
     5024static DECLCALLBACK(int) vmsvga3dBackDXBindShaderIface(PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext)
     5025{
     5026    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
     5027
     5028    RT_NOREF(pBackend, pDXContext);
     5029    AssertFailed(); /** @todo Implement */
     5030    return VERR_NOT_IMPLEMENTED;
    34425031}
    34435032
     
    34485037    AssertReturn(p3dState, VERR_NOT_SUPPORTED);
    34495038
    3450     PVMSVGA3DBACKEND pBackend = p3dState->pBackend;
     5039    PVMSVGA3DBACKEND pBackend = pThisCC->svga.p3dState->pBackend;
    34515040    AssertReturn(pBackend, VERR_NOT_SUPPORTED);
    34525041
     
    34625051            {
    34635052                VMSVGA3DBACKENDFUNCSDX *p = (VMSVGA3DBACKENDFUNCSDX *)pvInterfaceFuncs;
    3464                 p->pfnDXDefineContext             = vmsvga3dDXDefineContext;
    3465                 p->pfnDXDestroyContext            = vmsvga3dDXDestroyContext;
    3466                 p->pfnDXBindContext               = vmsvga3dDXBindContext;
    3467                 p->pfnDXReadbackContext           = vmsvga3dDXReadbackContext;
    3468                 p->pfnDXInvalidateContext         = vmsvga3dDXInvalidateContext;
    3469                 p->pfnDXSetSingleConstantBuffer   = vmsvga3dDXSetSingleConstantBuffer;
    3470                 p->pfnDXSetShaderResources        = vmsvga3dDXSetShaderResources;
    3471                 p->pfnDXSetShader                 = vmsvga3dDXSetShader;
    3472                 p->pfnDXSetSamplers               = vmsvga3dDXSetSamplers;
    3473                 p->pfnDXDraw                      = vmsvga3dDXDraw;
    3474                 p->pfnDXDrawIndexed               = vmsvga3dDXDrawIndexed;
    3475                 p->pfnDXDrawInstanced             = vmsvga3dDXDrawInstanced;
    3476                 p->pfnDXDrawIndexedInstanced      = vmsvga3dDXDrawIndexedInstanced;
    3477                 p->pfnDXDrawAuto                  = vmsvga3dDXDrawAuto;
    3478                 p->pfnDXSetInputLayout            = vmsvga3dDXSetInputLayout;
    3479                 p->pfnDXSetVertexBuffers          = vmsvga3dDXSetVertexBuffers;
    3480                 p->pfnDXSetIndexBuffer            = vmsvga3dDXSetIndexBuffer;
    3481                 p->pfnDXSetTopology               = vmsvga3dDXSetTopology;
    3482                 p->pfnDXSetRenderTargets          = vmsvga3dDXSetRenderTargets;
    3483                 p->pfnDXSetBlendState             = vmsvga3dDXSetBlendState;
    3484                 p->pfnDXSetDepthStencilState      = vmsvga3dDXSetDepthStencilState;
    3485                 p->pfnDXSetRasterizerState        = vmsvga3dDXSetRasterizerState;
    3486                 p->pfnDXDefineQuery               = vmsvga3dDXDefineQuery;
    3487                 p->pfnDXDestroyQuery              = vmsvga3dDXDestroyQuery;
    3488                 p->pfnDXBindQuery                 = vmsvga3dDXBindQuery;
    3489                 p->pfnDXSetQueryOffset            = vmsvga3dDXSetQueryOffset;
    3490                 p->pfnDXBeginQuery                = vmsvga3dDXBeginQuery;
    3491                 p->pfnDXEndQuery                  = vmsvga3dDXEndQuery;
    3492                 p->pfnDXReadbackQuery             = vmsvga3dDXReadbackQuery;
    3493                 p->pfnDXSetPredication            = vmsvga3dDXSetPredication;
    3494                 p->pfnDXSetSOTargets              = vmsvga3dDXSetSOTargets;
    3495                 p->pfnDXSetViewports              = vmsvga3dDXSetViewports;
    3496                 p->pfnDXSetScissorRects           = vmsvga3dDXSetScissorRects;
    3497                 p->pfnDXClearRenderTargetView     = vmsvga3dDXClearRenderTargetView;
    3498                 p->pfnDXClearDepthStencilView     = vmsvga3dDXClearDepthStencilView;
    3499                 p->pfnDXPredCopyRegion            = vmsvga3dDXPredCopyRegion;
    3500                 p->pfnDXPredCopy                  = vmsvga3dDXPredCopy;
    3501                 p->pfnDXPresentBlt                = vmsvga3dDXPresentBlt;
    3502                 p->pfnDXGenMips                   = vmsvga3dDXGenMips;
    3503                 p->pfnDXUpdateSubResource         = vmsvga3dDXUpdateSubResource;
    3504                 p->pfnDXReadbackSubResource       = vmsvga3dDXReadbackSubResource;
    3505                 p->pfnDXInvalidateSubResource     = vmsvga3dDXInvalidateSubResource;
    3506                 p->pfnDXDefineShaderResourceView  = vmsvga3dDXDefineShaderResourceView;
    3507                 p->pfnDXDestroyShaderResourceView = vmsvga3dDXDestroyShaderResourceView;
    3508                 p->pfnDXDefineRenderTargetView    = vmsvga3dDXDefineRenderTargetView;
    3509                 p->pfnDXDestroyRenderTargetView   = vmsvga3dDXDestroyRenderTargetView;
    3510                 p->pfnDXDefineDepthStencilView    = vmsvga3dDXDefineDepthStencilView;
    3511                 p->pfnDXDestroyDepthStencilView   = vmsvga3dDXDestroyDepthStencilView;
    3512                 p->pfnDXDefineElementLayout       = vmsvga3dDXDefineElementLayout;
    3513                 p->pfnDXDestroyElementLayout      = vmsvga3dDXDestroyElementLayout;
    3514                 p->pfnDXDefineBlendState          = vmsvga3dDXDefineBlendState;
    3515                 p->pfnDXDestroyBlendState         = vmsvga3dDXDestroyBlendState;
    3516                 p->pfnDXDefineDepthStencilState   = vmsvga3dDXDefineDepthStencilState;
    3517                 p->pfnDXDestroyDepthStencilState  = vmsvga3dDXDestroyDepthStencilState;
    3518                 p->pfnDXDefineRasterizerState     = vmsvga3dDXDefineRasterizerState;
    3519                 p->pfnDXDestroyRasterizerState    = vmsvga3dDXDestroyRasterizerState;
    3520                 p->pfnDXDefineSamplerState        = vmsvga3dDXDefineSamplerState;
    3521                 p->pfnDXDestroySamplerState       = vmsvga3dDXDestroySamplerState;
    3522                 p->pfnDXDefineShader              = vmsvga3dDXDefineShader;
    3523                 p->pfnDXDestroyShader             = vmsvga3dDXDestroyShader;
    3524                 p->pfnDXBindShader                = vmsvga3dDXBindShader;
    3525                 p->pfnDXDefineStreamOutput        = vmsvga3dDXDefineStreamOutput;
    3526                 p->pfnDXDestroyStreamOutput       = vmsvga3dDXDestroyStreamOutput;
    3527                 p->pfnDXSetStreamOutput           = vmsvga3dDXSetStreamOutput;
    3528                 p->pfnDXSetCOTable                = vmsvga3dDXSetCOTable;
    3529                 p->pfnDXReadbackCOTable           = vmsvga3dDXReadbackCOTable;
    3530                 p->pfnDXBufferCopy                = vmsvga3dDXBufferCopy;
    3531                 p->pfnDXTransferFromBuffer        = vmsvga3dDXTransferFromBuffer;
    3532                 p->pfnDXSurfaceCopyAndReadback    = vmsvga3dDXSurfaceCopyAndReadback;
    3533                 p->pfnDXMoveQuery                 = vmsvga3dDXMoveQuery;
    3534                 p->pfnDXBindAllQuery              = vmsvga3dDXBindAllQuery;
    3535                 p->pfnDXReadbackAllQuery          = vmsvga3dDXReadbackAllQuery;
    3536                 p->pfnDXPredTransferFromBuffer    = vmsvga3dDXPredTransferFromBuffer;
    3537                 p->pfnDXMobFence64                = vmsvga3dDXMobFence64;
    3538                 p->pfnDXBindAllShader             = vmsvga3dDXBindAllShader;
    3539                 p->pfnDXHint                      = vmsvga3dDXHint;
    3540                 p->pfnDXBufferUpdate              = vmsvga3dDXBufferUpdate;
    3541                 p->pfnDXSetVSConstantBufferOffset = vmsvga3dDXSetVSConstantBufferOffset;
    3542                 p->pfnDXSetPSConstantBufferOffset = vmsvga3dDXSetPSConstantBufferOffset;
    3543                 p->pfnDXSetGSConstantBufferOffset = vmsvga3dDXSetGSConstantBufferOffset;
    3544                 p->pfnDXSetHSConstantBufferOffset = vmsvga3dDXSetHSConstantBufferOffset;
    3545                 p->pfnDXSetDSConstantBufferOffset = vmsvga3dDXSetDSConstantBufferOffset;
    3546                 p->pfnDXSetCSConstantBufferOffset = vmsvga3dDXSetCSConstantBufferOffset;
    3547                 p->pfnDXCondBindAllShader         = vmsvga3dDXCondBindAllShader;
    3548                 p->pfnScreenCopy                  = vmsvga3dScreenCopy;
    3549                 p->pfnGrowOTable                  = vmsvga3dGrowOTable;
    3550                 p->pfnDXGrowCOTable               = vmsvga3dDXGrowCOTable;
    3551                 p->pfnIntraSurfaceCopy            = vmsvga3dIntraSurfaceCopy;
    3552                 p->pfnDefineGBSurface_v3          = vmsvga3dDefineGBSurface_v3;
    3553                 p->pfnDXResolveCopy               = vmsvga3dDXResolveCopy;
    3554                 p->pfnDXPredResolveCopy           = vmsvga3dDXPredResolveCopy;
    3555                 p->pfnDXPredConvertRegion         = vmsvga3dDXPredConvertRegion;
    3556                 p->pfnDXPredConvert               = vmsvga3dDXPredConvert;
    3557                 p->pfnWholeSurfaceCopy            = vmsvga3dWholeSurfaceCopy;
    3558                 p->pfnDXDefineUAView              = vmsvga3dDXDefineUAView;
    3559                 p->pfnDXDestroyUAView             = vmsvga3dDXDestroyUAView;
    3560                 p->pfnDXClearUAViewUint           = vmsvga3dDXClearUAViewUint;
    3561                 p->pfnDXClearUAViewFloat          = vmsvga3dDXClearUAViewFloat;
    3562                 p->pfnDXCopyStructureCount        = vmsvga3dDXCopyStructureCount;
    3563                 p->pfnDXSetUAViews                = vmsvga3dDXSetUAViews;
    3564                 p->pfnDXDrawIndexedInstancedIndirect = vmsvga3dDXDrawIndexedInstancedIndirect;
    3565                 p->pfnDXDrawInstancedIndirect     = vmsvga3dDXDrawInstancedIndirect;
    3566                 p->pfnDXDispatch                  = vmsvga3dDXDispatch;
    3567                 p->pfnDXDispatchIndirect          = vmsvga3dDXDispatchIndirect;
    3568                 p->pfnWriteZeroSurface            = vmsvga3dWriteZeroSurface;
    3569                 p->pfnHintZeroSurface             = vmsvga3dHintZeroSurface;
    3570                 p->pfnDXTransferToBuffer          = vmsvga3dDXTransferToBuffer;
    3571                 p->pfnDXSetStructureCount         = vmsvga3dDXSetStructureCount;
    3572                 p->pfnLogicOpsBitBlt              = vmsvga3dLogicOpsBitBlt;
    3573                 p->pfnLogicOpsTransBlt            = vmsvga3dLogicOpsTransBlt;
    3574                 p->pfnLogicOpsStretchBlt          = vmsvga3dLogicOpsStretchBlt;
    3575                 p->pfnLogicOpsColorFill           = vmsvga3dLogicOpsColorFill;
    3576                 p->pfnLogicOpsAlphaBlend          = vmsvga3dLogicOpsAlphaBlend;
    3577                 p->pfnLogicOpsClearTypeBlend      = vmsvga3dLogicOpsClearTypeBlend;
    3578                 p->pfnDefineGBSurface_v4          = vmsvga3dDefineGBSurface_v4;
    3579                 p->pfnDXSetCSUAViews              = vmsvga3dDXSetCSUAViews;
    3580                 p->pfnDXSetMinLOD                 = vmsvga3dDXSetMinLOD;
    3581                 p->pfnDXDefineDepthStencilView_v2 = vmsvga3dDXDefineDepthStencilView_v2;
    3582                 p->pfnDXDefineStreamOutputWithMob = vmsvga3dDXDefineStreamOutputWithMob;
    3583                 p->pfnDXSetShaderIface            = vmsvga3dDXSetShaderIface;
    3584                 p->pfnDXBindStreamOutput          = vmsvga3dDXBindStreamOutput;
    3585                 p->pfnSurfaceStretchBltNonMSToMS  = vmsvga3dSurfaceStretchBltNonMSToMS;
    3586                 p->pfnDXBindShaderIface           = vmsvga3dDXBindShaderIface;
     5053                p->pfnDXDefineContext             = vmsvga3dBackDXDefineContext;
     5054                p->pfnDXDestroyContext            = vmsvga3dBackDXDestroyContext;
     5055                p->pfnDXBindContext               = vmsvga3dBackDXBindContext;
     5056                p->pfnDXReadbackContext           = vmsvga3dBackDXReadbackContext;
     5057                p->pfnDXInvalidateContext         = vmsvga3dBackDXInvalidateContext;
     5058                p->pfnDXSetSingleConstantBuffer   = vmsvga3dBackDXSetSingleConstantBuffer;
     5059                p->pfnDXSetShaderResources        = vmsvga3dBackDXSetShaderResources;
     5060                p->pfnDXSetShader                 = vmsvga3dBackDXSetShader;
     5061                p->pfnDXSetSamplers               = vmsvga3dBackDXSetSamplers;
     5062                p->pfnDXDraw                      = vmsvga3dBackDXDraw;
     5063                p->pfnDXDrawIndexed               = vmsvga3dBackDXDrawIndexed;
     5064                p->pfnDXDrawInstanced             = vmsvga3dBackDXDrawInstanced;
     5065                p->pfnDXDrawIndexedInstanced      = vmsvga3dBackDXDrawIndexedInstanced;
     5066                p->pfnDXDrawAuto                  = vmsvga3dBackDXDrawAuto;
     5067                p->pfnDXSetInputLayout            = vmsvga3dBackDXSetInputLayout;
     5068                p->pfnDXSetVertexBuffers          = vmsvga3dBackDXSetVertexBuffers;
     5069                p->pfnDXSetIndexBuffer            = vmsvga3dBackDXSetIndexBuffer;
     5070                p->pfnDXSetTopology               = vmsvga3dBackDXSetTopology;
     5071                p->pfnDXSetRenderTargets          = vmsvga3dBackDXSetRenderTargets;
     5072                p->pfnDXSetBlendState             = vmsvga3dBackDXSetBlendState;
     5073                p->pfnDXSetDepthStencilState      = vmsvga3dBackDXSetDepthStencilState;
     5074                p->pfnDXSetRasterizerState        = vmsvga3dBackDXSetRasterizerState;
     5075                p->pfnDXDefineQuery               = vmsvga3dBackDXDefineQuery;
     5076                p->pfnDXDestroyQuery              = vmsvga3dBackDXDestroyQuery;
     5077                p->pfnDXBindQuery                 = vmsvga3dBackDXBindQuery;
     5078                p->pfnDXSetQueryOffset            = vmsvga3dBackDXSetQueryOffset;
     5079                p->pfnDXBeginQuery                = vmsvga3dBackDXBeginQuery;
     5080                p->pfnDXEndQuery                  = vmsvga3dBackDXEndQuery;
     5081                p->pfnDXReadbackQuery             = vmsvga3dBackDXReadbackQuery;
     5082                p->pfnDXSetPredication            = vmsvga3dBackDXSetPredication;
     5083                p->pfnDXSetSOTargets              = vmsvga3dBackDXSetSOTargets;
     5084                p->pfnDXSetViewports              = vmsvga3dBackDXSetViewports;
     5085                p->pfnDXSetScissorRects           = vmsvga3dBackDXSetScissorRects;
     5086                p->pfnDXClearRenderTargetView     = vmsvga3dBackDXClearRenderTargetView;
     5087                p->pfnDXClearDepthStencilView     = vmsvga3dBackDXClearDepthStencilView;
     5088                p->pfnDXPredCopyRegion            = vmsvga3dBackDXPredCopyRegion;
     5089                p->pfnDXPredCopy                  = vmsvga3dBackDXPredCopy;
     5090                p->pfnDXPresentBlt                = vmsvga3dBackDXPresentBlt;
     5091                p->pfnDXGenMips                   = vmsvga3dBackDXGenMips;
     5092                p->pfnDXUpdateSubResource         = vmsvga3dBackDXUpdateSubResource;
     5093                p->pfnDXReadbackSubResource       = vmsvga3dBackDXReadbackSubResource;
     5094                p->pfnDXInvalidateSubResource     = vmsvga3dBackDXInvalidateSubResource;
     5095                p->pfnDXDefineShaderResourceView  = vmsvga3dBackDXDefineShaderResourceView;
     5096                p->pfnDXDestroyShaderResourceView = vmsvga3dBackDXDestroyShaderResourceView;
     5097                p->pfnDXDefineRenderTargetView    = vmsvga3dBackDXDefineRenderTargetView;
     5098                p->pfnDXDestroyRenderTargetView   = vmsvga3dBackDXDestroyRenderTargetView;
     5099                p->pfnDXDefineDepthStencilView    = vmsvga3dBackDXDefineDepthStencilView;
     5100                p->pfnDXDestroyDepthStencilView   = vmsvga3dBackDXDestroyDepthStencilView;
     5101                p->pfnDXDefineElementLayout       = vmsvga3dBackDXDefineElementLayout;
     5102                p->pfnDXDestroyElementLayout      = vmsvga3dBackDXDestroyElementLayout;
     5103                p->pfnDXDefineBlendState          = vmsvga3dBackDXDefineBlendState;
     5104                p->pfnDXDestroyBlendState         = vmsvga3dBackDXDestroyBlendState;
     5105                p->pfnDXDefineDepthStencilState   = vmsvga3dBackDXDefineDepthStencilState;
     5106                p->pfnDXDestroyDepthStencilState  = vmsvga3dBackDXDestroyDepthStencilState;
     5107                p->pfnDXDefineRasterizerState     = vmsvga3dBackDXDefineRasterizerState;
     5108                p->pfnDXDestroyRasterizerState    = vmsvga3dBackDXDestroyRasterizerState;
     5109                p->pfnDXDefineSamplerState        = vmsvga3dBackDXDefineSamplerState;
     5110                p->pfnDXDestroySamplerState       = vmsvga3dBackDXDestroySamplerState;
     5111                p->pfnDXDefineShader              = vmsvga3dBackDXDefineShader;
     5112                p->pfnDXDestroyShader             = vmsvga3dBackDXDestroyShader;
     5113                p->pfnDXBindShader                = vmsvga3dBackDXBindShader;
     5114                p->pfnDXDefineStreamOutput        = vmsvga3dBackDXDefineStreamOutput;
     5115                p->pfnDXDestroyStreamOutput       = vmsvga3dBackDXDestroyStreamOutput;
     5116                p->pfnDXSetStreamOutput           = vmsvga3dBackDXSetStreamOutput;
     5117                p->pfnDXSetCOTable                = vmsvga3dBackDXSetCOTable;
     5118                p->pfnDXReadbackCOTable           = vmsvga3dBackDXReadbackCOTable;
     5119                p->pfnDXBufferCopy                = vmsvga3dBackDXBufferCopy;
     5120                p->pfnDXTransferFromBuffer        = vmsvga3dBackDXTransferFromBuffer;
     5121                p->pfnDXSurfaceCopyAndReadback    = vmsvga3dBackDXSurfaceCopyAndReadback;
     5122                p->pfnDXMoveQuery                 = vmsvga3dBackDXMoveQuery;
     5123                p->pfnDXBindAllQuery              = vmsvga3dBackDXBindAllQuery;
     5124                p->pfnDXReadbackAllQuery          = vmsvga3dBackDXReadbackAllQuery;
     5125                p->pfnDXPredTransferFromBuffer    = vmsvga3dBackDXPredTransferFromBuffer;
     5126                p->pfnDXMobFence64                = vmsvga3dBackDXMobFence64;
     5127                p->pfnDXBindAllShader             = vmsvga3dBackDXBindAllShader;
     5128                p->pfnDXHint                      = vmsvga3dBackDXHint;
     5129                p->pfnDXBufferUpdate              = vmsvga3dBackDXBufferUpdate;
     5130                p->pfnDXSetVSConstantBufferOffset = vmsvga3dBackDXSetVSConstantBufferOffset;
     5131                p->pfnDXSetPSConstantBufferOffset = vmsvga3dBackDXSetPSConstantBufferOffset;
     5132                p->pfnDXSetGSConstantBufferOffset = vmsvga3dBackDXSetGSConstantBufferOffset;
     5133                p->pfnDXSetHSConstantBufferOffset = vmsvga3dBackDXSetHSConstantBufferOffset;
     5134                p->pfnDXSetDSConstantBufferOffset = vmsvga3dBackDXSetDSConstantBufferOffset;
     5135                p->pfnDXSetCSConstantBufferOffset = vmsvga3dBackDXSetCSConstantBufferOffset;
     5136                p->pfnDXCondBindAllShader         = vmsvga3dBackDXCondBindAllShader;
     5137                p->pfnScreenCopy                  = vmsvga3dBackScreenCopy;
     5138                p->pfnGrowOTable                  = vmsvga3dBackGrowOTable;
     5139                p->pfnDXGrowCOTable               = vmsvga3dBackDXGrowCOTable;
     5140                p->pfnIntraSurfaceCopy            = vmsvga3dBackIntraSurfaceCopy;
     5141                p->pfnDefineGBSurface_v3          = vmsvga3dBackDefineGBSurface_v3;
     5142                p->pfnDXResolveCopy               = vmsvga3dBackDXResolveCopy;
     5143                p->pfnDXPredResolveCopy           = vmsvga3dBackDXPredResolveCopy;
     5144                p->pfnDXPredConvertRegion         = vmsvga3dBackDXPredConvertRegion;
     5145                p->pfnDXPredConvert               = vmsvga3dBackDXPredConvert;
     5146                p->pfnWholeSurfaceCopy            = vmsvga3dBackWholeSurfaceCopy;
     5147                p->pfnDXDefineUAView              = vmsvga3dBackDXDefineUAView;
     5148                p->pfnDXDestroyUAView             = vmsvga3dBackDXDestroyUAView;
     5149                p->pfnDXClearUAViewUint           = vmsvga3dBackDXClearUAViewUint;
     5150                p->pfnDXClearUAViewFloat          = vmsvga3dBackDXClearUAViewFloat;
     5151                p->pfnDXCopyStructureCount        = vmsvga3dBackDXCopyStructureCount;
     5152                p->pfnDXSetUAViews                = vmsvga3dBackDXSetUAViews;
     5153                p->pfnDXDrawIndexedInstancedIndirect = vmsvga3dBackDXDrawIndexedInstancedIndirect;
     5154                p->pfnDXDrawInstancedIndirect     = vmsvga3dBackDXDrawInstancedIndirect;
     5155                p->pfnDXDispatch                  = vmsvga3dBackDXDispatch;
     5156                p->pfnDXDispatchIndirect          = vmsvga3dBackDXDispatchIndirect;
     5157                p->pfnWriteZeroSurface            = vmsvga3dBackWriteZeroSurface;
     5158                p->pfnHintZeroSurface             = vmsvga3dBackHintZeroSurface;
     5159                p->pfnDXTransferToBuffer          = vmsvga3dBackDXTransferToBuffer;
     5160                p->pfnDXSetStructureCount         = vmsvga3dBackDXSetStructureCount;
     5161                p->pfnLogicOpsBitBlt              = vmsvga3dBackLogicOpsBitBlt;
     5162                p->pfnLogicOpsTransBlt            = vmsvga3dBackLogicOpsTransBlt;
     5163                p->pfnLogicOpsStretchBlt          = vmsvga3dBackLogicOpsStretchBlt;
     5164                p->pfnLogicOpsColorFill           = vmsvga3dBackLogicOpsColorFill;
     5165                p->pfnLogicOpsAlphaBlend          = vmsvga3dBackLogicOpsAlphaBlend;
     5166                p->pfnLogicOpsClearTypeBlend      = vmsvga3dBackLogicOpsClearTypeBlend;
     5167                p->pfnDefineGBSurface_v4          = vmsvga3dBackDefineGBSurface_v4;
     5168                p->pfnDXSetCSUAViews              = vmsvga3dBackDXSetCSUAViews;
     5169                p->pfnDXSetMinLOD                 = vmsvga3dBackDXSetMinLOD;
     5170                p->pfnDXDefineDepthStencilView_v2 = vmsvga3dBackDXDefineDepthStencilView_v2;
     5171                p->pfnDXDefineStreamOutputWithMob = vmsvga3dBackDXDefineStreamOutputWithMob;
     5172                p->pfnDXSetShaderIface            = vmsvga3dBackDXSetShaderIface;
     5173                p->pfnDXBindStreamOutput          = vmsvga3dBackDXBindStreamOutput;
     5174                p->pfnSurfaceStretchBltNonMSToMS  = vmsvga3dBackSurfaceStretchBltNonMSToMS;
     5175                p->pfnDXBindShaderIface           = vmsvga3dBackDXBindShaderIface;
    35875176            }
    35885177        }
  • trunk/src/VBox/Devices/Graphics/DevVGA-SVGA3d-win.cpp

    r86905 r88787  
    61726172}
    61736173
     6174int vmsvga3dQueryInterface(PVGASTATECC pThisCC, char const *pszInterfaceName, void *pvInterfaceFuncs, size_t cbInterfaceFuncs)
     6175{
     6176    RT_NOREF(pThisCC, pszInterfaceName, pvInterfaceFuncs, cbInterfaceFuncs);
     6177    return VERR_NOT_IMPLEMENTED;
     6178}
  • trunk/src/VBox/Devices/Graphics/DevVGA-SVGA3d.cpp

    r87110 r88787  
    9696    pSurface->idWeakContextAssociation = SVGA3D_INVALID_ID;
    9797    pSurface->oglId.buffer          = OPENGL_INVALID_ID;
    98 #elif defined(VMSVGA3D_DX)
     98#elif defined(VMSVGA3D_D3D11)
     99    pSurface->idAssociatedContext   = SVGA3D_INVALID_ID;
    99100    // pSurface->pBackendSurface       = NULL;
    100101#else /* VMSVGA3D_DIRECT3D */
     
    104105#endif
    105106
    106     /** @todo This 'switch' and the sufraceFlags tweaks should not be necessary.
     107    /** @todo This 'switch' and the surfaceFlags tweaks should not be necessary.
    107108     * The actual surface type will be figured out when the surface is actually used later.
    108109     * The backends code must be reviewed for unnecessary dependencies on the surfaceFlags value.
     
    295296    /* pSurface->bounce.pTexture = NULL; */
    296297    /* pSurface->emulated.pTexture = NULL; */
    297 #elif defined(VMSVGA3D_DX)
     298#elif defined(VMSVGA3D_D3D11)
    298299    /* Nothing, because all backend specific data reside in pSurface->pBackendSurface. */
    299300#else
     
    514515        /* Flush the drawing pipeline for this surface as it could be used in a shared context. */
    515516        vmsvga3dSurfaceFlush(pSurface);
    516 #elif defined(VMSVGA3D_DX)
     517#elif defined(VMSVGA3D_D3D11)
    517518        /** @todo */
    518519#else /* VMSVGA3D_OPENGL */
     
    9991000    return vmsvga3dBackDestroyScreen(pThisCC, pScreen);
    10001001}
     1002
     1003int vmsvga3dSurfaceInvalidate(PVGASTATECC pThisCC, uint32_t sid, uint32_t face, uint32_t mipmap)
     1004{
     1005    PVMSVGA3DSTATE pState = pThisCC->svga.p3dState;
     1006    AssertReturn(pState, VERR_INVALID_STATE);
     1007
     1008    PVMSVGA3DSURFACE pSurface;
     1009    int rc = vmsvga3dSurfaceFromSid(pState, sid, &pSurface);
     1010    AssertRCReturn(rc, rc);
     1011
     1012    if (face == SVGA_ID_INVALID && mipmap == SVGA_ID_INVALID)
     1013    {
     1014        for (uint32_t i = 0; i < pSurface->cLevels * pSurface->cFaces; ++i)
     1015        {
     1016            PVMSVGA3DMIPMAPLEVEL pMipmapLevel = &pSurface->paMipmapLevels[i];
     1017            pMipmapLevel->fDirty = true;
     1018        }
     1019    }
     1020    else
     1021    {
     1022        PVMSVGA3DMIPMAPLEVEL pMipmapLevel;
     1023        rc = vmsvga3dMipmapLevel(pSurface, face, mipmap, &pMipmapLevel);
     1024        AssertRCReturn(rc, rc);
     1025
     1026        pMipmapLevel->fDirty = true;
     1027    }
     1028    pSurface->fDirty = true;
     1029
     1030    return rc;
     1031}
  • trunk/src/VBox/Devices/Graphics/DevVGA-SVGA3d.h

    r86905 r88787  
    129129int vmsvga3dQueryEnd(PVGASTATECC pThisCC, uint32_t cid, SVGA3dQueryType type, SVGAGuestPtr guestResult);
    130130int vmsvga3dQueryWait(PVGASTATE pThis, PVGASTATECC pThisCC, uint32_t cid, SVGA3dQueryType type, SVGAGuestPtr guestResult);
     131
     132int vmsvga3dSurfaceInvalidate(PVGASTATECC pThisCC, uint32_t sid, uint32_t face, uint32_t mipmap);
    131133
    132134/* DevVGA-SVGA3d-shared.h: */
     
    270272typedef struct
    271273{
    272     DECLCALLBACKMEMBER(int, pfnScreenTargetBind,   (PVGASTATECC pThisCC, VMSVGASCREENOBJECT *pScreen, uint32_t sid));
    273     DECLCALLBACKMEMBER(int, pfnScreenTargetUpdate, (PVGASTATECC pThisCC, VMSVGASCREENOBJECT *pScreen, SVGA3dRect const *pRect));
     274    DECLCALLBACKMEMBER(int,  pfnScreenTargetBind,   (PVGASTATECC pThisCC, VMSVGASCREENOBJECT *pScreen, uint32_t sid));
     275    DECLCALLBACKMEMBER(int,  pfnScreenTargetUpdate, (PVGASTATECC pThisCC, VMSVGASCREENOBJECT *pScreen, SVGA3dRect const *pRect));
    274276} VMSVGA3DBACKENDFUNCSGBO;
    275277
     
    281283} VMSVGA3DBACKENDFUNCSMAP;
    282284
     285typedef struct VMSVGA3DSHADER *PVMSVGA3DSHADER;
     286typedef struct VMSVGA3DDXCONTEXT *PVMSVGA3DDXCONTEXT;
    283287#define VMSVGA3D_BACKEND_INTERFACE_NAME_DX "DX"
    284288typedef struct
    285289{
    286     DECLCALLBACKMEMBER(void, pfnDXDefineContext,             (PVMSVGA3DSTATE p3dState));
    287     DECLCALLBACKMEMBER(void, pfnDXDestroyContext,            (PVMSVGA3DSTATE p3dState));
    288     DECLCALLBACKMEMBER(void, pfnDXBindContext,               (PVMSVGA3DSTATE p3dState));
    289     DECLCALLBACKMEMBER(void, pfnDXReadbackContext,           (PVMSVGA3DSTATE p3dState));
    290     DECLCALLBACKMEMBER(void, pfnDXInvalidateContext,         (PVMSVGA3DSTATE p3dState));
    291     DECLCALLBACKMEMBER(void, pfnDXSetSingleConstantBuffer,   (PVMSVGA3DSTATE p3dState));
    292     DECLCALLBACKMEMBER(void, pfnDXSetShaderResources,        (PVMSVGA3DSTATE p3dState));
    293     DECLCALLBACKMEMBER(void, pfnDXSetShader,                 (PVMSVGA3DSTATE p3dState));
    294     DECLCALLBACKMEMBER(void, pfnDXSetSamplers,               (PVMSVGA3DSTATE p3dState));
    295     DECLCALLBACKMEMBER(void, pfnDXDraw,                      (PVMSVGA3DSTATE p3dState));
    296     DECLCALLBACKMEMBER(void, pfnDXDrawIndexed,               (PVMSVGA3DSTATE p3dState));
    297     DECLCALLBACKMEMBER(void, pfnDXDrawInstanced,             (PVMSVGA3DSTATE p3dState));
    298     DECLCALLBACKMEMBER(void, pfnDXDrawIndexedInstanced,      (PVMSVGA3DSTATE p3dState));
    299     DECLCALLBACKMEMBER(void, pfnDXDrawAuto,                  (PVMSVGA3DSTATE p3dState));
    300     DECLCALLBACKMEMBER(void, pfnDXSetInputLayout,            (PVMSVGA3DSTATE p3dState));
    301     DECLCALLBACKMEMBER(void, pfnDXSetVertexBuffers,          (PVMSVGA3DSTATE p3dState));
    302     DECLCALLBACKMEMBER(void, pfnDXSetIndexBuffer,            (PVMSVGA3DSTATE p3dState));
    303     DECLCALLBACKMEMBER(void, pfnDXSetTopology,               (PVMSVGA3DSTATE p3dState));
    304     DECLCALLBACKMEMBER(void, pfnDXSetRenderTargets,          (PVMSVGA3DSTATE p3dState));
    305     DECLCALLBACKMEMBER(void, pfnDXSetBlendState,             (PVMSVGA3DSTATE p3dState));
    306     DECLCALLBACKMEMBER(void, pfnDXSetDepthStencilState,      (PVMSVGA3DSTATE p3dState));
    307     DECLCALLBACKMEMBER(void, pfnDXSetRasterizerState,        (PVMSVGA3DSTATE p3dState));
    308     DECLCALLBACKMEMBER(void, pfnDXDefineQuery,               (PVMSVGA3DSTATE p3dState));
    309     DECLCALLBACKMEMBER(void, pfnDXDestroyQuery,              (PVMSVGA3DSTATE p3dState));
    310     DECLCALLBACKMEMBER(void, pfnDXBindQuery,                 (PVMSVGA3DSTATE p3dState));
    311     DECLCALLBACKMEMBER(void, pfnDXSetQueryOffset,            (PVMSVGA3DSTATE p3dState));
    312     DECLCALLBACKMEMBER(void, pfnDXBeginQuery,                (PVMSVGA3DSTATE p3dState));
    313     DECLCALLBACKMEMBER(void, pfnDXEndQuery,                  (PVMSVGA3DSTATE p3dState));
    314     DECLCALLBACKMEMBER(void, pfnDXReadbackQuery,             (PVMSVGA3DSTATE p3dState));
    315     DECLCALLBACKMEMBER(void, pfnDXSetPredication,            (PVMSVGA3DSTATE p3dState));
    316     DECLCALLBACKMEMBER(void, pfnDXSetSOTargets,              (PVMSVGA3DSTATE p3dState));
    317     DECLCALLBACKMEMBER(void, pfnDXSetViewports,              (PVMSVGA3DSTATE p3dState));
    318     DECLCALLBACKMEMBER(void, pfnDXSetScissorRects,           (PVMSVGA3DSTATE p3dState));
    319     DECLCALLBACKMEMBER(void, pfnDXClearRenderTargetView,     (PVMSVGA3DSTATE p3dState));
    320     DECLCALLBACKMEMBER(void, pfnDXClearDepthStencilView,     (PVMSVGA3DSTATE p3dState));
    321     DECLCALLBACKMEMBER(void, pfnDXPredCopyRegion,            (PVMSVGA3DSTATE p3dState));
    322     DECLCALLBACKMEMBER(void, pfnDXPredCopy,                  (PVMSVGA3DSTATE p3dState));
    323     DECLCALLBACKMEMBER(void, pfnDXPresentBlt,                (PVMSVGA3DSTATE p3dState));
    324     DECLCALLBACKMEMBER(void, pfnDXGenMips,                   (PVMSVGA3DSTATE p3dState));
    325     DECLCALLBACKMEMBER(void, pfnDXUpdateSubResource,         (PVMSVGA3DSTATE p3dState));
    326     DECLCALLBACKMEMBER(void, pfnDXReadbackSubResource,       (PVMSVGA3DSTATE p3dState));
    327     DECLCALLBACKMEMBER(void, pfnDXInvalidateSubResource,     (PVMSVGA3DSTATE p3dState));
    328     DECLCALLBACKMEMBER(void, pfnDXDefineShaderResourceView,  (PVMSVGA3DSTATE p3dState));
    329     DECLCALLBACKMEMBER(void, pfnDXDestroyShaderResourceView, (PVMSVGA3DSTATE p3dState));
    330     DECLCALLBACKMEMBER(void, pfnDXDefineRenderTargetView,    (PVMSVGA3DSTATE p3dState));
    331     DECLCALLBACKMEMBER(void, pfnDXDestroyRenderTargetView,   (PVMSVGA3DSTATE p3dState));
    332     DECLCALLBACKMEMBER(void, pfnDXDefineDepthStencilView,    (PVMSVGA3DSTATE p3dState));
    333     DECLCALLBACKMEMBER(void, pfnDXDestroyDepthStencilView,   (PVMSVGA3DSTATE p3dState));
    334     DECLCALLBACKMEMBER(void, pfnDXDefineElementLayout,       (PVMSVGA3DSTATE p3dState));
    335     DECLCALLBACKMEMBER(void, pfnDXDestroyElementLayout,      (PVMSVGA3DSTATE p3dState));
    336     DECLCALLBACKMEMBER(void, pfnDXDefineBlendState,          (PVMSVGA3DSTATE p3dState));
    337     DECLCALLBACKMEMBER(void, pfnDXDestroyBlendState,         (PVMSVGA3DSTATE p3dState));
    338     DECLCALLBACKMEMBER(void, pfnDXDefineDepthStencilState,   (PVMSVGA3DSTATE p3dState));
    339     DECLCALLBACKMEMBER(void, pfnDXDestroyDepthStencilState,  (PVMSVGA3DSTATE p3dState));
    340     DECLCALLBACKMEMBER(void, pfnDXDefineRasterizerState,     (PVMSVGA3DSTATE p3dState));
    341     DECLCALLBACKMEMBER(void, pfnDXDestroyRasterizerState,    (PVMSVGA3DSTATE p3dState));
    342     DECLCALLBACKMEMBER(void, pfnDXDefineSamplerState,        (PVMSVGA3DSTATE p3dState));
    343     DECLCALLBACKMEMBER(void, pfnDXDestroySamplerState,       (PVMSVGA3DSTATE p3dState));
    344     DECLCALLBACKMEMBER(void, pfnDXDefineShader,              (PVMSVGA3DSTATE p3dState));
    345     DECLCALLBACKMEMBER(void, pfnDXDestroyShader,             (PVMSVGA3DSTATE p3dState));
    346     DECLCALLBACKMEMBER(void, pfnDXBindShader,                (PVMSVGA3DSTATE p3dState));
    347     DECLCALLBACKMEMBER(void, pfnDXDefineStreamOutput,        (PVMSVGA3DSTATE p3dState));
    348     DECLCALLBACKMEMBER(void, pfnDXDestroyStreamOutput,       (PVMSVGA3DSTATE p3dState));
    349     DECLCALLBACKMEMBER(void, pfnDXSetStreamOutput,           (PVMSVGA3DSTATE p3dState));
    350     DECLCALLBACKMEMBER(void, pfnDXSetCOTable,                (PVMSVGA3DSTATE p3dState));
    351     DECLCALLBACKMEMBER(void, pfnDXReadbackCOTable,           (PVMSVGA3DSTATE p3dState));
    352     DECLCALLBACKMEMBER(void, pfnDXBufferCopy,                (PVMSVGA3DSTATE p3dState));
    353     DECLCALLBACKMEMBER(void, pfnDXTransferFromBuffer,        (PVMSVGA3DSTATE p3dState));
    354     DECLCALLBACKMEMBER(void, pfnDXSurfaceCopyAndReadback,    (PVMSVGA3DSTATE p3dState));
    355     DECLCALLBACKMEMBER(void, pfnDXMoveQuery,                 (PVMSVGA3DSTATE p3dState));
    356     DECLCALLBACKMEMBER(void, pfnDXBindAllQuery,              (PVMSVGA3DSTATE p3dState));
    357     DECLCALLBACKMEMBER(void, pfnDXReadbackAllQuery,          (PVMSVGA3DSTATE p3dState));
    358     DECLCALLBACKMEMBER(void, pfnDXPredTransferFromBuffer,    (PVMSVGA3DSTATE p3dState));
    359     DECLCALLBACKMEMBER(void, pfnDXMobFence64,                (PVMSVGA3DSTATE p3dState));
    360     DECLCALLBACKMEMBER(void, pfnDXBindAllShader,             (PVMSVGA3DSTATE p3dState));
    361     DECLCALLBACKMEMBER(void, pfnDXHint,                      (PVMSVGA3DSTATE p3dState));
    362     DECLCALLBACKMEMBER(void, pfnDXBufferUpdate,              (PVMSVGA3DSTATE p3dState));
    363     DECLCALLBACKMEMBER(void, pfnDXSetVSConstantBufferOffset, (PVMSVGA3DSTATE p3dState));
    364     DECLCALLBACKMEMBER(void, pfnDXSetPSConstantBufferOffset, (PVMSVGA3DSTATE p3dState));
    365     DECLCALLBACKMEMBER(void, pfnDXSetGSConstantBufferOffset, (PVMSVGA3DSTATE p3dState));
    366     DECLCALLBACKMEMBER(void, pfnDXSetHSConstantBufferOffset, (PVMSVGA3DSTATE p3dState));
    367     DECLCALLBACKMEMBER(void, pfnDXSetDSConstantBufferOffset, (PVMSVGA3DSTATE p3dState));
    368     DECLCALLBACKMEMBER(void, pfnDXSetCSConstantBufferOffset, (PVMSVGA3DSTATE p3dState));
    369     DECLCALLBACKMEMBER(void, pfnDXCondBindAllShader,         (PVMSVGA3DSTATE p3dState));
    370     DECLCALLBACKMEMBER(void, pfnScreenCopy,                  (PVMSVGA3DSTATE p3dState));
    371     DECLCALLBACKMEMBER(void, pfnGrowOTable,                  (PVMSVGA3DSTATE p3dState));
    372     DECLCALLBACKMEMBER(void, pfnDXGrowCOTable,               (PVMSVGA3DSTATE p3dState));
    373     DECLCALLBACKMEMBER(void, pfnIntraSurfaceCopy,            (PVMSVGA3DSTATE p3dState));
    374     DECLCALLBACKMEMBER(void, pfnDefineGBSurface_v3,          (PVMSVGA3DSTATE p3dState));
    375     DECLCALLBACKMEMBER(void, pfnDXResolveCopy,               (PVMSVGA3DSTATE p3dState));
    376     DECLCALLBACKMEMBER(void, pfnDXPredResolveCopy,           (PVMSVGA3DSTATE p3dState));
    377     DECLCALLBACKMEMBER(void, pfnDXPredConvertRegion,         (PVMSVGA3DSTATE p3dState));
    378     DECLCALLBACKMEMBER(void, pfnDXPredConvert,               (PVMSVGA3DSTATE p3dState));
    379     DECLCALLBACKMEMBER(void, pfnWholeSurfaceCopy,            (PVMSVGA3DSTATE p3dState));
    380     DECLCALLBACKMEMBER(void, pfnDXDefineUAView,              (PVMSVGA3DSTATE p3dState));
    381     DECLCALLBACKMEMBER(void, pfnDXDestroyUAView,             (PVMSVGA3DSTATE p3dState));
    382     DECLCALLBACKMEMBER(void, pfnDXClearUAViewUint,           (PVMSVGA3DSTATE p3dState));
    383     DECLCALLBACKMEMBER(void, pfnDXClearUAViewFloat,          (PVMSVGA3DSTATE p3dState));
    384     DECLCALLBACKMEMBER(void, pfnDXCopyStructureCount,        (PVMSVGA3DSTATE p3dState));
    385     DECLCALLBACKMEMBER(void, pfnDXSetUAViews,                (PVMSVGA3DSTATE p3dState));
    386     DECLCALLBACKMEMBER(void, pfnDXDrawIndexedInstancedIndirect, (PVMSVGA3DSTATE p3dState));
    387     DECLCALLBACKMEMBER(void, pfnDXDrawInstancedIndirect,     (PVMSVGA3DSTATE p3dState));
    388     DECLCALLBACKMEMBER(void, pfnDXDispatch,                  (PVMSVGA3DSTATE p3dState));
    389     DECLCALLBACKMEMBER(void, pfnDXDispatchIndirect,          (PVMSVGA3DSTATE p3dState));
    390     DECLCALLBACKMEMBER(void, pfnWriteZeroSurface,            (PVMSVGA3DSTATE p3dState));
    391     DECLCALLBACKMEMBER(void, pfnHintZeroSurface,             (PVMSVGA3DSTATE p3dState));
    392     DECLCALLBACKMEMBER(void, pfnDXTransferToBuffer,          (PVMSVGA3DSTATE p3dState));
    393     DECLCALLBACKMEMBER(void, pfnDXSetStructureCount,         (PVMSVGA3DSTATE p3dState));
    394     DECLCALLBACKMEMBER(void, pfnLogicOpsBitBlt,              (PVMSVGA3DSTATE p3dState));
    395     DECLCALLBACKMEMBER(void, pfnLogicOpsTransBlt,            (PVMSVGA3DSTATE p3dState));
    396     DECLCALLBACKMEMBER(void, pfnLogicOpsStretchBlt,          (PVMSVGA3DSTATE p3dState));
    397     DECLCALLBACKMEMBER(void, pfnLogicOpsColorFill,           (PVMSVGA3DSTATE p3dState));
    398     DECLCALLBACKMEMBER(void, pfnLogicOpsAlphaBlend,          (PVMSVGA3DSTATE p3dState));
    399     DECLCALLBACKMEMBER(void, pfnLogicOpsClearTypeBlend,      (PVMSVGA3DSTATE p3dState));
    400     DECLCALLBACKMEMBER(void, pfnDefineGBSurface_v4,          (PVMSVGA3DSTATE p3dState));
    401     DECLCALLBACKMEMBER(void, pfnDXSetCSUAViews,              (PVMSVGA3DSTATE p3dState));
    402     DECLCALLBACKMEMBER(void, pfnDXSetMinLOD,                 (PVMSVGA3DSTATE p3dState));
    403     DECLCALLBACKMEMBER(void, pfnDXDefineDepthStencilView_v2, (PVMSVGA3DSTATE p3dState));
    404     DECLCALLBACKMEMBER(void, pfnDXDefineStreamOutputWithMob, (PVMSVGA3DSTATE p3dState));
    405     DECLCALLBACKMEMBER(void, pfnDXSetShaderIface,            (PVMSVGA3DSTATE p3dState));
    406     DECLCALLBACKMEMBER(void, pfnDXBindStreamOutput,          (PVMSVGA3DSTATE p3dState));
    407     DECLCALLBACKMEMBER(void, pfnSurfaceStretchBltNonMSToMS,  (PVMSVGA3DSTATE p3dState));
    408     DECLCALLBACKMEMBER(void, pfnDXBindShaderIface,           (PVMSVGA3DSTATE p3dState));
     290    DECLCALLBACKMEMBER(int, pfnDXDefineContext,             (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     291    DECLCALLBACKMEMBER(int, pfnDXDestroyContext,            (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     292    DECLCALLBACKMEMBER(int, pfnDXBindContext,               (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     293    DECLCALLBACKMEMBER(int, pfnDXReadbackContext,           (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     294    DECLCALLBACKMEMBER(int, pfnDXInvalidateContext,         (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     295    DECLCALLBACKMEMBER(int, pfnDXSetSingleConstantBuffer,   (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, uint32_t slot, SVGA3dShaderType type, SVGA3dSurfaceId sid, uint32_t offsetInBytes, uint32_t sizeInBytes));
     296    DECLCALLBACKMEMBER(int, pfnDXSetShaderResources,        (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     297    DECLCALLBACKMEMBER(int, pfnDXSetShader,                 (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, PVMSVGA3DSHADER pShader));
     298    DECLCALLBACKMEMBER(int, pfnDXSetSamplers,               (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, uint32_t startSampler, SVGA3dShaderType type, uint32_t cSamplerId, SVGA3dSamplerId const *paSamplerId));
     299    DECLCALLBACKMEMBER(int, pfnDXDraw,                      (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, uint32_t vertexCount, uint32_t startVertexLocation));
     300    DECLCALLBACKMEMBER(int, pfnDXDrawIndexed,               (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, uint32_t indexCount, uint32_t startIndexLocation, int32_t baseVertexLocation));
     301    DECLCALLBACKMEMBER(int, pfnDXDrawInstanced,             (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     302    DECLCALLBACKMEMBER(int, pfnDXDrawIndexedInstanced,      (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     303    DECLCALLBACKMEMBER(int, pfnDXDrawAuto,                  (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     304    DECLCALLBACKMEMBER(int, pfnDXSetInputLayout,            (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dElementLayoutId elementLayoutId));
     305    DECLCALLBACKMEMBER(int, pfnDXSetVertexBuffers,          (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, uint32_t startBuffer, uint32_t cVertexBuffer, SVGA3dVertexBuffer const *paVertexBuffer));
     306    DECLCALLBACKMEMBER(int, pfnDXSetIndexBuffer,            (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dSurfaceId sid, SVGA3dSurfaceFormat format, uint32_t offset));
     307    DECLCALLBACKMEMBER(int, pfnDXSetTopology,               (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dPrimitiveType topology));
     308    DECLCALLBACKMEMBER(int, pfnDXSetRenderTargets,          (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dDepthStencilViewId depthStencilViewId, uint32_t cRenderTargetViewId, SVGA3dRenderTargetViewId const *paRenderTargetViewId));
     309    DECLCALLBACKMEMBER(int, pfnDXSetBlendState,             (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dBlendStateId blendId, float const blendFactor[4], uint32_t sampleMask));
     310    DECLCALLBACKMEMBER(int, pfnDXSetDepthStencilState,      (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dDepthStencilStateId depthStencilId, uint32_t stencilRef));
     311    DECLCALLBACKMEMBER(int, pfnDXSetRasterizerState,        (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dRasterizerStateId rasterizerId));
     312    DECLCALLBACKMEMBER(int, pfnDXDefineQuery,               (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     313    DECLCALLBACKMEMBER(int, pfnDXDestroyQuery,              (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     314    DECLCALLBACKMEMBER(int, pfnDXBindQuery,                 (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     315    DECLCALLBACKMEMBER(int, pfnDXSetQueryOffset,            (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     316    DECLCALLBACKMEMBER(int, pfnDXBeginQuery,                (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     317    DECLCALLBACKMEMBER(int, pfnDXEndQuery,                  (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     318    DECLCALLBACKMEMBER(int, pfnDXReadbackQuery,             (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     319    DECLCALLBACKMEMBER(int, pfnDXSetPredication,            (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     320    DECLCALLBACKMEMBER(int, pfnDXSetSOTargets,              (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     321    DECLCALLBACKMEMBER(int, pfnDXSetViewports,              (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, uint32_t cViewport, SVGA3dViewport const *paViewport));
     322    DECLCALLBACKMEMBER(int, pfnDXSetScissorRects,           (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, uint32_t cRect, SVGASignedRect const *paRect));
     323    DECLCALLBACKMEMBER(int, pfnDXClearRenderTargetView,     (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     324    DECLCALLBACKMEMBER(int, pfnDXClearDepthStencilView,     (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     325    DECLCALLBACKMEMBER(int, pfnDXPredCopyRegion,            (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     326    DECLCALLBACKMEMBER(int, pfnDXPredCopy,                  (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     327    DECLCALLBACKMEMBER(int, pfnDXPresentBlt,                (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     328    DECLCALLBACKMEMBER(int, pfnDXGenMips,                   (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     329    DECLCALLBACKMEMBER(int, pfnDXUpdateSubResource,         (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     330    DECLCALLBACKMEMBER(int, pfnDXReadbackSubResource,       (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     331    DECLCALLBACKMEMBER(int, pfnDXInvalidateSubResource,     (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     332    DECLCALLBACKMEMBER(int, pfnDXDefineShaderResourceView,  (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dShaderResourceViewId shaderResourceViewId, SVGACOTableDXSRViewEntry const *pEntry));
     333    DECLCALLBACKMEMBER(int, pfnDXDestroyShaderResourceView, (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     334    DECLCALLBACKMEMBER(int, pfnDXDefineRenderTargetView,    (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dRenderTargetViewId renderTargetViewId, SVGACOTableDXRTViewEntry const *pEntry));
     335    DECLCALLBACKMEMBER(int, pfnDXDestroyRenderTargetView,   (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     336    DECLCALLBACKMEMBER(int, pfnDXDefineDepthStencilView,    (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     337    DECLCALLBACKMEMBER(int, pfnDXDestroyDepthStencilView,   (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     338    DECLCALLBACKMEMBER(int, pfnDXDefineElementLayout,       (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dElementLayoutId elementLayoutId, SVGACOTableDXElementLayoutEntry const *pEntry));
     339    DECLCALLBACKMEMBER(int, pfnDXDestroyElementLayout,      (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     340    DECLCALLBACKMEMBER(int, pfnDXDefineBlendState,          (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dBlendStateId blendId, SVGACOTableDXBlendStateEntry const *pEntry));
     341    DECLCALLBACKMEMBER(int, pfnDXDestroyBlendState,         (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     342    DECLCALLBACKMEMBER(int, pfnDXDefineDepthStencilState,   (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dDepthStencilStateId depthStencilId, SVGACOTableDXDepthStencilEntry *pEntry));
     343    DECLCALLBACKMEMBER(int, pfnDXDestroyDepthStencilState,  (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     344    DECLCALLBACKMEMBER(int, pfnDXDefineRasterizerState,     (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dRasterizerStateId rasterizerId, SVGACOTableDXRasterizerStateEntry const *pEntry));
     345    DECLCALLBACKMEMBER(int, pfnDXDestroyRasterizerState,    (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     346    DECLCALLBACKMEMBER(int, pfnDXDefineSamplerState,        (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGA3dSamplerId samplerId, SVGACOTableDXSamplerEntry const *pEntry));
     347    DECLCALLBACKMEMBER(int, pfnDXDestroySamplerState,       (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     348    DECLCALLBACKMEMBER(int, pfnDXDefineShader,              (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, PVMSVGA3DSHADER pShader));
     349    DECLCALLBACKMEMBER(int, pfnDXDestroyShader,             (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     350    DECLCALLBACKMEMBER(int, pfnDXBindShader,                (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, PVMSVGA3DSHADER pShader, void const *pvShaderBytecode));
     351    DECLCALLBACKMEMBER(int, pfnDXDefineStreamOutput,        (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     352    DECLCALLBACKMEMBER(int, pfnDXDestroyStreamOutput,       (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     353    DECLCALLBACKMEMBER(int, pfnDXSetStreamOutput,           (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     354    DECLCALLBACKMEMBER(int, pfnDXSetCOTable,                (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext, SVGACOTableType type, uint32_t cEntries));
     355    DECLCALLBACKMEMBER(int, pfnDXReadbackCOTable,           (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     356    DECLCALLBACKMEMBER(int, pfnDXBufferCopy,                (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     357    DECLCALLBACKMEMBER(int, pfnDXTransferFromBuffer,        (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     358    DECLCALLBACKMEMBER(int, pfnDXSurfaceCopyAndReadback,    (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     359    DECLCALLBACKMEMBER(int, pfnDXMoveQuery,                 (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     360    DECLCALLBACKMEMBER(int, pfnDXBindAllQuery,              (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     361    DECLCALLBACKMEMBER(int, pfnDXReadbackAllQuery,          (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     362    DECLCALLBACKMEMBER(int, pfnDXPredTransferFromBuffer,    (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     363    DECLCALLBACKMEMBER(int, pfnDXMobFence64,                (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     364    DECLCALLBACKMEMBER(int, pfnDXBindAllShader,             (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     365    DECLCALLBACKMEMBER(int, pfnDXHint,                      (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     366    DECLCALLBACKMEMBER(int, pfnDXBufferUpdate,              (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     367    DECLCALLBACKMEMBER(int, pfnDXSetVSConstantBufferOffset, (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     368    DECLCALLBACKMEMBER(int, pfnDXSetPSConstantBufferOffset, (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     369    DECLCALLBACKMEMBER(int, pfnDXSetGSConstantBufferOffset, (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     370    DECLCALLBACKMEMBER(int, pfnDXSetHSConstantBufferOffset, (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     371    DECLCALLBACKMEMBER(int, pfnDXSetDSConstantBufferOffset, (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     372    DECLCALLBACKMEMBER(int, pfnDXSetCSConstantBufferOffset, (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     373    DECLCALLBACKMEMBER(int, pfnDXCondBindAllShader,         (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     374    DECLCALLBACKMEMBER(int, pfnScreenCopy,                  (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     375    DECLCALLBACKMEMBER(int, pfnGrowOTable,                  (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     376    DECLCALLBACKMEMBER(int, pfnDXGrowCOTable,               (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     377    DECLCALLBACKMEMBER(int, pfnIntraSurfaceCopy,            (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     378    DECLCALLBACKMEMBER(int, pfnDefineGBSurface_v3,          (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     379    DECLCALLBACKMEMBER(int, pfnDXResolveCopy,               (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     380    DECLCALLBACKMEMBER(int, pfnDXPredResolveCopy,           (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     381    DECLCALLBACKMEMBER(int, pfnDXPredConvertRegion,         (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     382    DECLCALLBACKMEMBER(int, pfnDXPredConvert,               (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     383    DECLCALLBACKMEMBER(int, pfnWholeSurfaceCopy,            (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     384    DECLCALLBACKMEMBER(int, pfnDXDefineUAView,              (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     385    DECLCALLBACKMEMBER(int, pfnDXDestroyUAView,             (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     386    DECLCALLBACKMEMBER(int, pfnDXClearUAViewUint,           (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     387    DECLCALLBACKMEMBER(int, pfnDXClearUAViewFloat,          (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     388    DECLCALLBACKMEMBER(int, pfnDXCopyStructureCount,        (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     389    DECLCALLBACKMEMBER(int, pfnDXSetUAViews,                (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     390    DECLCALLBACKMEMBER(int, pfnDXDrawIndexedInstancedIndirect, (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     391    DECLCALLBACKMEMBER(int, pfnDXDrawInstancedIndirect,     (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     392    DECLCALLBACKMEMBER(int, pfnDXDispatch,                  (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     393    DECLCALLBACKMEMBER(int, pfnDXDispatchIndirect,          (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     394    DECLCALLBACKMEMBER(int, pfnWriteZeroSurface,            (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     395    DECLCALLBACKMEMBER(int, pfnHintZeroSurface,             (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     396    DECLCALLBACKMEMBER(int, pfnDXTransferToBuffer,          (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     397    DECLCALLBACKMEMBER(int, pfnDXSetStructureCount,         (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     398    DECLCALLBACKMEMBER(int, pfnLogicOpsBitBlt,              (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     399    DECLCALLBACKMEMBER(int, pfnLogicOpsTransBlt,            (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     400    DECLCALLBACKMEMBER(int, pfnLogicOpsStretchBlt,          (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     401    DECLCALLBACKMEMBER(int, pfnLogicOpsColorFill,           (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     402    DECLCALLBACKMEMBER(int, pfnLogicOpsAlphaBlend,          (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     403    DECLCALLBACKMEMBER(int, pfnLogicOpsClearTypeBlend,      (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     404    DECLCALLBACKMEMBER(int, pfnDefineGBSurface_v4,          (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     405    DECLCALLBACKMEMBER(int, pfnDXSetCSUAViews,              (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     406    DECLCALLBACKMEMBER(int, pfnDXSetMinLOD,                 (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     407    DECLCALLBACKMEMBER(int, pfnDXDefineDepthStencilView_v2, (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     408    DECLCALLBACKMEMBER(int, pfnDXDefineStreamOutputWithMob, (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     409    DECLCALLBACKMEMBER(int, pfnDXSetShaderIface,            (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     410    DECLCALLBACKMEMBER(int, pfnDXBindStreamOutput,          (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     411    DECLCALLBACKMEMBER(int, pfnSurfaceStretchBltNonMSToMS,  (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
     412    DECLCALLBACKMEMBER(int, pfnDXBindShaderIface,           (PVGASTATECC pThisCC, PVMSVGA3DDXCONTEXT pDXContext));
    409413} VMSVGA3DBACKENDFUNCSDX;
    410414
    411415int vmsvga3dQueryInterface(PVGASTATECC pThisCC, char const *pszInterfaceName, void *pvInterfaceFuncs, size_t cbInterfaceFuncs);
    412416
     417#ifdef VMSVGA3D_DX
     418/* Helpers. */
     419int vmsvga3dDXUnbindContext(PVGASTATECC pThisCC, uint32_t cid, SVGADXContextMobFormat *pSvgaDXContext);
     420
     421/* Command handlers. */
     422int vmsvga3dDXDefineContext(PVGASTATECC pThisCC, uint32_t cid);
     423int vmsvga3dDXDestroyContext(PVGASTATECC pThisCC, uint32_t cid);
     424int vmsvga3dDXBindContext(PVGASTATECC pThisCC, uint32_t cid, SVGADXContextMobFormat *pSvgaDXContext);
     425int vmsvga3dDXReadbackContext(PVGASTATECC pThisCC, uint32_t idDXContext);
     426int vmsvga3dDXInvalidateContext(PVGASTATECC pThisCC, uint32_t idDXContext);
     427int vmsvga3dDXSetSingleConstantBuffer(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetSingleConstantBuffer const *pCmd);
     428int vmsvga3dDXSetShaderResources(PVGASTATECC pThisCC, uint32_t idDXContext);
     429int vmsvga3dDXSetShader(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetShader const *pCmd);
     430int vmsvga3dDXSetSamplers(PVGASTATECC pThisCC, uint32_t idDXContext, uint32_t startSampler, SVGA3dShaderType type, uint32_t cSamplerId, SVGA3dSamplerId const *paSamplerId);
     431int vmsvga3dDXDraw(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDraw const *pCmd);
     432int vmsvga3dDXDrawIndexed(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDrawIndexed const *pCmd);
     433int vmsvga3dDXDrawInstanced(PVGASTATECC pThisCC, uint32_t idDXContext);
     434int vmsvga3dDXDrawIndexedInstanced(PVGASTATECC pThisCC, uint32_t idDXContext);
     435int vmsvga3dDXDrawAuto(PVGASTATECC pThisCC, uint32_t idDXContext);
     436int vmsvga3dDXSetInputLayout(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dElementLayoutId elementLayoutId);
     437int vmsvga3dDXSetVertexBuffers(PVGASTATECC pThisCC, uint32_t idDXContext, uint32_t startBuffer, uint32_t cVertexBuffer, SVGA3dVertexBuffer const *paVertexBuffer);
     438int vmsvga3dDXSetIndexBuffer(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetIndexBuffer const *pCmd);
     439int vmsvga3dDXSetTopology(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dPrimitiveType topology);
     440int vmsvga3dDXSetRenderTargets(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dDepthStencilViewId depthStencilViewId, uint32_t cRenderTargetViewId, SVGA3dRenderTargetViewId const *paRenderTargetViewId);
     441int vmsvga3dDXSetBlendState(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetBlendState const *pCmd);
     442int vmsvga3dDXSetDepthStencilState(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXSetDepthStencilState const *pCmd);
     443int vmsvga3dDXSetRasterizerState(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dRasterizerStateId rasterizerId);
     444int vmsvga3dDXDefineQuery(PVGASTATECC pThisCC, uint32_t idDXContext);
     445int vmsvga3dDXDestroyQuery(PVGASTATECC pThisCC, uint32_t idDXContext);
     446int vmsvga3dDXBindQuery(PVGASTATECC pThisCC, uint32_t idDXContext);
     447int vmsvga3dDXSetQueryOffset(PVGASTATECC pThisCC, uint32_t idDXContext);
     448int vmsvga3dDXBeginQuery(PVGASTATECC pThisCC, uint32_t idDXContext);
     449int vmsvga3dDXEndQuery(PVGASTATECC pThisCC, uint32_t idDXContext);
     450int vmsvga3dDXReadbackQuery(PVGASTATECC pThisCC, uint32_t idDXContext);
     451int vmsvga3dDXSetPredication(PVGASTATECC pThisCC, uint32_t idDXContext);
     452int vmsvga3dDXSetSOTargets(PVGASTATECC pThisCC, uint32_t idDXContext);
     453int vmsvga3dDXSetViewports(PVGASTATECC pThisCC, uint32_t idDXContext, uint32_t cViewport, SVGA3dViewport const *paViewport);
     454int vmsvga3dDXSetScissorRects(PVGASTATECC pThisCC, uint32_t idDXContext, uint32_t cRect, SVGASignedRect const *paRect);
     455int vmsvga3dDXClearRenderTargetView(PVGASTATECC pThisCC, uint32_t idDXContext);
     456int vmsvga3dDXClearDepthStencilView(PVGASTATECC pThisCC, uint32_t idDXContext);
     457int vmsvga3dDXPredCopyRegion(PVGASTATECC pThisCC, uint32_t idDXContext);
     458int vmsvga3dDXPredCopy(PVGASTATECC pThisCC, uint32_t idDXContext);
     459int vmsvga3dDXPresentBlt(PVGASTATECC pThisCC, uint32_t idDXContext);
     460int vmsvga3dDXGenMips(PVGASTATECC pThisCC, uint32_t idDXContext);
     461int vmsvga3dDXUpdateSubResource(PVGASTATECC pThisCC, uint32_t idDXContext);
     462int vmsvga3dDXReadbackSubResource(PVGASTATECC pThisCC, uint32_t idDXContext);
     463int vmsvga3dDXInvalidateSubResource(PVGASTATECC pThisCC, uint32_t idDXContext);
     464int vmsvga3dDXDefineShaderResourceView(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineShaderResourceView const *pCmd);
     465int vmsvga3dDXDestroyShaderResourceView(PVGASTATECC pThisCC, uint32_t idDXContext);
     466int vmsvga3dDXDefineRenderTargetView(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineRenderTargetView const *pCmd);
     467int vmsvga3dDXDestroyRenderTargetView(PVGASTATECC pThisCC, uint32_t idDXContext);
     468int vmsvga3dDXDefineDepthStencilView(PVGASTATECC pThisCC, uint32_t idDXContext);
     469int vmsvga3dDXDestroyDepthStencilView(PVGASTATECC pThisCC, uint32_t idDXContext);
     470int vmsvga3dDXDefineElementLayout(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dElementLayoutId elementLayoutId, uint32_t cDesc, SVGA3dInputElementDesc const *paDesc);
     471int vmsvga3dDXDestroyElementLayout(PVGASTATECC pThisCC, uint32_t idDXContext);
     472int vmsvga3dDXDefineBlendState(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineBlendState const *pCmd);
     473int vmsvga3dDXDestroyBlendState(PVGASTATECC pThisCC, uint32_t idDXContext);
     474int vmsvga3dDXDefineDepthStencilState(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineDepthStencilState const *pCmd);
     475int vmsvga3dDXDestroyDepthStencilState(PVGASTATECC pThisCC, uint32_t idDXContext);
     476int vmsvga3dDXDefineRasterizerState(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineRasterizerState const *pCmd);
     477int vmsvga3dDXDestroyRasterizerState(PVGASTATECC pThisCC, uint32_t idDXContext);
     478int vmsvga3dDXDefineSamplerState(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineSamplerState const *pCmd);
     479int vmsvga3dDXDestroySamplerState(PVGASTATECC pThisCC, uint32_t idDXContext);
     480int vmsvga3dDXDefineShader(PVGASTATECC pThisCC, uint32_t idDXContext, SVGA3dCmdDXDefineShader const *pCmd);
     481int vmsvga3dDXDestroyShader(PVGASTATECC pThisCC, uint32_t idDXContext);
     482int vmsvga3dDXBindShader(PVGASTATECC pThisCC, uint32_t cid, PVMSVGAMOB pMob, uint32_t shid, uint32_t offsetInBytes);
     483int vmsvga3dDXDefineStreamOutput(PVGASTATECC pThisCC, uint32_t idDXContext);
     484int vmsvga3dDXDestroyStreamOutput(PVGASTATECC pThisCC, uint32_t idDXContext);
     485int vmsvga3dDXSetStreamOutput(PVGASTATECC pThisCC, uint32_t idDXContext);
     486int vmsvga3dDXSetCOTable(PVGASTATECC pThisCC, uint32_t cid, PVMSVGAMOB pMob, SVGACOTableType type, uint32_t validSizeInBytes);
     487int vmsvga3dDXReadbackCOTable(PVGASTATECC pThisCC, uint32_t idDXContext);
     488int vmsvga3dDXBufferCopy(PVGASTATECC pThisCC, uint32_t idDXContext);
     489int vmsvga3dDXTransferFromBuffer(PVGASTATECC pThisCC, uint32_t idDXContext);
     490int vmsvga3dDXSurfaceCopyAndReadback(PVGASTATECC pThisCC, uint32_t idDXContext);
     491int vmsvga3dDXMoveQuery(PVGASTATECC pThisCC, uint32_t idDXContext);
     492int vmsvga3dDXBindAllQuery(PVGASTATECC pThisCC, uint32_t idDXContext);
     493int vmsvga3dDXReadbackAllQuery(PVGASTATECC pThisCC, uint32_t idDXContext);
     494int vmsvga3dDXPredTransferFromBuffer(PVGASTATECC pThisCC, uint32_t idDXContext);
     495int vmsvga3dDXMobFence64(PVGASTATECC pThisCC, uint32_t idDXContext);
     496int vmsvga3dDXBindAllShader(PVGASTATECC pThisCC, uint32_t idDXContext);
     497int vmsvga3dDXHint(PVGASTATECC pThisCC, uint32_t idDXContext);
     498int vmsvga3dDXBufferUpdate(PVGASTATECC pThisCC, uint32_t idDXContext);
     499int vmsvga3dDXSetVSConstantBufferOffset(PVGASTATECC pThisCC, uint32_t idDXContext);
     500int vmsvga3dDXSetPSConstantBufferOffset(PVGASTATECC pThisCC, uint32_t idDXContext);
     501int vmsvga3dDXSetGSConstantBufferOffset(PVGASTATECC pThisCC, uint32_t idDXContext);
     502int vmsvga3dDXSetHSConstantBufferOffset(PVGASTATECC pThisCC, uint32_t idDXContext);
     503int vmsvga3dDXSetDSConstantBufferOffset(PVGASTATECC pThisCC, uint32_t idDXContext);
     504int vmsvga3dDXSetCSConstantBufferOffset(PVGASTATECC pThisCC, uint32_t idDXContext);
     505int vmsvga3dDXCondBindAllShader(PVGASTATECC pThisCC, uint32_t idDXContext);
     506int vmsvga3dScreenCopy(PVGASTATECC pThisCC, uint32_t idDXContext);
     507int vmsvga3dGrowOTable(PVGASTATECC pThisCC, uint32_t idDXContext);
     508int vmsvga3dDXGrowCOTable(PVGASTATECC pThisCC, uint32_t idDXContext);
     509int vmsvga3dIntraSurfaceCopy(PVGASTATECC pThisCC, uint32_t idDXContext);
     510int vmsvga3dDefineGBSurface_v3(PVGASTATECC pThisCC, uint32_t idDXContext);
     511int vmsvga3dDXResolveCopy(PVGASTATECC pThisCC, uint32_t idDXContext);
     512int vmsvga3dDXPredResolveCopy(PVGASTATECC pThisCC, uint32_t idDXContext);
     513int vmsvga3dDXPredConvertRegion(PVGASTATECC pThisCC, uint32_t idDXContext);
     514int vmsvga3dDXPredConvert(PVGASTATECC pThisCC, uint32_t idDXContext);
     515int vmsvga3dWholeSurfaceCopy(PVGASTATECC pThisCC, uint32_t idDXContext);
     516int vmsvga3dDXDefineUAView(PVGASTATECC pThisCC, uint32_t idDXContext);
     517int vmsvga3dDXDestroyUAView(PVGASTATECC pThisCC, uint32_t idDXContext);
     518int vmsvga3dDXClearUAViewUint(PVGASTATECC pThisCC, uint32_t idDXContext);
     519int vmsvga3dDXClearUAViewFloat(PVGASTATECC pThisCC, uint32_t idDXContext);
     520int vmsvga3dDXCopyStructureCount(PVGASTATECC pThisCC, uint32_t idDXContext);
     521int vmsvga3dDXSetUAViews(PVGASTATECC pThisCC, uint32_t idDXContext);
     522int vmsvga3dDXDrawIndexedInstancedIndirect(PVGASTATECC pThisCC, uint32_t idDXContext);
     523int vmsvga3dDXDrawInstancedIndirect(PVGASTATECC pThisCC, uint32_t idDXContext);
     524int vmsvga3dDXDispatch(PVGASTATECC pThisCC, uint32_t idDXContext);
     525int vmsvga3dDXDispatchIndirect(PVGASTATECC pThisCC, uint32_t idDXContext);
     526int vmsvga3dWriteZeroSurface(PVGASTATECC pThisCC, uint32_t idDXContext);
     527int vmsvga3dHintZeroSurface(PVGASTATECC pThisCC, uint32_t idDXContext);
     528int vmsvga3dDXTransferToBuffer(PVGASTATECC pThisCC, uint32_t idDXContext);
     529int vmsvga3dDXSetStructureCount(PVGASTATECC pThisCC, uint32_t idDXContext);
     530int vmsvga3dLogicOpsBitBlt(PVGASTATECC pThisCC, uint32_t idDXContext);
     531int vmsvga3dLogicOpsTransBlt(PVGASTATECC pThisCC, uint32_t idDXContext);
     532int vmsvga3dLogicOpsStretchBlt(PVGASTATECC pThisCC, uint32_t idDXContext);
     533int vmsvga3dLogicOpsColorFill(PVGASTATECC pThisCC, uint32_t idDXContext);
     534int vmsvga3dLogicOpsAlphaBlend(PVGASTATECC pThisCC, uint32_t idDXContext);
     535int vmsvga3dLogicOpsClearTypeBlend(PVGASTATECC pThisCC, uint32_t idDXContext);
     536int vmsvga3dDefineGBSurface_v4(PVGASTATECC pThisCC, uint32_t idDXContext);
     537int vmsvga3dDXSetCSUAViews(PVGASTATECC pThisCC, uint32_t idDXContext);
     538int vmsvga3dDXSetMinLOD(PVGASTATECC pThisCC, uint32_t idDXContext);
     539int vmsvga3dDXDefineDepthStencilView_v2(PVGASTATECC pThisCC, uint32_t idDXContext);
     540int vmsvga3dDXDefineStreamOutputWithMob(PVGASTATECC pThisCC, uint32_t idDXContext);
     541int vmsvga3dDXSetShaderIface(PVGASTATECC pThisCC, uint32_t idDXContext);
     542int vmsvga3dDXBindStreamOutput(PVGASTATECC pThisCC, uint32_t idDXContext);
     543int vmsvga3dSurfaceStretchBltNonMSToMS(PVGASTATECC pThisCC, uint32_t idDXContext);
     544int vmsvga3dDXBindShaderIface(PVGASTATECC pThisCC, uint32_t idDXContext);
     545#endif /* VMSVGA3D_DX */
     546
     547
    413548#endif /* !VBOX_INCLUDED_SRC_Graphics_DevVGA_SVGA3d_h */
    414549
  • trunk/src/VBox/Devices/Makefile.kmk

    r88626 r88787  
    325325        Graphics/DevVGA-SVGA3d-shared.cpp \
    326326        Graphics/DevVGA-SVGA3d-savedstate.cpp
     327  ifdef VBOX_WITH_VMSVGA3D_DX
     328   VBoxDD_DEFS          += VMSVGA3D_DX
     329   VBoxDD_SOURCES       += \
     330       Graphics/DevVGA-SVGA3d-dx.cpp \
     331       Graphics/DevVGA-SVGA3d-dx-shader.cpp
     332  endif
    327333  if  "$(KBUILD_TARGET)" == "win" && !defined(VBOX_WITH_VMSVGA3D_USE_OPENGL)
    328334   ifdef VBOX_WITH_VMSVGA3D_DX
    329     VBoxDD_DEFS          += VMSVGA3D_DX
     335    VBoxDD_DEFS          += VMSVGA3D_D3D11
    330336    VBoxDD_SOURCES       += \
    331337        Graphics/DevVGA-SVGA3d-win-dx.cpp
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