VirtualBox

Changeset 76716 in vbox for trunk/src/VBox/Additions


Ignore:
Timestamp:
Jan 8, 2019 11:36:02 PM (6 years ago)
Author:
vboxsync
Message:

os2/VBoxSF,Vbgl: Promoted the fast host request wrappers to generic status. bugref:9172

Location:
trunk/src/VBox/Additions/os2/VBoxSF
Files:
4 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/Additions/os2/VBoxSF/VBoxSF.cpp

    r76715 r76716  
    286286    /* Note! We won't get there while the folder is on the list. */
    287287    LogRel(("vboxSfOs2ReleaseFolder: Destroying %p [%s]\n", pFolder, pFolder->szName));
    288     vboxSfOs2HostReqUnmapFolderSimple(pFolder->idHostRoot);
     288    VbglR0SfHostReqUnmapFolderSimple(pFolder->idHostRoot);
    289289    RT_ZERO(pFolder);
    290290    RTMemFree(pFolder);
     
    395395        if (pReq)
    396396        {
    397             rc = vboxSfOs2HostReqMapFolderWithBuf(pReq, pName, RTPATH_DELIMITER, false /*fCaseSensitive*/);
     397            rc = VbglR0SfHostReqMapFolderWithBuf(pReq, pName, RTPATH_DELIMITER, false /*fCaseSensitive*/);
    398398            if (RT_SUCCESS(rc))
    399399            {
     
    408408            }
    409409            else
    410                 LogRel(("vboxSfOs2MapFolder: vboxSfOs2HostReqMapFolderWithBuf(,%s,) -> %Rrc\n", pNew->szName, rc));
     410                LogRel(("vboxSfOs2MapFolder: VbglR0SfHostReqMapFolderWithBuf(,%s,) -> %Rrc\n", pNew->szName, rc));
    411411            VbglR0PhysHeapFree(pReq);
    412412        }
     
    13641364        pu->Open.Req.StrPath.String.utf16[2] = '\0';
    13651365
    1366         int vrc = vboxSfOs2HostReqCreate(pFolder->idHostRoot, &pu->Open.Req);
    1367         LogFlow(("FS32_FSINFO: vboxSfOs2HostReqCreate -> %Rrc Result=%d Handle=%#RX64\n",
     1366        int vrc = VbglR0SfHostReqCreate(pFolder->idHostRoot, &pu->Open.Req);
     1367        LogFlow(("FS32_FSINFO: VbglR0SfHostReqCreate -> %Rrc Result=%d Handle=%#RX64\n",
    13681368                 vrc, pu->Open.Req.CreateParms.Result, pu->Open.Req.CreateParms.Handle));
    13691369        if (   RT_SUCCESS(vrc)
     
    13731373
    13741374            RT_ZERO(pu->Info.Req);
    1375             vrc = vboxSfOs2HostReqQueryVolInfo(pFolder->idHostRoot, &pu->Info.Req, hHandle);
     1375            vrc = VbglR0SfHostReqQueryVolInfo(pFolder->idHostRoot, &pu->Info.Req, hHandle);
    13761376            if (RT_SUCCESS(vrc))
    13771377            {
     
    14001400            else
    14011401            {
    1402                 LogRel(("FS32_FSINFO: vboxSfOs2HostReqQueryVolInfo failed: %Rrc\n", vrc));
     1402                LogRel(("FS32_FSINFO: VbglR0SfHostReqQueryVolInfo failed: %Rrc\n", vrc));
    14031403                rc = ERROR_GEN_FAILURE;
    14041404            }
    14051405
    1406             vrc = vboxSfOs2HostReqClose(pFolder->idHostRoot, &pu->Close, hHandle);
     1406            vrc = VbglR0SfHostReqClose(pFolder->idHostRoot, &pu->Close, hHandle);
    14071407            AssertRC(vrc);
    14081408        }
     
    14801480            pReq->CreateParms.CreateFlags = SHFL_CF_LOOKUP;
    14811481
    1482             int vrc = vboxSfOs2HostReqCreate(pFolder->idHostRoot, pReq);
    1483             LogFlow(("FS32_CHDIR: vboxSfOs2HostReqCreate -> %Rrc Result=%d fMode=%#x\n",
     1482            int vrc = VbglR0SfHostReqCreate(pFolder->idHostRoot, pReq);
     1483            LogFlow(("FS32_CHDIR: VbglR0SfHostReqCreate -> %Rrc Result=%d fMode=%#x\n",
    14841484                     vrc, pReq->CreateParms.Result, pReq->CreateParms.Info.Attr.fMode));
    14851485            if (RT_SUCCESS(vrc))
     
    15541554                                          | SHFL_CF_ACCESS_READ | SHFL_CF_ACCESS_DENYNONE;
    15551555
    1556             int vrc = vboxSfOs2HostReqCreate(pFolder->idHostRoot, pReq);
    1557             LogFlow(("FS32_MKDIR: vboxSfOs2HostReqCreate -> %Rrc Result=%d fMode=%#x\n",
     1556            int vrc = VbglR0SfHostReqCreate(pFolder->idHostRoot, pReq);
     1557            LogFlow(("FS32_MKDIR: VbglR0SfHostReqCreate -> %Rrc Result=%d fMode=%#x\n",
    15581558                     vrc, pReq->CreateParms.Result, pReq->CreateParms.Info.Attr.fMode));
    15591559            if (RT_SUCCESS(vrc))
     
    15651565                        {
    15661566                            AssertCompile(RTASSERT_OFFSET_OF(VBOXSFCREATEREQ, CreateParms.Handle) > sizeof(VBOXSFCLOSEREQ)); /* no aliasing issues */
    1567                             vrc = vboxSfOs2HostReqClose(pFolder->idHostRoot, (VBOXSFCLOSEREQ *)pReq, pReq->CreateParms.Handle);
     1567                            vrc = VbglR0SfHostReqClose(pFolder->idHostRoot, (VBOXSFCLOSEREQ *)pReq, pReq->CreateParms.Handle);
    15681568                            AssertRC(vrc);
    15691569                        }
     
    16201620    if (rc == NO_ERROR)
    16211621    {
    1622         int vrc = vboxSfOs2HostReqRemove(pFolder->idHostRoot, pReq, SHFL_REMOVE_DIR);
    1623         LogFlow(("FS32_RMDIR: vboxSfOs2HostReqRemove -> %Rrc\n", rc));
     1622        int vrc = VbglR0SfHostReqRemove(pFolder->idHostRoot, pReq, SHFL_REMOVE_DIR);
     1623        LogFlow(("FS32_RMDIR: VbglR0SfHostReqRemove -> %Rrc\n", rc));
    16241624        if (RT_SUCCESS(vrc))
    16251625            rc = NO_ERROR;
     
    16781678                 * Note! Requires 6.0.0beta2+ or 5.2.24+ host for renaming files.
    16791679                 */
    1680                 int vrc = vboxSfOs2HostReqRenameWithSrcBuf(pSrcFolder->idHostRoot, pReq, pSrcFolderPath,
    1681                                                            SHFL_RENAME_FILE | SHFL_RENAME_DIR);
     1680                int vrc = VbglR0SfHostReqRenameWithSrcBuf(pSrcFolder->idHostRoot, pReq, pSrcFolderPath,
     1681                                                          SHFL_RENAME_FILE | SHFL_RENAME_DIR);
    16821682                if (RT_SUCCESS(vrc))
    16831683                    rc = NO_ERROR;
    16841684                else
    16851685                {
    1686                     Log(("FS32_MOVE: vboxSfOs2HostReqRenameWithSrcBuf failed: %Rrc\n", rc));
     1686                    Log(("FS32_MOVE: VbglR0SfHostReqRenameWithSrcBuf failed: %Rrc\n", rc));
    16871687                    rc = vboxSfOs2ConvertStatusToOs2(vrc, ERROR_ACCESS_DENIED);
    16881688                }
     
    17181718    if (rc == NO_ERROR)
    17191719    {
    1720         int vrc = vboxSfOs2HostReqRemove(pFolder->idHostRoot, pReq, SHFL_REMOVE_FILE);
    1721         LogFlow(("FS32_DELETE: vboxSfOs2HostReqRemove -> %Rrc\n", rc));
     1720        int vrc = VbglR0SfHostReqRemove(pFolder->idHostRoot, pReq, SHFL_REMOVE_FILE);
     1721        LogFlow(("FS32_DELETE: VbglR0SfHostReqRemove -> %Rrc\n", rc));
    17221722        if (RT_SUCCESS(vrc))
    17231723            rc = NO_ERROR;
     
    17981798    if (pReq)
    17991799    {
    1800         int vrc = vboxSfOs2HostReqSetObjInfoWithBuf(pFolder->idHostRoot, pReq, hHostFile, pObjInfoBuf, offObjInfoInAlloc);
    1801         LogFlow(("vboxSfOs2SetFileInfo: vboxSfOs2HostReqSetObjInfoWithBuf -> %Rrc\n", vrc));
     1800        int vrc = VbglR0SfHostReqSetObjInfoWithBuf(pFolder->idHostRoot, pReq, hHostFile, pObjInfoBuf, offObjInfoInAlloc);
     1801        LogFlow(("vboxSfOs2SetFileInfo: VbglR0SfHostReqSetObjInfoWithBuf -> %Rrc\n", vrc));
    18021802
    18031803        VbglR0PhysHeapFree(pReq);
     
    18291829                                  | SHFL_CF_ACCESS_ATTR_READWRITE | SHFL_CF_ACCESS_DENYNONE | SHFL_CF_ACCESS_NONE;
    18301830
    1831     int vrc = vboxSfOs2HostReqCreate(pFolder->idHostRoot, pReq);
    1832     LogFlow(("vboxSfOs2SetPathInfoWorker: vboxSfOs2HostReqCreate -> %Rrc Result=%d Handle=%#RX64 fMode=%#x\n",
     1831    int vrc = VbglR0SfHostReqCreate(pFolder->idHostRoot, pReq);
     1832    LogFlow(("vboxSfOs2SetPathInfoWorker: VbglR0SfHostReqCreate -> %Rrc Result=%d Handle=%#RX64 fMode=%#x\n",
    18331833             vrc, pReq->CreateParms.Result, pReq->CreateParms.Handle, pReq->CreateParms.Info.Attr.fMode));
    18341834    if (   vrc == VERR_IS_A_DIRECTORY
     
    18401840        pReq->CreateParms.CreateFlags = SHFL_CF_DIRECTORY | SHFL_CF_ACT_OPEN_IF_EXISTS | SHFL_CF_ACT_FAIL_IF_NEW
    18411841                                      | SHFL_CF_ACCESS_ATTR_READWRITE | SHFL_CF_ACCESS_DENYNONE | SHFL_CF_ACCESS_NONE;
    1842         vrc = vboxSfOs2HostReqCreate(pFolder->idHostRoot, pReq);
    1843         LogFlow(("vboxSfOs2SetPathInfoWorker: vboxSfOs2HostReqCreate#2 -> %Rrc Result=%d Handle=%#RX64 fMode=%#x\n",
     1842        vrc = VbglR0SfHostReqCreate(pFolder->idHostRoot, pReq);
     1843        LogFlow(("vboxSfOs2SetPathInfoWorker: VbglR0SfHostReqCreate#2 -> %Rrc Result=%d Handle=%#RX64 fMode=%#x\n",
    18441844                 vrc, pReq->CreateParms.Result, pReq->CreateParms.Handle, pReq->CreateParms.Info.Attr.fMode));
    18451845    }
     
    18581858
    18591859                    AssertCompile(RTASSERT_OFFSET_OF(VBOXSFCREATEREQ, CreateParms.Handle) > sizeof(VBOXSFCLOSEREQ)); /* no aliasing issues */
    1860                     vrc = vboxSfOs2HostReqClose(pFolder->idHostRoot, (VBOXSFCLOSEREQ *)pReq, pReq->CreateParms.Handle);
     1860                    vrc = VbglR0SfHostReqClose(pFolder->idHostRoot, (VBOXSFCLOSEREQ *)pReq, pReq->CreateParms.Handle);
    18611861                    AssertRC(vrc);
    18621862                }
     
    19091909                pReq->CreateParms.CreateFlags = SHFL_CF_LOOKUP;
    19101910
    1911                 int vrc = vboxSfOs2HostReqCreate(pFolder->idHostRoot, pReq);
    1912                 LogFlow(("FS32_FILEATTRIBUTE: vboxSfOs2HostReqCreate -> %Rrc Result=%d fMode=%#x\n",
     1911                int vrc = VbglR0SfHostReqCreate(pFolder->idHostRoot, pReq);
     1912                LogFlow(("FS32_FILEATTRIBUTE: VbglR0SfHostReqCreate -> %Rrc Result=%d fMode=%#x\n",
    19131913                         vrc, pReq->CreateParms.Result, pReq->CreateParms.Info.Attr.fMode));
    19141914                if (RT_SUCCESS(vrc))
     
    22142214    pReq->CreateParms.CreateFlags = SHFL_CF_LOOKUP;
    22152215
    2216     int vrc = vboxSfOs2HostReqCreate(pFolder->idHostRoot, pReq);
    2217     LogFlow(("FS32_PATHINFO: vboxSfOs2HostReqCreate -> %Rrc Result=%d fMode=%#x\n",
     2216    int vrc = VbglR0SfHostReqCreate(pFolder->idHostRoot, pReq);
     2217    LogFlow(("FS32_PATHINFO: VbglR0SfHostReqCreate -> %Rrc Result=%d fMode=%#x\n",
    22182218             vrc, pReq->CreateParms.Result, pReq->CreateParms.Info.Attr.fMode));
    22192219    if (RT_SUCCESS(vrc))
  • trunk/src/VBox/Additions/os2/VBoxSF/VBoxSFFile.cpp

    r76715 r76716  
    233233     * Try open the file.
    234234     */
    235     int vrc = vboxSfOs2HostReqCreate(pFolder->idHostRoot, pReq);
    236     LogFlow(("FS32_OPENCREATE: vboxSfOs2HostReqCreate -> %Rrc Result=%d fMode=%#x\n",
     235    int vrc = VbglR0SfHostReqCreate(pFolder->idHostRoot, pReq);
     236    LogFlow(("FS32_OPENCREATE: VbglR0SfHostReqCreate -> %Rrc Result=%d fMode=%#x\n",
    237237             vrc, pReq->CreateParms.Result, pReq->CreateParms.Info.Attr.fMode));
    238238    if (RT_SUCCESS(vrc))
     
    282282                    LogRel(("FS32_OPENCREATE: cbObject=%#RX64 no OPEN_FLAGS_LARGEFILE (%s)\n", pReq->CreateParms.Info.cbObject, pszName));
    283283                    AssertCompile(RTASSERT_OFFSET_OF(VBOXSFCREATEREQ, CreateParms.Handle) > sizeof(VBOXSFCLOSEREQ)); /* no aliasing issues */
    284                     vboxSfOs2HostReqClose(pFolder->idHostRoot, (VBOXSFCLOSEREQ *)pReq, pReq->CreateParms.Handle);
     284                    VbglR0SfHostReqClose(pFolder->idHostRoot, (VBOXSFCLOSEREQ *)pReq, pReq->CreateParms.Handle);
    285285                    rc = ERROR_ACCESS_DENIED;
    286286                }
     
    335335    RT_NOREF(fIoFlags);
    336336
    337     int vrc = vboxSfOs2HostReqCloseSimple(pFolder->idHostRoot, pSfFsd->hHostFile);
     337    int vrc = VbglR0SfHostReqCloseSimple(pFolder->idHostRoot, pSfFsd->hHostFile);
    338338    AssertRC(vrc);
    339339
     
    374374        || (pSfFsi->sfi_mode & SFMODE_OPEN_ACCESS) == SFMODE_OPEN_READWRITE)
    375375    {
    376         int vrc = vboxSfOs2HostReqFlushSimple(pFolder->idHostRoot, pSfFsd->hHostFile);
     376        int vrc = VbglR0SfHostReqFlushSimple(pFolder->idHostRoot, pSfFsd->hHostFile);
    377377        if (RT_FAILURE(vrc))
    378378        {
    379             LogRel(("FS32_COMMIT: vboxSfOs2HostReqFlushSimple failed: %Rrc\n", vrc));
     379            LogRel(("FS32_COMMIT: VbglR0SfHostReqFlushSimple failed: %Rrc\n", vrc));
    380380            return ERROR_FLUSHBUF_FAILED;
    381381        }
     
    435435                return ERROR_NOT_ENOUGH_MEMORY;
    436436
    437             int vrc = vboxSfOs2HostReqQueryObjInfo(pFolder->idHostRoot, pReq, pSfFsd->hHostFile);
     437            int vrc = VbglR0SfHostReqQueryObjInfo(pFolder->idHostRoot, pReq, pSfFsd->hHostFile);
    438438            if (RT_SUCCESS(vrc))
    439439            {
     
    858858    if (pReq)
    859859    {
    860         int vrc = vboxSfOs2HostReqQueryObjInfo(pFolder->idHostRoot, pReq, pSfFsd->hHostFile);
     860        int vrc = VbglR0SfHostReqQueryObjInfo(pFolder->idHostRoot, pReq, pSfFsd->hHostFile);
    861861        if (RT_SUCCESS(vrc))
    862862        {
     
    876876        else
    877877        {
    878             Log(("vboxSfOs2QueryFileInfo: vboxSfOs2HostReqQueryObjInfo failed: %Rrc\n", vrc));
     878            Log(("vboxSfOs2QueryFileInfo: VbglR0SfHostReqQueryObjInfo failed: %Rrc\n", vrc));
    879879            rc = vboxSfOs2ConvertStatusToOs2(vrc, ERROR_GEN_FAILURE);
    880880        }
     
    10471047         * Call the host.
    10481048         */
    1049         int vrc = vboxSfOs2HostReqSetFileSizeSimple(pFolder->idHostRoot, pSfFsd->hHostFile, cbFile);
     1049        int vrc = VbglR0SfHostReqSetFileSizeSimple(pFolder->idHostRoot, pSfFsd->hHostFile, cbFile);
    10501050        if (RT_SUCCESS(vrc))
    10511051        {
     
    11661166        {
    11671167            APIRET rc;
    1168             int vrc = vboxSfOs2HostReqReadEmbedded(pFolder->idHostRoot, pReq, pSfFsd->hHostFile, offRead, cbToRead);
     1168            int vrc = VbglR0SfHostReqReadEmbedded(pFolder->idHostRoot, pReq, pSfFsd->hHostFile, offRead, cbToRead);
    11691169            if (RT_SUCCESS(vrc))
    11701170            {
     
    11801180            else
    11811181            {
    1182                 Log(("FS32_READ: vboxSfOs2HostReqReadEmbedded(off=%#RU64,cb=%#x) -> %Rrc [embedded]\n", offRead, cbToRead, vrc));
     1182                Log(("FS32_READ: VbglR0SfHostReqReadEmbedded(off=%#RU64,cb=%#x) -> %Rrc [embedded]\n", offRead, cbToRead, vrc));
    11831183                rc = ERROR_BAD_NET_RESP;
    11841184            }
     
    12231223        {
    12241224            APIRET rc;
    1225             int vrc = vboxSfOs2HostReqReadContig(pFolder->idHostRoot, pReq, pSfFsd->hHostFile,
    1226                                                  offRead, cbToRead, pvBuf, GCPhys);
     1225            int vrc = VbglR0SfHostReqReadContig(pFolder->idHostRoot, pReq, pSfFsd->hHostFile, offRead, cbToRead, pvBuf, GCPhys);
    12271226            if (RT_SUCCESS(vrc))
    12281227            {
     
    12381237            else
    12391238            {
    1240                 Log(("FS32_READ: vboxSfOs2HostReqReadEmbedded(off=%#RU64,cb=%#x) -> %Rrc [bounced]\n", offRead, cbToRead, vrc));
     1239                Log(("FS32_READ: VbglR0SfHostReqReadEmbedded(off=%#RU64,cb=%#x) -> %Rrc [bounced]\n", offRead, cbToRead, vrc));
    12411240                rc = ERROR_BAD_NET_RESP;
    12421241            }
     
    12661265
    12671266        APIRET rc;
    1268         int vrc = vboxSfOs2HostReqReadPgLst(pFolder->idHostRoot, pReq, pSfFsd->hHostFile, offRead, cbToRead, cPages);
     1267        int vrc = VbglR0SfHostReqReadPgLst(pFolder->idHostRoot, pReq, pSfFsd->hHostFile, offRead, cbToRead, cPages);
    12691268        if (RT_SUCCESS(vrc))
    12701269        {
     
    12761275        else
    12771276        {
    1278             Log(("FS32_READ: vboxSfOs2HostReqReadEmbedded(off=%#RU64,cb=%#x) -> %Rrc [locked]\n", offRead, cbToRead, vrc));
     1277            Log(("FS32_READ: VbglR0SfHostReqReadEmbedded(off=%#RU64,cb=%#x) -> %Rrc [locked]\n", offRead, cbToRead, vrc));
    12791278            rc = ERROR_BAD_NET_RESP;
    12801279        }
     
    13371336            if (rc == NO_ERROR)
    13381337            {
    1339                 int vrc = vboxSfOs2HostReqWriteEmbedded(pFolder->idHostRoot, pReq, pSfFsd->hHostFile, offWrite, cbToWrite);
     1338                int vrc = VbglR0SfHostReqWriteEmbedded(pFolder->idHostRoot, pReq, pSfFsd->hHostFile, offWrite, cbToWrite);
    13401339                if (RT_SUCCESS(vrc))
    13411340                {
     
    13471346                else
    13481347                {
    1349                     Log(("FS32_WRITE: vboxSfOs2HostReqWriteEmbedded(off=%#RU64,cb=%#x) -> %Rrc [embedded]\n", offWrite, cbToWrite, vrc));
     1348                    Log(("FS32_WRITE: VbglR0SfHostReqWriteEmbedded(off=%#RU64,cb=%#x) -> %Rrc [embedded]\n", offWrite, cbToWrite, vrc));
    13501349                    rc = ERROR_BAD_NET_RESP;
    13511350                }
     
    13941393            {
    13951394                APIRET rc;
    1396                 int vrc = vboxSfOs2HostReqWriteContig(pFolder->idHostRoot, pReq, pSfFsd->hHostFile,
    1397                                                       offWrite, cbToWrite, pvBuf, GCPhys);
     1395                int vrc = VbglR0SfHostReqWriteContig(pFolder->idHostRoot, pReq, pSfFsd->hHostFile,
     1396                                                     offWrite, cbToWrite, pvBuf, GCPhys);
    13981397                if (RT_SUCCESS(vrc))
    13991398                {
     
    14051404                else
    14061405                {
    1407                     Log(("FS32_WRITE: vboxSfOs2HostReqWriteEmbedded(off=%#RU64,cb=%#x) -> %Rrc [bounced]\n", offWrite, cbToWrite, vrc));
     1406                    Log(("FS32_WRITE: VbglR0SfHostReqWriteEmbedded(off=%#RU64,cb=%#x) -> %Rrc [bounced]\n", offWrite, cbToWrite, vrc));
    14081407                    rc = ERROR_BAD_NET_RESP;
    14091408                }
     
    14331432
    14341433        APIRET rc;
    1435         int vrc = vboxSfOs2HostReqWritePgLst(pFolder->idHostRoot, pReq, pSfFsd->hHostFile, offWrite, cbToWrite, cPages);
     1434        int vrc = VbglR0SfHostReqWritePgLst(pFolder->idHostRoot, pReq, pSfFsd->hHostFile, offWrite, cbToWrite, cPages);
    14361435        if (RT_SUCCESS(vrc))
    14371436        {
     
    14431442        else
    14441443        {
    1445             Log(("FS32_WRITE: vboxSfOs2HostReqWriteEmbedded(off=%#RU64,cb=%#x) -> %Rrc [locked]\n", offWrite, cbToWrite, vrc));
     1444            Log(("FS32_WRITE: VbglR0SfHostReqWriteEmbedded(off=%#RU64,cb=%#x) -> %Rrc [locked]\n", offWrite, cbToWrite, vrc));
    14461445            rc = ERROR_BAD_NET_RESP;
    14471446        }
  • trunk/src/VBox/Additions/os2/VBoxSF/VBoxSFFind.cpp

    r76715 r76716  
    234234        {
    235235            pDataBuf->pEntry = pEntry = pDataBuf->pBuf;
    236             int vrc = vboxSfOs2HostReqListDir(pFolder->idHostRoot, &pDataBuf->Req, pFsFsd->hHostDir, pDataBuf->pFilter,
    237                                               /*cMaxMatches == 1 ? SHFL_LIST_RETURN_ONE :*/ 0, pDataBuf->pBuf, pDataBuf->cbBuf);
     236            int vrc = VbglR0SfHostReqListDir(pFolder->idHostRoot, &pDataBuf->Req, pFsFsd->hHostDir, pDataBuf->pFilter,
     237                                             /*cMaxMatches == 1 ? SHFL_LIST_RETURN_ONE :*/ 0, pDataBuf->pBuf, pDataBuf->cbBuf);
    238238            if (RT_SUCCESS(vrc))
    239239            {
     
    243243                AssertReturn(pDataBuf->cbValid >= RT_UOFFSETOF(SHFLDIRINFO, name.String), ERROR_SYS_INTERNAL);
    244244                AssertReturn(pDataBuf->cbValid >= RT_UOFFSETOF(SHFLDIRINFO, name.String) + pEntry->name.u16Size, ERROR_SYS_INTERNAL);
    245                 Log4(("vboxSfOs2ReadDirEntries: vboxSfOs2HostReqListDir returned %#x matches in %#x bytes\n", pDataBuf->cEntriesLeft, pDataBuf->cbValid));
     245                Log4(("vboxSfOs2ReadDirEntries: VbglR0SfHostReqListDir returned %#x matches in %#x bytes\n", pDataBuf->cEntriesLeft, pDataBuf->cbValid));
    246246            }
    247247            else
    248248            {
    249249                if (vrc == VERR_NO_MORE_FILES)
    250                     Log4(("vboxSfOs2ReadDirEntries: vboxSfOs2HostReqListDir returned VERR_NO_MORE_FILES (%d,%d)\n",
     250                    Log4(("vboxSfOs2ReadDirEntries: VbglR0SfHostReqListDir returned VERR_NO_MORE_FILES (%d,%d)\n",
    251251                          pDataBuf->Req.Parms.c32Entries.u.value32, pDataBuf->Req.Parms.cb32Buffer.u.value32));
    252252                else
    253                     Log(("vboxSfOs2ReadDirEntries: vboxSfOs2HostReqListDir failed %Rrc (%d,%d)\n", vrc,
     253                    Log(("vboxSfOs2ReadDirEntries: VbglR0SfHostReqListDir failed %Rrc (%d,%d)\n", vrc,
    254254                         pDataBuf->Req.Parms.c32Entries.u.value32, pDataBuf->Req.Parms.cb32Buffer.u.value32));
    255255                pDataBuf->pEntry       = NULL;
     
    601601                                              | SHFL_CF_ACCESS_READ | SHFL_CF_ACCESS_ATTR_READ | SHFL_CF_ACCESS_DENYNONE;
    602602
    603                 int vrc = vboxSfOs2HostReqCreate(pFolder->idHostRoot, pReq);
    604                 LogFlow(("FS32_FINDFIRST: vboxSfOs2HostReqCreate(%ls) -> %Rrc Result=%d fMode=%#x hHandle=%#RX64\n",
     603                int vrc = VbglR0SfHostReqCreate(pFolder->idHostRoot, pReq);
     604                LogFlow(("FS32_FINDFIRST: VbglR0SfHostReqCreate(%ls) -> %Rrc Result=%d fMode=%#x hHandle=%#RX64\n",
    605605                         pStrFolderPath->String.utf16, vrc, pReq->CreateParms.Result, pReq->CreateParms.Info.Attr.fMode,
    606606                         pReq->CreateParms.Handle));
     
    649649                                {
    650650                                    AssertCompile(sizeof(VBOXSFCLOSEREQ) < sizeof(*pReq));
    651                                     vrc = vboxSfOs2HostReqClose(pFolder->idHostRoot, (VBOXSFCLOSEREQ *)pReq, pFsFsd->hHostDir);
     651                                    vrc = VbglR0SfHostReqClose(pFolder->idHostRoot, (VBOXSFCLOSEREQ *)pReq, pFsFsd->hHostDir);
    652652                                    AssertRC(vrc);
    653653                                    pFsFsd->u32Magic = ~VBOXSFFS_MAGIC;
     
    659659                            else
    660660                            {
    661                                 LogFlow(("FS32_FINDFIRST: vboxSfOs2HostReqCreate returns NIL handle for '%ls'\n",
     661                                LogFlow(("FS32_FINDFIRST: VbglR0SfHostReqCreate returns NIL handle for '%ls'\n",
    662662                                         pStrFolderPath->String.utf16));
    663663                                rc = ERROR_PATH_NOT_FOUND;
     
    826826    if (pFsFsd->hHostDir != SHFL_HANDLE_NIL)
    827827    {
    828         int vrc = vboxSfOs2HostReqCloseSimple(pFolder->idHostRoot, pFsFsd->hHostDir);
     828        int vrc = VbglR0SfHostReqCloseSimple(pFolder->idHostRoot, pFsFsd->hHostDir);
    829829        AssertRC(vrc);
    830830    }
  • trunk/src/VBox/Additions/os2/VBoxSF/VBoxSFInternal.h

    r76715 r76716  
    4949#include <iprt/assert.h>
    5050#include <iprt/list.h>
    51 #include <VBox/VBoxGuestLibSharedFolders.h>
    5251#include <VBox/VBoxGuest.h>
     52#include <VBox/VBoxGuestLibSharedFoldersInline.h>
    5353
    5454
     
    156156#define VBOXSFSYFI_MAGIC         UINT32_C(0x19690520)
    157157
    158 
    159 /** Request structure for vboxSfOs2HostReqListDir. */
    160 typedef struct VBOXSFLISTDIRREQ
    161 {
    162     VBGLIOCIDCHGCMFASTCALL  Hdr;
    163     VMMDevHGCMCall          Call;
    164     VBoxSFParmList          Parms;
    165     HGCMPageListInfo        StrPgLst;
    166     HGCMPageListInfo        BufPgLst;
    167 } VBOXSFLISTDIRREQ;
    168158
    169159/**
     
    261251
    262252
    263 /** @name Host request helpers
    264  *
    265  * @todo generalize these and put back into VbglR0Sf.
    266  *
    267  * @{  */
    268 
    269 #include <iprt/err.h>
    270 
    271 /** Request structure for vboxSfOs2HostReqMapFolderWithBuf.  */
    272 typedef struct VBOXSFMAPFOLDERWITHBUFREQ
    273 {
    274     VBGLIOCIDCHGCMFASTCALL  Hdr;
    275     VMMDevHGCMCall          Call;
    276     VBoxSFParmMapFolder     Parms;
    277     HGCMPageListInfo        PgLst;
    278 } VBOXSFMAPFOLDERWITHBUFREQ;
    279 
    280 /**
    281  * SHFL_FN_MAP_FOLDER request.
    282  */
    283 DECLINLINE(int) vboxSfOs2HostReqMapFolderWithBuf(VBOXSFMAPFOLDERWITHBUFREQ *pReq, PSHFLSTRING pStrName,
    284                                                  RTUTF16 wcDelimiter, bool fCaseSensitive)
    285 {
    286     VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    287                                 SHFL_FN_MAP_FOLDER, SHFL_CPARMS_MAP_FOLDER, sizeof(*pReq));
    288 
    289     pReq->Parms.id32Root.type                   = VMMDevHGCMParmType_32bit;
    290     pReq->Parms.id32Root.u.value32              = SHFL_ROOT_NIL;
    291 
    292     pReq->Parms.uc32Delimiter.type              = VMMDevHGCMParmType_32bit;
    293     pReq->Parms.uc32Delimiter.u.value32         = wcDelimiter;
    294 
    295     pReq->Parms.fCaseSensitive.type             = VMMDevHGCMParmType_32bit;
    296     pReq->Parms.fCaseSensitive.u.value32        = fCaseSensitive;
    297 
    298     if (g_fHostFeatures & VMMDEV_HVF_HGCM_CONTIGUOUS_PAGE_LIST)
    299     {
    300         pReq->Parms.pStrName.type               = VMMDevHGCMParmType_PageList;
    301         pReq->Parms.pStrName.u.PageList.size    = SHFLSTRING_HEADER_SIZE + pStrName->u16Size;
    302         pReq->Parms.pStrName.u.PageList.offset  = RT_UOFFSETOF(VBOXSFMAPFOLDERWITHBUFREQ, PgLst) - sizeof(VBGLIOCIDCHGCMFASTCALL);
    303         pReq->PgLst.flags                       = VBOX_HGCM_F_PARM_DIRECTION_BOTH;
    304         pReq->PgLst.aPages[0]                   = VbglR0PhysHeapGetPhysAddr(pStrName);
    305         pReq->PgLst.offFirstPage                = (uint16_t)(pReq->PgLst.aPages[0] & PAGE_OFFSET_MASK);
    306         pReq->PgLst.aPages[0]                  &= ~(RTGCPHYS)PAGE_OFFSET_MASK;
    307         pReq->PgLst.cPages                      = 1;
    308     }
    309     else
    310     {
    311         pReq->Parms.pStrName.type               = VMMDevHGCMParmType_LinAddr_In;
    312         pReq->Parms.pStrName.u.LinAddr.cb       = SHFLSTRING_HEADER_SIZE + pStrName->u16Size;
    313         pReq->Parms.pStrName.u.LinAddr.uAddr    = (uintptr_t)pStrName;
    314     }
    315 
    316     int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr, sizeof(*pReq));
    317     if (RT_SUCCESS(vrc))
    318         vrc = pReq->Call.header.result;
    319     return vrc;
    320 }
    321 
    322 
    323 
    324 /** Request structure used by vboxSfOs2HostReqUnmapFolder.  */
    325 typedef struct VBOXSFUNMAPFOLDERREQ
    326 {
    327     VBGLIOCIDCHGCMFASTCALL  Hdr;
    328     VMMDevHGCMCall          Call;
    329     VBoxSFParmUnmapFolder   Parms;
    330 } VBOXSFUNMAPFOLDERREQ;
    331 
    332 
    333 /**
    334  * SHFL_FN_UNMAP_FOLDER request.
    335  */
    336 DECLINLINE(int) vboxSfOs2HostReqUnmapFolderSimple(uint32_t idRoot)
    337 {
    338     VBOXSFUNMAPFOLDERREQ *pReq = (VBOXSFUNMAPFOLDERREQ *)VbglR0PhysHeapAlloc(sizeof(*pReq));
    339     if (pReq)
    340     {
    341         pReq->Parms.id32Root.type      = VMMDevHGCMParmType_32bit;
    342         pReq->Parms.id32Root.u.value32 = idRoot;
    343 
    344         VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    345                                     SHFL_FN_UNMAP_FOLDER, SHFL_CPARMS_UNMAP_FOLDER, sizeof(*pReq));
    346 
    347         int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr, sizeof(*pReq));
    348         if (RT_SUCCESS(vrc))
    349             vrc = pReq->Call.header.result;
    350 
    351         VbglR0PhysHeapFree(pReq);
    352         return vrc;
    353     }
    354     return VERR_NO_MEMORY;
    355 }
    356 
    357 
    358 /** Request structure for vboxSfOs2HostReqCreate.  */
    359 typedef struct VBOXSFCREATEREQ
    360 {
    361     VBGLIOCIDCHGCMFASTCALL  Hdr;
    362     VMMDevHGCMCall          Call;
    363     VBoxSFParmCreate        Parms;
    364     SHFLCREATEPARMS         CreateParms;
    365     SHFLSTRING              StrPath;
    366 } VBOXSFCREATEREQ;
    367 
    368 /**
    369  * SHFL_FN_CREATE request.
    370  */
    371 DECLINLINE(int) vboxSfOs2HostReqCreate(SHFLROOT idRoot, VBOXSFCREATEREQ *pReq)
    372 {
    373     uint32_t const cbReq = g_fHostFeatures & VMMDEV_HVF_HGCM_EMBEDDED_BUFFERS
    374                          ? RT_UOFFSETOF(VBOXSFCREATEREQ, StrPath.String) + pReq->StrPath.u16Size
    375                          : RT_UOFFSETOF(VBOXSFCREATEREQ, CreateParms);
    376     VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    377                                 SHFL_FN_CREATE, SHFL_CPARMS_CREATE, cbReq);
    378 
    379     pReq->Parms.id32Root.type                       = VMMDevHGCMParmType_32bit;
    380     pReq->Parms.id32Root.u.value32                  = idRoot;
    381 
    382     if (g_fHostFeatures & VMMDEV_HVF_HGCM_EMBEDDED_BUFFERS)
    383     {
    384         pReq->Parms.pStrPath.type                   = VMMDevHGCMParmType_Embedded;
    385         pReq->Parms.pStrPath.u.Embedded.cbData      = SHFLSTRING_HEADER_SIZE + pReq->StrPath.u16Size;
    386         pReq->Parms.pStrPath.u.Embedded.offData     = RT_UOFFSETOF(VBOXSFCREATEREQ, StrPath) - sizeof(VBGLIOCIDCHGCMFASTCALL);
    387         pReq->Parms.pStrPath.u.Embedded.fFlags      = VBOX_HGCM_F_PARM_DIRECTION_TO_HOST;
    388 
    389         pReq->Parms.pCreateParms.type               = VMMDevHGCMParmType_Embedded;
    390         pReq->Parms.pCreateParms.u.Embedded.cbData  = sizeof(pReq->CreateParms);
    391         pReq->Parms.pCreateParms.u.Embedded.offData = RT_UOFFSETOF(VBOXSFCREATEREQ, CreateParms) - sizeof(VBGLIOCIDCHGCMFASTCALL);
    392         pReq->Parms.pCreateParms.u.Embedded.fFlags  = VBOX_HGCM_F_PARM_DIRECTION_BOTH;
    393     }
    394     else
    395     {
    396         pReq->Parms.pStrPath.type                   = VMMDevHGCMParmType_LinAddr_In;
    397         pReq->Parms.pStrPath.u.LinAddr.cb           = SHFLSTRING_HEADER_SIZE + pReq->StrPath.u16Size;
    398         pReq->Parms.pStrPath.u.LinAddr.uAddr        = (uintptr_t)&pReq->StrPath;
    399 
    400         pReq->Parms.pCreateParms.type               = VMMDevHGCMParmType_LinAddr;
    401         pReq->Parms.pCreateParms.u.LinAddr.cb       = sizeof(pReq->CreateParms);
    402         pReq->Parms.pCreateParms.u.LinAddr.uAddr    = (uintptr_t)&pReq->CreateParms;
    403     }
    404 
    405     int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr, cbReq);
    406     if (RT_SUCCESS(vrc))
    407         vrc = pReq->Call.header.result;
    408     return vrc;
    409 }
    410 
    411 
    412 /** Request structure for vboxSfOs2HostReqClose.  */
    413 typedef struct VBOXSFCLOSEREQ
    414 {
    415     VBGLIOCIDCHGCMFASTCALL  Hdr;
    416     VMMDevHGCMCall          Call;
    417     VBoxSFParmClose         Parms;
    418 } VBOXSFCLOSEREQ;
    419 
    420 /**
    421  * SHFL_FN_CLOSE request.
    422  */
    423 DECLINLINE(int) vboxSfOs2HostReqClose(SHFLROOT idRoot, VBOXSFCLOSEREQ *pReq, uint64_t hHostFile)
    424 {
    425     VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    426                                 SHFL_FN_CLOSE, SHFL_CPARMS_CLOSE, sizeof(*pReq));
    427 
    428     pReq->Parms.id32Root.type       = VMMDevHGCMParmType_32bit;
    429     pReq->Parms.id32Root.u.value32  = idRoot;
    430 
    431     pReq->Parms.u64Handle.type      = VMMDevHGCMParmType_64bit;
    432     pReq->Parms.u64Handle.u.value64 = hHostFile;
    433 
    434     int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr, sizeof(*pReq));
    435     if (RT_SUCCESS(vrc))
    436         vrc = pReq->Call.header.result;
    437     return vrc;
    438 }
    439 
    440 /**
    441  * SHFL_FN_CLOSE request, allocate request buffer.
    442  */
    443 DECLINLINE(int) vboxSfOs2HostReqCloseSimple(SHFLROOT idRoot, uint64_t hHostFile)
    444 {
    445     VBOXSFCLOSEREQ *pReq = (VBOXSFCLOSEREQ *)VbglR0PhysHeapAlloc(sizeof(*pReq));
    446     if (pReq)
    447     {
    448         int vrc = vboxSfOs2HostReqClose(idRoot, pReq, hHostFile);
    449         VbglR0PhysHeapFree(pReq);
    450         return vrc;
    451     }
    452     return VERR_NO_MEMORY;
    453 }
    454 
    455 
    456 /** Request structure for vboxSfOs2HostReqQueryVolInfo.  */
    457 typedef struct VBOXSFVOLINFOREQ
    458 {
    459     VBGLIOCIDCHGCMFASTCALL  Hdr;
    460     VMMDevHGCMCall          Call;
    461     VBoxSFParmInformation   Parms;
    462     SHFLVOLINFO             VolInfo;
    463 } VBOXSFVOLINFOREQ;
    464 
    465 /**
    466  * SHFL_FN_INFORMATION[SHFL_INFO_VOLUME | SHFL_INFO_GET] request.
    467  */
    468 DECLINLINE(int) vboxSfOs2HostReqQueryVolInfo(SHFLROOT idRoot, VBOXSFVOLINFOREQ *pReq, uint64_t hHostFile)
    469 {
    470     uint32_t const cbReq = g_fHostFeatures & VMMDEV_HVF_HGCM_EMBEDDED_BUFFERS
    471                          ? sizeof(*pReq) : RT_UOFFSETOF(VBOXSFVOLINFOREQ, VolInfo);
    472     VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    473                                 SHFL_FN_INFORMATION, SHFL_CPARMS_INFORMATION, cbReq);
    474 
    475     pReq->Parms.id32Root.type                   = VMMDevHGCMParmType_32bit;
    476     pReq->Parms.id32Root.u.value32              = idRoot;
    477 
    478     pReq->Parms.u64Handle.type                  = VMMDevHGCMParmType_64bit;
    479     pReq->Parms.u64Handle.u.value64             = hHostFile;
    480 
    481     pReq->Parms.f32Flags.type                   = VMMDevHGCMParmType_32bit;
    482     pReq->Parms.f32Flags.u.value32              = SHFL_INFO_VOLUME | SHFL_INFO_GET;
    483 
    484     pReq->Parms.cb32.type                       = VMMDevHGCMParmType_32bit;
    485     pReq->Parms.cb32.u.value32                  = sizeof(pReq->VolInfo);
    486 
    487     if (g_fHostFeatures & VMMDEV_HVF_HGCM_EMBEDDED_BUFFERS)
    488     {
    489         pReq->Parms.pInfo.type                  = VMMDevHGCMParmType_Embedded;
    490         pReq->Parms.pInfo.u.Embedded.cbData     = sizeof(pReq->VolInfo);
    491         pReq->Parms.pInfo.u.Embedded.offData    = RT_UOFFSETOF(VBOXSFVOLINFOREQ, VolInfo) - sizeof(VBGLIOCIDCHGCMFASTCALL);
    492         pReq->Parms.pInfo.u.Embedded.fFlags     = VBOX_HGCM_F_PARM_DIRECTION_FROM_HOST;
    493     }
    494     else
    495     {
    496         pReq->Parms.pInfo.type                  = VMMDevHGCMParmType_LinAddr_Out;
    497         pReq->Parms.pInfo.u.LinAddr.cb          = sizeof(pReq->VolInfo);
    498         pReq->Parms.pInfo.u.LinAddr.uAddr       = (uintptr_t)&pReq->VolInfo;
    499     }
    500 
    501     int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr, cbReq);
    502     if (RT_SUCCESS(vrc))
    503         vrc = pReq->Call.header.result;
    504     return vrc;
    505 }
    506 
    507 
    508 /** Request structure for vboxSfOs2HostReqSetObjInfo & vboxSfOs2HostReqQueryObjInfo. */
    509 typedef struct VBOXSFOBJINFOREQ
    510 {
    511     VBGLIOCIDCHGCMFASTCALL  Hdr;
    512     VMMDevHGCMCall          Call;
    513     VBoxSFParmInformation   Parms;
    514     SHFLFSOBJINFO           ObjInfo;
    515 } VBOXSFOBJINFOREQ;
    516 
    517 /**
    518  * SHFL_FN_INFORMATION[SHFL_INFO_GET | SHFL_INFO_FILE] request.
    519  */
    520 DECLINLINE(int) vboxSfOs2HostReqQueryObjInfo(SHFLROOT idRoot, VBOXSFOBJINFOREQ *pReq, uint64_t hHostFile)
    521 {
    522     uint32_t const cbReq = g_fHostFeatures & VMMDEV_HVF_HGCM_EMBEDDED_BUFFERS
    523                          ? sizeof(*pReq) : RT_UOFFSETOF(VBOXSFOBJINFOREQ, ObjInfo);
    524     VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    525                                 SHFL_FN_INFORMATION, SHFL_CPARMS_INFORMATION, cbReq);
    526 
    527     pReq->Parms.id32Root.type                   = VMMDevHGCMParmType_32bit;
    528     pReq->Parms.id32Root.u.value32              = idRoot;
    529 
    530     pReq->Parms.u64Handle.type                  = VMMDevHGCMParmType_64bit;
    531     pReq->Parms.u64Handle.u.value64             = hHostFile;
    532 
    533     pReq->Parms.f32Flags.type                   = VMMDevHGCMParmType_32bit;
    534     pReq->Parms.f32Flags.u.value32              = SHFL_INFO_GET | SHFL_INFO_FILE;
    535 
    536     pReq->Parms.cb32.type                       = VMMDevHGCMParmType_32bit;
    537     pReq->Parms.cb32.u.value32                  = sizeof(pReq->ObjInfo);
    538 
    539     if (g_fHostFeatures & VMMDEV_HVF_HGCM_EMBEDDED_BUFFERS)
    540     {
    541         pReq->Parms.pInfo.type                  = VMMDevHGCMParmType_Embedded;
    542         pReq->Parms.pInfo.u.Embedded.cbData     = sizeof(pReq->ObjInfo);
    543         pReq->Parms.pInfo.u.Embedded.offData    = RT_UOFFSETOF(VBOXSFOBJINFOREQ, ObjInfo) - sizeof(VBGLIOCIDCHGCMFASTCALL);
    544         pReq->Parms.pInfo.u.Embedded.fFlags     = VBOX_HGCM_F_PARM_DIRECTION_FROM_HOST;
    545     }
    546     else
    547     {
    548         pReq->Parms.pInfo.type                  = VMMDevHGCMParmType_LinAddr_Out;
    549         pReq->Parms.pInfo.u.LinAddr.cb          = sizeof(pReq->ObjInfo);
    550         pReq->Parms.pInfo.u.LinAddr.uAddr       = (uintptr_t)&pReq->ObjInfo;
    551     }
    552 
    553     int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr, cbReq);
    554     if (RT_SUCCESS(vrc))
    555         vrc = pReq->Call.header.result;
    556     return vrc;
    557 }
    558 
    559 
    560 /**
    561  * SHFL_FN_INFORMATION[SHFL_INFO_SET | SHFL_INFO_FILE] request.
    562  */
    563 DECLINLINE(int) vboxSfOs2HostReqSetObjInfo(SHFLROOT idRoot, VBOXSFOBJINFOREQ *pReq, uint64_t hHostFile)
    564 {
    565     uint32_t const cbReq = g_fHostFeatures & VMMDEV_HVF_HGCM_EMBEDDED_BUFFERS
    566                          ? sizeof(*pReq) : RT_UOFFSETOF(VBOXSFOBJINFOREQ, ObjInfo);
    567     VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    568                                 SHFL_FN_INFORMATION, SHFL_CPARMS_INFORMATION, cbReq);
    569 
    570     pReq->Parms.id32Root.type                   = VMMDevHGCMParmType_32bit;
    571     pReq->Parms.id32Root.u.value32              = idRoot;
    572 
    573     pReq->Parms.u64Handle.type                  = VMMDevHGCMParmType_64bit;
    574     pReq->Parms.u64Handle.u.value64             = hHostFile;
    575 
    576     pReq->Parms.f32Flags.type                   = VMMDevHGCMParmType_32bit;
    577     pReq->Parms.f32Flags.u.value32              = SHFL_INFO_SET | SHFL_INFO_FILE;
    578 
    579     pReq->Parms.cb32.type                       = VMMDevHGCMParmType_32bit;
    580     pReq->Parms.cb32.u.value32                  = sizeof(pReq->ObjInfo);
    581 
    582     if (g_fHostFeatures & VMMDEV_HVF_HGCM_EMBEDDED_BUFFERS)
    583     {
    584         pReq->Parms.pInfo.type                  = VMMDevHGCMParmType_Embedded;
    585         pReq->Parms.pInfo.u.Embedded.cbData     = sizeof(pReq->ObjInfo);
    586         pReq->Parms.pInfo.u.Embedded.offData    = RT_UOFFSETOF(VBOXSFOBJINFOREQ, ObjInfo) - sizeof(VBGLIOCIDCHGCMFASTCALL);
    587         pReq->Parms.pInfo.u.Embedded.fFlags     = VBOX_HGCM_F_PARM_DIRECTION_BOTH;
    588     }
    589     else
    590     {
    591         pReq->Parms.pInfo.type                  = VMMDevHGCMParmType_LinAddr;
    592         pReq->Parms.pInfo.u.LinAddr.cb          = sizeof(pReq->ObjInfo);
    593         pReq->Parms.pInfo.u.LinAddr.uAddr       = (uintptr_t)&pReq->ObjInfo;
    594     }
    595 
    596     int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr, cbReq);
    597     if (RT_SUCCESS(vrc))
    598         vrc = pReq->Call.header.result;
    599     return vrc;
    600 }
    601 
    602 
    603 /** Request structure for vboxSfOs2HostReqSetObjInfo.  */
    604 typedef struct VBOXSFOBJINFOWITHBUFREQ
    605 {
    606     VBGLIOCIDCHGCMFASTCALL  Hdr;
    607     VMMDevHGCMCall          Call;
    608     VBoxSFParmInformation   Parms;
    609     HGCMPageListInfo        PgLst;
    610 } VBOXSFOBJINFOWITHBUFREQ;
    611 
    612 /**
    613  * SHFL_FN_INFORMATION[SHFL_INFO_SET | SHFL_INFO_FILE] request, with separate
    614  * buffer (on the physical heap).
    615  */
    616 DECLINLINE(int) vboxSfOs2HostReqSetObjInfoWithBuf(SHFLROOT idRoot, VBOXSFOBJINFOWITHBUFREQ *pReq, uint64_t hHostFile,
    617                                                   PSHFLFSOBJINFO pObjInfo, uint32_t offObjInfoInAlloc)
    618 {
    619     VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    620                                 SHFL_FN_INFORMATION, SHFL_CPARMS_INFORMATION, sizeof(*pReq));
    621 
    622     pReq->Parms.id32Root.type               = VMMDevHGCMParmType_32bit;
    623     pReq->Parms.id32Root.u.value32          = idRoot;
    624 
    625     pReq->Parms.u64Handle.type              = VMMDevHGCMParmType_64bit;
    626     pReq->Parms.u64Handle.u.value64         = hHostFile;
    627 
    628     pReq->Parms.f32Flags.type               = VMMDevHGCMParmType_32bit;
    629     pReq->Parms.f32Flags.u.value32          = SHFL_INFO_SET | SHFL_INFO_FILE;
    630 
    631     pReq->Parms.cb32.type                   = VMMDevHGCMParmType_32bit;
    632     pReq->Parms.cb32.u.value32              = sizeof(*pObjInfo);
    633 
    634     if (g_fHostFeatures & VMMDEV_HVF_HGCM_CONTIGUOUS_PAGE_LIST)
    635     {
    636         pReq->Parms.pInfo.type              = VMMDevHGCMParmType_ContiguousPageList;
    637         pReq->Parms.pInfo.u.PageList.size   = sizeof(*pObjInfo);
    638         pReq->Parms.pInfo.u.PageList.offset = RT_UOFFSETOF(VBOXSFOBJINFOREQ, ObjInfo) - sizeof(VBGLIOCIDCHGCMFASTCALL);
    639         pReq->PgLst.flags                   = VBOX_HGCM_F_PARM_DIRECTION_BOTH;
    640         pReq->PgLst.aPages[0]               = VbglR0PhysHeapGetPhysAddr((uint8_t *)pObjInfo - offObjInfoInAlloc) + offObjInfoInAlloc;
    641         pReq->PgLst.offFirstPage            = (uint16_t)(pReq->PgLst.aPages[0] & PAGE_OFFSET_MASK);
    642         pReq->PgLst.aPages[0]              &= ~(RTGCPHYS)PAGE_OFFSET_MASK;
    643         pReq->PgLst.cPages                  = 1;
    644     }
    645     else
    646     {
    647         pReq->Parms.pInfo.type              = VMMDevHGCMParmType_LinAddr;
    648         pReq->Parms.pInfo.u.LinAddr.cb      = sizeof(*pObjInfo);
    649         pReq->Parms.pInfo.u.LinAddr.uAddr   = (uintptr_t)pObjInfo;
    650     }
    651 
    652     int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr, sizeof(*pReq));
    653     if (RT_SUCCESS(vrc))
    654         vrc = pReq->Call.header.result;
    655     return vrc;
    656 }
    657 
    658 
    659 /** Request structure for vboxSfOs2HostReqRemove.  */
    660 typedef struct VBOXSFREMOVEREQ
    661 {
    662     VBGLIOCIDCHGCMFASTCALL  Hdr;
    663     VMMDevHGCMCall          Call;
    664     VBoxSFParmRemove        Parms;
    665     SHFLSTRING              StrPath;
    666 } VBOXSFREMOVEREQ;
    667 
    668 /**
    669  * SHFL_FN_REMOVE request.
    670  */
    671 DECLINLINE(int) vboxSfOs2HostReqRemove(SHFLROOT idRoot, VBOXSFREMOVEREQ *pReq, uint32_t fFlags)
    672 {
    673     uint32_t const cbReq = RT_UOFFSETOF(VBOXSFREMOVEREQ, StrPath.String)
    674                          + (g_fHostFeatures & VMMDEV_HVF_HGCM_EMBEDDED_BUFFERS ? pReq->StrPath.u16Size : 0);
    675     VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    676                                 SHFL_FN_REMOVE, SHFL_CPARMS_REMOVE, cbReq);
    677 
    678     pReq->Parms.id32Root.type                   = VMMDevHGCMParmType_32bit;
    679     pReq->Parms.id32Root.u.value32              = idRoot;
    680 
    681     if (g_fHostFeatures & VMMDEV_HVF_HGCM_EMBEDDED_BUFFERS)
    682     {
    683         pReq->Parms.pStrPath.type               = VMMDevHGCMParmType_Embedded;
    684         pReq->Parms.pStrPath.u.Embedded.cbData  = SHFLSTRING_HEADER_SIZE + pReq->StrPath.u16Size;
    685         pReq->Parms.pStrPath.u.Embedded.offData = RT_UOFFSETOF(VBOXSFREMOVEREQ, StrPath) - sizeof(VBGLIOCIDCHGCMFASTCALL);
    686         pReq->Parms.pStrPath.u.Embedded.fFlags  = VBOX_HGCM_F_PARM_DIRECTION_TO_HOST;
    687     }
    688     else
    689     {
    690         pReq->Parms.pStrPath.type               = VMMDevHGCMParmType_LinAddr_In;
    691         pReq->Parms.pStrPath.u.LinAddr.cb       = SHFLSTRING_HEADER_SIZE + pReq->StrPath.u16Size;
    692         pReq->Parms.pStrPath.u.LinAddr.uAddr    = (uintptr_t)&pReq->StrPath;
    693     }
    694 
    695     pReq->Parms.f32Flags.type                   = VMMDevHGCMParmType_32bit;
    696     pReq->Parms.f32Flags.u.value32              = fFlags;
    697 
    698     int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr, cbReq);
    699     if (RT_SUCCESS(vrc))
    700         vrc = pReq->Call.header.result;
    701     return vrc;
    702 }
    703 
    704 
    705 /** Request structure for vboxSfOs2HostReqRename.  */
    706 typedef struct VBOXSFRENAMEWITHSRCBUFREQ
    707 {
    708     VBGLIOCIDCHGCMFASTCALL  Hdr;
    709     VMMDevHGCMCall          Call;
    710     VBoxSFParmRename        Parms;
    711     HGCMPageListInfo        PgLst;
    712     SHFLSTRING              StrDstPath;
    713 } VBOXSFRENAMEWITHSRCBUFREQ;
    714 
    715 /**
    716  * SHFL_FN_REMOVE request.
    717  */
    718 DECLINLINE(int) vboxSfOs2HostReqRenameWithSrcBuf(SHFLROOT idRoot, VBOXSFRENAMEWITHSRCBUFREQ *pReq,
    719                                                  PSHFLSTRING pSrcStr, uint32_t fFlags)
    720 {
    721     uint32_t const cbReq = RT_UOFFSETOF(VBOXSFRENAMEWITHSRCBUFREQ, StrDstPath.String)
    722                          + (g_fHostFeatures & VMMDEV_HVF_HGCM_EMBEDDED_BUFFERS ? pReq->StrDstPath.u16Size : 0);
    723     VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    724                                 SHFL_FN_RENAME, SHFL_CPARMS_RENAME, cbReq);
    725 
    726     pReq->Parms.id32Root.type                       = VMMDevHGCMParmType_32bit;
    727     pReq->Parms.id32Root.u.value32                  = idRoot;
    728 
    729     if (g_fHostFeatures & VMMDEV_HVF_HGCM_CONTIGUOUS_PAGE_LIST)
    730     {
    731         pReq->Parms.pStrSrcPath.type                = VMMDevHGCMParmType_ContiguousPageList;
    732         pReq->Parms.pStrSrcPath.u.PageList.size     = SHFLSTRING_HEADER_SIZE + pSrcStr->u16Size;
    733         pReq->Parms.pStrSrcPath.u.PageList.offset   = RT_UOFFSETOF(VBOXSFRENAMEWITHSRCBUFREQ, PgLst)
    734                                                     - sizeof(VBGLIOCIDCHGCMFASTCALL);
    735         pReq->PgLst.flags                           = VBOX_HGCM_F_PARM_DIRECTION_TO_HOST;
    736         pReq->PgLst.aPages[0]                       = VbglR0PhysHeapGetPhysAddr(pSrcStr);
    737         pReq->PgLst.offFirstPage                    = (uint16_t)(pReq->PgLst.aPages[0] & PAGE_OFFSET_MASK);
    738         pReq->PgLst.aPages[0]                      &= ~(RTGCPHYS)PAGE_OFFSET_MASK;
    739         pReq->PgLst.cPages                          = 1;
    740     }
    741     else
    742     {
    743         pReq->Parms.pStrSrcPath.type                = VMMDevHGCMParmType_LinAddr_In;
    744         pReq->Parms.pStrSrcPath.u.LinAddr.cb        = SHFLSTRING_HEADER_SIZE + pSrcStr->u16Size;
    745         pReq->Parms.pStrSrcPath.u.LinAddr.uAddr     = (uintptr_t)pSrcStr;
    746     }
    747 
    748     if (g_fHostFeatures & VMMDEV_HVF_HGCM_EMBEDDED_BUFFERS)
    749     {
    750         pReq->Parms.pStrDstPath.type                = VMMDevHGCMParmType_Embedded;
    751         pReq->Parms.pStrDstPath.u.Embedded.cbData   = SHFLSTRING_HEADER_SIZE + pReq->StrDstPath.u16Size;
    752         pReq->Parms.pStrDstPath.u.Embedded.offData  = RT_UOFFSETOF(VBOXSFRENAMEWITHSRCBUFREQ, StrDstPath)
    753                                                     - sizeof(VBGLIOCIDCHGCMFASTCALL);
    754         pReq->Parms.pStrDstPath.u.Embedded.fFlags   = VBOX_HGCM_F_PARM_DIRECTION_TO_HOST;
    755     }
    756     else
    757     {
    758         pReq->Parms.pStrDstPath.type                = VMMDevHGCMParmType_LinAddr_In;
    759         pReq->Parms.pStrDstPath.u.LinAddr.cb        = SHFLSTRING_HEADER_SIZE + pReq->StrDstPath.u16Size;
    760         pReq->Parms.pStrDstPath.u.LinAddr.uAddr     = (uintptr_t)&pReq->StrDstPath;
    761     }
    762 
    763     pReq->Parms.f32Flags.type                       = VMMDevHGCMParmType_32bit;
    764     pReq->Parms.f32Flags.u.value32                  = fFlags;
    765 
    766     int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr, cbReq);
    767     if (RT_SUCCESS(vrc))
    768         vrc = pReq->Call.header.result;
    769     return vrc;
    770 }
    771 
    772 
    773 /** Request structure for vboxSfOs2HostReqFlush.  */
    774 typedef struct VBOXSFFLUSHREQ
    775 {
    776     VBGLIOCIDCHGCMFASTCALL  Hdr;
    777     VMMDevHGCMCall          Call;
    778     VBoxSFParmFlush         Parms;
    779 } VBOXSFFLUSHREQ;
    780 
    781 /**
    782  * SHFL_FN_FLUSH request.
    783  */
    784 DECLINLINE(int) vboxSfOs2HostReqFlush(SHFLROOT idRoot, VBOXSFFLUSHREQ *pReq, uint64_t hHostFile)
    785 {
    786     VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    787                                 SHFL_FN_FLUSH, SHFL_CPARMS_FLUSH, sizeof(*pReq));
    788 
    789     pReq->Parms.id32Root.type       = VMMDevHGCMParmType_32bit;
    790     pReq->Parms.id32Root.u.value32  = idRoot;
    791 
    792     pReq->Parms.u64Handle.type      = VMMDevHGCMParmType_64bit;
    793     pReq->Parms.u64Handle.u.value64 = hHostFile;
    794 
    795     int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr, sizeof(*pReq));
    796     if (RT_SUCCESS(vrc))
    797         vrc = pReq->Call.header.result;
    798     return vrc;
    799 }
    800 
    801 /**
    802  * SHFL_FN_FLUSH request, allocate request buffer.
    803  */
    804 DECLINLINE(int) vboxSfOs2HostReqFlushSimple(SHFLROOT idRoot, uint64_t hHostFile)
    805 {
    806     VBOXSFFLUSHREQ *pReq = (VBOXSFFLUSHREQ *)VbglR0PhysHeapAlloc(sizeof(*pReq));
    807     if (pReq)
    808     {
    809         int vrc = vboxSfOs2HostReqFlush(idRoot, pReq, hHostFile);
    810         VbglR0PhysHeapFree(pReq);
    811         return vrc;
    812     }
    813     return VERR_NO_MEMORY;
    814 }
    815 
    816 
    817 /** Request structure for vboxSfOs2HostReqSetFileSize.  */
    818 typedef struct VBOXSFSETFILESIZEREQ
    819 {
    820     VBGLIOCIDCHGCMFASTCALL  Hdr;
    821     VMMDevHGCMCall          Call;
    822     VBoxSFParmSetFileSize   Parms;
    823 } VBOXSFSETFILESIZEREQ;
    824 
    825 /**
    826  * SHFL_FN_SET_FILE_SIZE request.
    827  */
    828 DECLINLINE(int) vboxSfOs2HostReqSetFileSize(SHFLROOT idRoot, VBOXSFSETFILESIZEREQ *pReq,
    829                                             uint64_t hHostFile, uint64_t cbNewSize)
    830 {
    831     VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    832                                 SHFL_FN_SET_FILE_SIZE, SHFL_CPARMS_SET_FILE_SIZE, sizeof(*pReq));
    833 
    834     pReq->Parms.id32Root.type           = VMMDevHGCMParmType_32bit;
    835     pReq->Parms.id32Root.u.value32      = idRoot;
    836 
    837     pReq->Parms.u64Handle.type          = VMMDevHGCMParmType_64bit;
    838     pReq->Parms.u64Handle.u.value64     = hHostFile;
    839 
    840     pReq->Parms.cb64NewSize.type        = VMMDevHGCMParmType_64bit;
    841     pReq->Parms.cb64NewSize.u.value64   = cbNewSize;
    842 
    843     int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr, sizeof(*pReq));
    844     if (RT_SUCCESS(vrc))
    845         vrc = pReq->Call.header.result;
    846     return vrc;
    847 }
    848 
    849 /**
    850  * SHFL_FN_SET_FILE_SIZE request, allocate request buffer.
    851  */
    852 DECLINLINE(int) vboxSfOs2HostReqSetFileSizeSimple(SHFLROOT idRoot, uint64_t hHostFile, uint64_t cbNewSize)
    853 {
    854     VBOXSFSETFILESIZEREQ *pReq = (VBOXSFSETFILESIZEREQ *)VbglR0PhysHeapAlloc(sizeof(*pReq));
    855     if (pReq)
    856     {
    857         int vrc = vboxSfOs2HostReqSetFileSize(idRoot, pReq, hHostFile, cbNewSize);
    858         VbglR0PhysHeapFree(pReq);
    859         return vrc;
    860     }
    861     return VERR_NO_MEMORY;
    862 }
    863 
    864 
    865 /** Request structure for vboxSfOs2HostReqReadEmbedded. */
    866 typedef struct VBOXSFREADEMBEDDEDREQ
    867 {
    868     VBGLIOCIDCHGCMFASTCALL  Hdr;
    869     VMMDevHGCMCall          Call;
    870     VBoxSFParmRead          Parms;
    871     uint8_t                 abData[RT_FLEXIBLE_ARRAY];
    872 } VBOXSFREADEMBEDDEDREQ;
    873 
    874 /**
    875  * SHFL_FN_READ request using embedded data buffer.
    876  */
    877 DECLINLINE(int) vboxSfOs2HostReqReadEmbedded(SHFLROOT idRoot, VBOXSFREADEMBEDDEDREQ *pReq, uint64_t hHostFile,
    878                                              uint64_t offRead, uint32_t cbToRead)
    879 {
    880     uint32_t const cbReq = RT_UOFFSETOF(VBOXSFREADEMBEDDEDREQ, abData[0])
    881                          + (g_fHostFeatures & VMMDEV_HVF_HGCM_EMBEDDED_BUFFERS ? cbToRead : 0);
    882     VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    883                                 SHFL_FN_READ, SHFL_CPARMS_READ, cbReq);
    884 
    885     pReq->Parms.id32Root.type               = VMMDevHGCMParmType_32bit;
    886     pReq->Parms.id32Root.u.value32          = idRoot;
    887 
    888     pReq->Parms.u64Handle.type              = VMMDevHGCMParmType_64bit;
    889     pReq->Parms.u64Handle.u.value64         = hHostFile;
    890 
    891     pReq->Parms.off64Read.type              = VMMDevHGCMParmType_64bit;
    892     pReq->Parms.off64Read.u.value64         = offRead;
    893 
    894     pReq->Parms.cb32Read.type               = VMMDevHGCMParmType_32bit;
    895     pReq->Parms.cb32Read.u.value32          = cbToRead;
    896 
    897     if (g_fHostFeatures & VMMDEV_HVF_HGCM_EMBEDDED_BUFFERS)
    898     {
    899         pReq->Parms.pBuf.type               = VMMDevHGCMParmType_Embedded;
    900         pReq->Parms.pBuf.u.Embedded.cbData  = cbToRead;
    901         pReq->Parms.pBuf.u.Embedded.offData = RT_UOFFSETOF(VBOXSFREADEMBEDDEDREQ, abData[0]) - sizeof(VBGLIOCIDCHGCMFASTCALL);
    902         pReq->Parms.pBuf.u.Embedded.fFlags  = VBOX_HGCM_F_PARM_DIRECTION_FROM_HOST;
    903     }
    904     else
    905     {
    906         pReq->Parms.pBuf.type               = VMMDevHGCMParmType_LinAddr_Out;
    907         pReq->Parms.pBuf.u.LinAddr.cb       = cbToRead;
    908         pReq->Parms.pBuf.u.LinAddr.uAddr    = (uintptr_t)&pReq->abData[0];
    909     }
    910 
    911     int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr, cbReq);
    912     if (RT_SUCCESS(vrc))
    913         vrc = pReq->Call.header.result;
    914     return vrc;
    915 }
    916 
    917 
    918 /** Request structure for vboxSfOs2HostReqRead & vboxSfOs2HostReqReadContig. */
    919 typedef struct VBOXSFREADPGLSTREQ
    920 {
    921     VBGLIOCIDCHGCMFASTCALL  Hdr;
    922     VMMDevHGCMCall          Call;
    923     VBoxSFParmRead          Parms;
    924     HGCMPageListInfo        PgLst;
    925 } VBOXSFREADPGLSTREQ;
    926 
    927 /**
    928  * SHFL_FN_READ request using page list for data buffer (caller populated).
    929  */
    930 DECLINLINE(int) vboxSfOs2HostReqReadPgLst(SHFLROOT idRoot, VBOXSFREADPGLSTREQ *pReq, uint64_t hHostFile,
    931                                           uint64_t offRead, uint32_t cbToRead, uint32_t cPages)
    932 {
    933     VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    934                                 SHFL_FN_READ, SHFL_CPARMS_READ,
    935                                 RT_UOFFSETOF_DYN(VBOXSFREADPGLSTREQ, PgLst.aPages[cPages]));
    936 
    937     pReq->Parms.id32Root.type               = VMMDevHGCMParmType_32bit;
    938     pReq->Parms.id32Root.u.value32          = idRoot;
    939 
    940     pReq->Parms.u64Handle.type              = VMMDevHGCMParmType_64bit;
    941     pReq->Parms.u64Handle.u.value64         = hHostFile;
    942 
    943     pReq->Parms.off64Read.type              = VMMDevHGCMParmType_64bit;
    944     pReq->Parms.off64Read.u.value64         = offRead;
    945 
    946     pReq->Parms.cb32Read.type               = VMMDevHGCMParmType_32bit;
    947     pReq->Parms.cb32Read.u.value32          = cbToRead;
    948 
    949     pReq->Parms.pBuf.type                   = VMMDevHGCMParmType_PageList;
    950     pReq->Parms.pBuf.u.PageList.size        = cbToRead;
    951     pReq->Parms.pBuf.u.PageList.offset      = RT_UOFFSETOF(VBOXSFREADPGLSTREQ, PgLst) - sizeof(VBGLIOCIDCHGCMFASTCALL);
    952     pReq->PgLst.flags                       = VBOX_HGCM_F_PARM_DIRECTION_FROM_HOST;
    953     pReq->PgLst.cPages                      = (uint16_t)cPages;
    954     AssertReturn(cPages <= UINT16_MAX, VERR_OUT_OF_RANGE);
    955     /* caller sets offset */
    956 
    957     int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr,
    958                                  RT_UOFFSETOF_DYN(VBOXSFREADPGLSTREQ, PgLst.aPages[cPages]));
    959     if (RT_SUCCESS(vrc))
    960         vrc = pReq->Call.header.result;
    961     return vrc;
    962 }
    963 
    964 
    965 /**
    966  * SHFL_FN_READ request using a physically contiguous buffer.
    967  */
    968 DECLINLINE(int) vboxSfOs2HostReqReadContig(SHFLROOT idRoot, VBOXSFREADPGLSTREQ *pReq, uint64_t hHostFile,
    969                                           uint64_t offRead, uint32_t cbToRead, void *pvBuffer, RTGCPHYS64 PhysBuffer)
    970 {
    971     VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    972                                 SHFL_FN_READ, SHFL_CPARMS_READ, RT_UOFFSETOF_DYN(VBOXSFREADPGLSTREQ, PgLst.aPages[1]));
    973 
    974     pReq->Parms.id32Root.type               = VMMDevHGCMParmType_32bit;
    975     pReq->Parms.id32Root.u.value32          = idRoot;
    976 
    977     pReq->Parms.u64Handle.type              = VMMDevHGCMParmType_64bit;
    978     pReq->Parms.u64Handle.u.value64         = hHostFile;
    979 
    980     pReq->Parms.off64Read.type              = VMMDevHGCMParmType_64bit;
    981     pReq->Parms.off64Read.u.value64         = offRead;
    982 
    983     pReq->Parms.cb32Read.type               = VMMDevHGCMParmType_32bit;
    984     pReq->Parms.cb32Read.u.value32          = cbToRead;
    985 
    986     if (g_fHostFeatures & VMMDEV_HVF_HGCM_CONTIGUOUS_PAGE_LIST)
    987     {
    988         pReq->Parms.pBuf.type               = VMMDevHGCMParmType_ContiguousPageList;
    989         pReq->Parms.pBuf.u.PageList.size    = cbToRead;
    990         pReq->Parms.pBuf.u.PageList.offset  = RT_UOFFSETOF(VBOXSFREADPGLSTREQ, PgLst) - sizeof(VBGLIOCIDCHGCMFASTCALL);
    991         pReq->PgLst.flags                   = VBOX_HGCM_F_PARM_DIRECTION_FROM_HOST;
    992         pReq->PgLst.offFirstPage            = (uint16_t)(PhysBuffer & PAGE_OFFSET_MASK);
    993         pReq->PgLst.cPages                  = 1;
    994         pReq->PgLst.aPages[0]               = PhysBuffer & ~(RTGCPHYS64)PAGE_OFFSET_MASK;
    995     }
    996     else
    997     {
    998         pReq->Parms.pBuf.type               = VMMDevHGCMParmType_LinAddr_Out;
    999         pReq->Parms.pBuf.u.LinAddr.cb       = cbToRead;
    1000         pReq->Parms.pBuf.u.LinAddr.uAddr    = (uintptr_t)pvBuffer;
    1001     }
    1002 
    1003     int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr, RT_UOFFSETOF_DYN(VBOXSFREADPGLSTREQ, PgLst.aPages[1]));
    1004     if (RT_SUCCESS(vrc))
    1005         vrc = pReq->Call.header.result;
    1006     return vrc;
    1007 }
    1008 
    1009 
    1010 
    1011 /** Request structure for vboxSfOs2HostReqWriteEmbedded. */
    1012 typedef struct VBOXSFWRITEEMBEDDEDREQ
    1013 {
    1014     VBGLIOCIDCHGCMFASTCALL  Hdr;
    1015     VMMDevHGCMCall          Call;
    1016     VBoxSFParmWrite         Parms;
    1017     uint8_t                 abData[RT_FLEXIBLE_ARRAY];
    1018 } VBOXSFWRITEEMBEDDEDREQ;
    1019 
    1020 /**
    1021  * SHFL_FN_WRITE request using embedded data buffer.
    1022  */
    1023 DECLINLINE(int) vboxSfOs2HostReqWriteEmbedded(SHFLROOT idRoot, VBOXSFWRITEEMBEDDEDREQ *pReq, uint64_t hHostFile,
    1024                                               uint64_t offWrite, uint32_t cbToWrite)
    1025 {
    1026     uint32_t const cbReq = RT_UOFFSETOF(VBOXSFWRITEEMBEDDEDREQ, abData[0])
    1027                          + (g_fHostFeatures & VMMDEV_HVF_HGCM_EMBEDDED_BUFFERS ? cbToWrite : 0);
    1028     VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    1029                                 SHFL_FN_WRITE, SHFL_CPARMS_WRITE, cbReq);
    1030 
    1031     pReq->Parms.id32Root.type               = VMMDevHGCMParmType_32bit;
    1032     pReq->Parms.id32Root.u.value32          = idRoot;
    1033 
    1034     pReq->Parms.u64Handle.type              = VMMDevHGCMParmType_64bit;
    1035     pReq->Parms.u64Handle.u.value64         = hHostFile;
    1036 
    1037     pReq->Parms.off64Write.type             = VMMDevHGCMParmType_64bit;
    1038     pReq->Parms.off64Write.u.value64        = offWrite;
    1039 
    1040     pReq->Parms.cb32Write.type              = VMMDevHGCMParmType_32bit;
    1041     pReq->Parms.cb32Write.u.value32         = cbToWrite;
    1042 
    1043     if (g_fHostFeatures & VMMDEV_HVF_HGCM_EMBEDDED_BUFFERS)
    1044     {
    1045         pReq->Parms.pBuf.type               = VMMDevHGCMParmType_Embedded;
    1046         pReq->Parms.pBuf.u.Embedded.cbData  = cbToWrite;
    1047         pReq->Parms.pBuf.u.Embedded.offData = RT_UOFFSETOF(VBOXSFWRITEEMBEDDEDREQ, abData[0]) - sizeof(VBGLIOCIDCHGCMFASTCALL);
    1048         pReq->Parms.pBuf.u.Embedded.fFlags  = VBOX_HGCM_F_PARM_DIRECTION_TO_HOST;
    1049     }
    1050     else
    1051     {
    1052         pReq->Parms.pBuf.type               = VMMDevHGCMParmType_LinAddr_In;
    1053         pReq->Parms.pBuf.u.LinAddr.cb       = cbToWrite;
    1054         pReq->Parms.pBuf.u.LinAddr.uAddr    = (uintptr_t)&pReq->abData[0];
    1055     }
    1056 
    1057     int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr, cbReq);
    1058     if (RT_SUCCESS(vrc))
    1059         vrc = pReq->Call.header.result;
    1060     return vrc;
    1061 }
    1062 
    1063 
    1064 /** Request structure for vboxSfOs2HostReqWrite and vboxSfOs2HostReqWriteContig. */
    1065 typedef struct VBOXSFWRITEPGLSTREQ
    1066 {
    1067     VBGLIOCIDCHGCMFASTCALL  Hdr;
    1068     VMMDevHGCMCall          Call;
    1069     VBoxSFParmWrite         Parms;
    1070     HGCMPageListInfo        PgLst;
    1071 } VBOXSFWRITEPGLSTREQ;
    1072 
    1073 /**
    1074  * SHFL_FN_WRITE request using page list for data buffer (caller populated).
    1075  */
    1076 DECLINLINE(int) vboxSfOs2HostReqWritePgLst(SHFLROOT idRoot, VBOXSFWRITEPGLSTREQ *pReq, uint64_t hHostFile,
    1077                                            uint64_t offWrite, uint32_t cbToWrite, uint32_t cPages)
    1078 {
    1079     VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    1080                                 SHFL_FN_WRITE, SHFL_CPARMS_WRITE,
    1081                                 RT_UOFFSETOF_DYN(VBOXSFWRITEPGLSTREQ, PgLst.aPages[cPages]));
    1082 
    1083     pReq->Parms.id32Root.type               = VMMDevHGCMParmType_32bit;
    1084     pReq->Parms.id32Root.u.value32          = idRoot;
    1085 
    1086     pReq->Parms.u64Handle.type              = VMMDevHGCMParmType_64bit;
    1087     pReq->Parms.u64Handle.u.value64         = hHostFile;
    1088 
    1089     pReq->Parms.off64Write.type             = VMMDevHGCMParmType_64bit;
    1090     pReq->Parms.off64Write.u.value64        = offWrite;
    1091 
    1092     pReq->Parms.cb32Write.type              = VMMDevHGCMParmType_32bit;
    1093     pReq->Parms.cb32Write.u.value32         = cbToWrite;
    1094 
    1095     pReq->Parms.pBuf.type                   = VMMDevHGCMParmType_PageList;
    1096     pReq->Parms.pBuf.u.PageList.size        = cbToWrite;
    1097     pReq->Parms.pBuf.u.PageList.offset      = RT_UOFFSETOF(VBOXSFWRITEPGLSTREQ, PgLst) - sizeof(VBGLIOCIDCHGCMFASTCALL);
    1098     pReq->PgLst.flags                       = VBOX_HGCM_F_PARM_DIRECTION_TO_HOST;
    1099     pReq->PgLst.cPages                      = (uint16_t)cPages;
    1100     AssertReturn(cPages <= UINT16_MAX, VERR_OUT_OF_RANGE);
    1101     /* caller sets offset */
    1102 
    1103     int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr,
    1104                                  RT_UOFFSETOF_DYN(VBOXSFWRITEPGLSTREQ, PgLst.aPages[cPages]));
    1105     if (RT_SUCCESS(vrc))
    1106         vrc = pReq->Call.header.result;
    1107     return vrc;
    1108 }
    1109 
    1110 
    1111 /**
    1112  * SHFL_FN_WRITE request using a physically contiguous buffer.
    1113  */
    1114 DECLINLINE(int) vboxSfOs2HostReqWriteContig(SHFLROOT idRoot, VBOXSFWRITEPGLSTREQ *pReq, uint64_t hHostFile,
    1115                                             uint64_t offWrite, uint32_t cbToWrite, void const *pvBuffer, RTGCPHYS64 PhysBuffer)
    1116 {
    1117     VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    1118                                 SHFL_FN_WRITE, SHFL_CPARMS_WRITE, RT_UOFFSETOF_DYN(VBOXSFWRITEPGLSTREQ, PgLst.aPages[1]));
    1119 
    1120     pReq->Parms.id32Root.type               = VMMDevHGCMParmType_32bit;
    1121     pReq->Parms.id32Root.u.value32          = idRoot;
    1122 
    1123     pReq->Parms.u64Handle.type              = VMMDevHGCMParmType_64bit;
    1124     pReq->Parms.u64Handle.u.value64         = hHostFile;
    1125 
    1126     pReq->Parms.off64Write.type             = VMMDevHGCMParmType_64bit;
    1127     pReq->Parms.off64Write.u.value64        = offWrite;
    1128 
    1129     pReq->Parms.cb32Write.type              = VMMDevHGCMParmType_32bit;
    1130     pReq->Parms.cb32Write.u.value32         = cbToWrite;
    1131 
    1132     if (g_fHostFeatures & VMMDEV_HVF_HGCM_CONTIGUOUS_PAGE_LIST)
    1133     {
    1134         pReq->Parms.pBuf.type               = VMMDevHGCMParmType_ContiguousPageList;
    1135         pReq->Parms.pBuf.u.PageList.size    = cbToWrite;
    1136         pReq->Parms.pBuf.u.PageList.offset  = RT_UOFFSETOF(VBOXSFWRITEPGLSTREQ, PgLst) - sizeof(VBGLIOCIDCHGCMFASTCALL);
    1137         pReq->PgLst.flags                   = VBOX_HGCM_F_PARM_DIRECTION_TO_HOST;
    1138         pReq->PgLst.offFirstPage            = (uint16_t)(PhysBuffer & PAGE_OFFSET_MASK);
    1139         pReq->PgLst.cPages                  = 1;
    1140         pReq->PgLst.aPages[0]               = PhysBuffer & ~(RTGCPHYS64)PAGE_OFFSET_MASK;
    1141     }
    1142     else
    1143     {
    1144         pReq->Parms.pBuf.type               = VMMDevHGCMParmType_LinAddr_In;
    1145         pReq->Parms.pBuf.u.LinAddr.cb       = cbToWrite;
    1146         pReq->Parms.pBuf.u.LinAddr.uAddr    = (uintptr_t)pvBuffer;
    1147     }
    1148 
    1149     int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr, RT_UOFFSETOF_DYN(VBOXSFWRITEPGLSTREQ, PgLst.aPages[1]));
    1150     if (RT_SUCCESS(vrc))
    1151         vrc = pReq->Call.header.result;
    1152     return vrc;
    1153 }
    1154 
    1155 
    1156 /**
    1157  * SHFL_FN_LIST request with separate string buffer and buffers for entries,
    1158  * both allocated on the physical heap.
    1159  */
    1160 DECLINLINE(int) vboxSfOs2HostReqListDir(SHFLROOT idRoot, VBOXSFLISTDIRREQ *pReq, uint64_t hHostDir,
    1161                                         PSHFLSTRING pFilter, uint32_t fFlags, PSHFLDIRINFO pBuffer, uint32_t cbBuffer)
    1162 {
    1163     VBGLIOCIDCHGCMFASTCALL_INIT(&pReq->Hdr, VbglR0PhysHeapGetPhysAddr(pReq), &pReq->Call, g_SfClient.idClient,
    1164                                 SHFL_FN_LIST, SHFL_CPARMS_LIST, sizeof(*pReq));
    1165 
    1166     pReq->Parms.id32Root.type                       = VMMDevHGCMParmType_32bit;
    1167     pReq->Parms.id32Root.u.value32                  = idRoot;
    1168 
    1169     pReq->Parms.u64Handle.type                      = VMMDevHGCMParmType_64bit;
    1170     pReq->Parms.u64Handle.u.value64                 = hHostDir;
    1171 
    1172     pReq->Parms.f32Flags.type                       = VMMDevHGCMParmType_32bit;
    1173     pReq->Parms.f32Flags.u.value32                  = fFlags;
    1174 
    1175     pReq->Parms.cb32Buffer.type                     = VMMDevHGCMParmType_32bit;
    1176     pReq->Parms.cb32Buffer.u.value32                = cbBuffer;
    1177 
    1178     if (g_fHostFeatures & VMMDEV_HVF_HGCM_CONTIGUOUS_PAGE_LIST)
    1179     {
    1180         pReq->Parms.pStrFilter.type                 = VMMDevHGCMParmType_ContiguousPageList;
    1181         pReq->Parms.pStrFilter.u.PageList.offset    = RT_UOFFSETOF(VBOXSFLISTDIRREQ, StrPgLst) - sizeof(VBGLIOCIDCHGCMFASTCALL);
    1182         pReq->StrPgLst.flags                        = VBOX_HGCM_F_PARM_DIRECTION_TO_HOST;
    1183         pReq->StrPgLst.cPages                       = 1;
    1184         if (pFilter)
    1185         {
    1186             pReq->Parms.pStrFilter.u.PageList.size  = SHFLSTRING_HEADER_SIZE + pFilter->u16Size;
    1187             RTGCPHYS32 const GCPhys       = VbglR0PhysHeapGetPhysAddr(pFilter);
    1188             uint32_t const   offFirstPage = GCPhys & PAGE_OFFSET_MASK;
    1189             pReq->StrPgLst.offFirstPage             = (uint16_t)offFirstPage;
    1190             pReq->StrPgLst.aPages[0]                = GCPhys - offFirstPage;
    1191         }
    1192         else
    1193         {
    1194             pReq->Parms.pStrFilter.u.PageList.size  = 0;
    1195             pReq->StrPgLst.offFirstPage             = 0;
    1196             pReq->StrPgLst.aPages[0]                = NIL_RTGCPHYS64;
    1197         }
    1198 
    1199         pReq->Parms.pBuffer.type                    = VMMDevHGCMParmType_ContiguousPageList;
    1200         pReq->Parms.pBuffer.u.PageList.offset       = RT_UOFFSETOF(VBOXSFLISTDIRREQ, BufPgLst) - sizeof(VBGLIOCIDCHGCMFASTCALL);
    1201         pReq->Parms.pBuffer.u.PageList.size         = cbBuffer;
    1202         pReq->BufPgLst.flags                        = VBOX_HGCM_F_PARM_DIRECTION_FROM_HOST;
    1203         pReq->BufPgLst.cPages                       = 1;
    1204         RTGCPHYS32 const GCPhys       = VbglR0PhysHeapGetPhysAddr(pBuffer);
    1205         uint32_t const   offFirstPage = GCPhys & PAGE_OFFSET_MASK;
    1206         pReq->BufPgLst.offFirstPage                 = (uint16_t)offFirstPage;
    1207         pReq->BufPgLst.aPages[0]                    = GCPhys - offFirstPage;
    1208     }
    1209     else
    1210     {
    1211         pReq->Parms.pStrFilter.type                 = VMMDevHGCMParmType_LinAddr_In;
    1212         pReq->Parms.pStrFilter.u.LinAddr.cb         = pFilter ? SHFLSTRING_HEADER_SIZE + pFilter->u16Size : 0;
    1213         pReq->Parms.pStrFilter.u.LinAddr.uAddr      = (uintptr_t)pFilter;
    1214 
    1215         pReq->Parms.pBuffer.type                    = VMMDevHGCMParmType_LinAddr_Out;
    1216         pReq->Parms.pBuffer.u.LinAddr.cb            = cbBuffer;
    1217         pReq->Parms.pBuffer.u.LinAddr.uAddr         = (uintptr_t)pBuffer;
    1218     }
    1219 
    1220     pReq->Parms.f32Done.type                        = VMMDevHGCMParmType_32bit;
    1221     pReq->Parms.f32Done.u.value32                   = 0;
    1222 
    1223     pReq->Parms.c32Entries.type                     = VMMDevHGCMParmType_32bit;
    1224     pReq->Parms.c32Entries.u.value32                = 0;
    1225 
    1226     int vrc = VbglR0HGCMFastCall(g_SfClient.handle, &pReq->Hdr, sizeof(*pReq));
    1227     if (RT_SUCCESS(vrc))
    1228         vrc = pReq->Call.header.result;
    1229     return vrc;
    1230 }
    1231 
    1232 /** @} */
    1233 
    1234253#endif /* !GA_INCLUDED_SRC_os2_VBoxSF_VBoxSFInternal_h */
    1235254
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