summaryrefslogtreecommitdiffstats
path: root/src/VBox/VMM/include/PDMAsyncCompletionFileInternal.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/VBox/VMM/include/PDMAsyncCompletionFileInternal.h')
-rw-r--r--src/VBox/VMM/include/PDMAsyncCompletionFileInternal.h566
1 files changed, 566 insertions, 0 deletions
diff --git a/src/VBox/VMM/include/PDMAsyncCompletionFileInternal.h b/src/VBox/VMM/include/PDMAsyncCompletionFileInternal.h
new file mode 100644
index 00000000..07ee7669
--- /dev/null
+++ b/src/VBox/VMM/include/PDMAsyncCompletionFileInternal.h
@@ -0,0 +1,566 @@
+/* $Id: PDMAsyncCompletionFileInternal.h $ */
+/** @file
+ * PDM Async I/O - Transport data asynchronous in R3 using EMT.
+ */
+
+/*
+ * Copyright (C) 2006-2019 Oracle Corporation
+ *
+ * This file is part of VirtualBox Open Source Edition (OSE), as
+ * available from http://www.virtualbox.org. This file is free software;
+ * you can redistribute it and/or modify it under the terms of the GNU
+ * General Public License (GPL) as published by the Free Software
+ * Foundation, in version 2 as it comes in the "COPYING" file of the
+ * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
+ * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
+ */
+
+#ifndef VMM_INCLUDED_SRC_include_PDMAsyncCompletionFileInternal_h
+#define VMM_INCLUDED_SRC_include_PDMAsyncCompletionFileInternal_h
+#ifndef RT_WITHOUT_PRAGMA_ONCE
+# pragma once
+#endif
+
+#include <VBox/vmm/cfgm.h>
+#include <VBox/vmm/stam.h>
+#include <VBox/vmm/tm.h>
+#include <iprt/types.h>
+#include <iprt/file.h>
+#include <iprt/thread.h>
+#include <iprt/semaphore.h>
+#include <iprt/critsect.h>
+#include <iprt/avl.h>
+#include <iprt/list.h>
+#include <iprt/spinlock.h>
+#include <iprt/memcache.h>
+
+#include "PDMAsyncCompletionInternal.h"
+
+/** @todo: Revise the caching of tasks. We have currently four caches:
+ * Per endpoint task cache
+ * Per class cache
+ * Per endpoint task segment cache
+ * Per class task segment cache
+ *
+ * We could use the RT heap for this probably or extend MMR3Heap (uses RTMemAlloc
+ * instead of managing larger blocks) to have this global for the whole VM.
+ */
+
+/** Enable for delay injection from the debugger. */
+#if 0
+# define PDM_ASYNC_COMPLETION_FILE_WITH_DELAY
+#endif
+
+RT_C_DECLS_BEGIN
+
+/**
+ * A few forward declarations.
+ */
+typedef struct PDMASYNCCOMPLETIONENDPOINTFILE *PPDMASYNCCOMPLETIONENDPOINTFILE;
+/** Pointer to a request segment. */
+typedef struct PDMACTASKFILE *PPDMACTASKFILE;
+/** Pointer to the endpoint class data. */
+typedef struct PDMASYNCCOMPLETIONTASKFILE *PPDMASYNCCOMPLETIONTASKFILE;
+/** Pointer to a cache LRU list. */
+typedef struct PDMACFILELRULIST *PPDMACFILELRULIST;
+/** Pointer to the global cache structure. */
+typedef struct PDMACFILECACHEGLOBAL *PPDMACFILECACHEGLOBAL;
+/** Pointer to a task segment. */
+typedef struct PDMACFILETASKSEG *PPDMACFILETASKSEG;
+
+/**
+ * Blocking event types.
+ */
+typedef enum PDMACEPFILEAIOMGRBLOCKINGEVENT
+{
+ /** Invalid tye */
+ PDMACEPFILEAIOMGRBLOCKINGEVENT_INVALID = 0,
+ /** An endpoint is added to the manager. */
+ PDMACEPFILEAIOMGRBLOCKINGEVENT_ADD_ENDPOINT,
+ /** An endpoint is removed from the manager. */
+ PDMACEPFILEAIOMGRBLOCKINGEVENT_REMOVE_ENDPOINT,
+ /** An endpoint is about to be closed. */
+ PDMACEPFILEAIOMGRBLOCKINGEVENT_CLOSE_ENDPOINT,
+ /** The manager is requested to terminate */
+ PDMACEPFILEAIOMGRBLOCKINGEVENT_SHUTDOWN,
+ /** The manager is requested to suspend */
+ PDMACEPFILEAIOMGRBLOCKINGEVENT_SUSPEND,
+ /** The manager is requested to resume */
+ PDMACEPFILEAIOMGRBLOCKINGEVENT_RESUME,
+ /** 32bit hack */
+ PDMACEPFILEAIOMGRBLOCKINGEVENT_32BIT_HACK = 0x7fffffff
+} PDMACEPFILEAIOMGRBLOCKINGEVENT;
+
+/**
+ * I/O manager type.
+ */
+typedef enum PDMACEPFILEMGRTYPE
+{
+ /** Simple aka failsafe */
+ PDMACEPFILEMGRTYPE_SIMPLE = 0,
+ /** Async I/O with host cache enabled. */
+ PDMACEPFILEMGRTYPE_ASYNC,
+ /** 32bit hack */
+ PDMACEPFILEMGRTYPE_32BIT_HACK = 0x7fffffff
+} PDMACEPFILEMGRTYPE;
+/** Pointer to a I/O manager type */
+typedef PDMACEPFILEMGRTYPE *PPDMACEPFILEMGRTYPE;
+
+/**
+ * States of the I/O manager.
+ */
+typedef enum PDMACEPFILEMGRSTATE
+{
+ /** Invalid state. */
+ PDMACEPFILEMGRSTATE_INVALID = 0,
+ /** Normal running state accepting new requests
+ * and processing them.
+ */
+ PDMACEPFILEMGRSTATE_RUNNING,
+ /** Fault state - not accepting new tasks for endpoints but waiting for
+ * remaining ones to finish.
+ */
+ PDMACEPFILEMGRSTATE_FAULT,
+ /** Suspending state - not accepting new tasks for endpoints but waiting
+ * for remaining ones to finish.
+ */
+ PDMACEPFILEMGRSTATE_SUSPENDING,
+ /** Shutdown state - not accepting new tasks for endpoints but waiting
+ * for remaining ones to finish.
+ */
+ PDMACEPFILEMGRSTATE_SHUTDOWN,
+ /** The I/O manager waits for all active requests to complete and doesn't queue
+ * new ones because it needs to grow to handle more requests.
+ */
+ PDMACEPFILEMGRSTATE_GROWING,
+ /** 32bit hack */
+ PDMACEPFILEMGRSTATE_32BIT_HACK = 0x7fffffff
+} PDMACEPFILEMGRSTATE;
+
+/**
+ * State of a async I/O manager.
+ */
+typedef struct PDMACEPFILEMGR
+{
+ /** Next Aio manager in the list. */
+ R3PTRTYPE(struct PDMACEPFILEMGR *) pNext;
+ /** Previous Aio manager in the list. */
+ R3PTRTYPE(struct PDMACEPFILEMGR *) pPrev;
+ /** Manager type */
+ PDMACEPFILEMGRTYPE enmMgrType;
+ /** Current state of the manager. */
+ PDMACEPFILEMGRSTATE enmState;
+ /** Event semaphore the manager sleeps on when waiting for new requests. */
+ RTSEMEVENT EventSem;
+ /** Flag whether the thread waits in the event semaphore. */
+ volatile bool fWaitingEventSem;
+ /** Thread data */
+ RTTHREAD Thread;
+ /** The async I/O context for this manager. */
+ RTFILEAIOCTX hAioCtx;
+ /** Flag whether the I/O manager was woken up. */
+ volatile bool fWokenUp;
+ /** List of endpoints assigned to this manager. */
+ R3PTRTYPE(PPDMASYNCCOMPLETIONENDPOINTFILE) pEndpointsHead;
+ /** Number of endpoints assigned to the manager. */
+ unsigned cEndpoints;
+ /** Number of requests active currently. */
+ unsigned cRequestsActive;
+ /** Number of maximum requests active. */
+ uint32_t cRequestsActiveMax;
+ /** Pointer to an array of free async I/O request handles. */
+ RTFILEAIOREQ *pahReqsFree;
+ /** Index of the next free entry in the cache. */
+ uint32_t iFreeEntry;
+ /** Size of the array. */
+ unsigned cReqEntries;
+ /** Memory cache for file range locks. */
+ RTMEMCACHE hMemCacheRangeLocks;
+ /** Number of milliseconds to wait until the bandwidth is refreshed for at least
+ * one endpoint and it is possible to process more requests. */
+ RTMSINTERVAL msBwLimitExpired;
+ /** Critical section protecting the blocking event handling. */
+ RTCRITSECT CritSectBlockingEvent;
+ /** Event semaphore for blocking external events.
+ * The caller waits on it until the async I/O manager
+ * finished processing the event. */
+ RTSEMEVENT EventSemBlock;
+ /** Flag whether a blocking event is pending and needs
+ * processing by the I/O manager. */
+ volatile bool fBlockingEventPending;
+ /** Blocking event type */
+ volatile PDMACEPFILEAIOMGRBLOCKINGEVENT enmBlockingEvent;
+ /** Event type data */
+ union
+ {
+ /** Add endpoint event. */
+ struct
+ {
+ /** The endpoint to be added */
+ volatile PPDMASYNCCOMPLETIONENDPOINTFILE pEndpoint;
+ } AddEndpoint;
+ /** Remove endpoint event. */
+ struct
+ {
+ /** The endpoint to be removed */
+ volatile PPDMASYNCCOMPLETIONENDPOINTFILE pEndpoint;
+ } RemoveEndpoint;
+ /** Close endpoint event. */
+ struct
+ {
+ /** The endpoint to be closed */
+ volatile PPDMASYNCCOMPLETIONENDPOINTFILE pEndpoint;
+ } CloseEndpoint;
+ } BlockingEventData;
+} PDMACEPFILEMGR;
+/** Pointer to a async I/O manager state. */
+typedef PDMACEPFILEMGR *PPDMACEPFILEMGR;
+/** Pointer to a async I/O manager state pointer. */
+typedef PPDMACEPFILEMGR *PPPDMACEPFILEMGR;
+
+/**
+ * A file access range lock.
+ */
+typedef struct PDMACFILERANGELOCK
+{
+ /** AVL node in the locked range tree of the endpoint. */
+ AVLRFOFFNODECORE Core;
+ /** How many tasks have locked this range. */
+ uint32_t cRefs;
+ /** Flag whether this is a read or write lock. */
+ bool fReadLock;
+ /** List of tasks which are waiting that the range gets unlocked. */
+ PPDMACTASKFILE pWaitingTasksHead;
+ /** List of tasks which are waiting that the range gets unlocked. */
+ PPDMACTASKFILE pWaitingTasksTail;
+} PDMACFILERANGELOCK, *PPDMACFILERANGELOCK;
+
+/**
+ * Backend type for the endpoint.
+ */
+typedef enum PDMACFILEEPBACKEND
+{
+ /** Non buffered. */
+ PDMACFILEEPBACKEND_NON_BUFFERED = 0,
+ /** Buffered (i.e host cache enabled) */
+ PDMACFILEEPBACKEND_BUFFERED,
+ /** 32bit hack */
+ PDMACFILEEPBACKEND_32BIT_HACK = 0x7fffffff
+} PDMACFILEEPBACKEND;
+/** Pointer to a backend type. */
+typedef PDMACFILEEPBACKEND *PPDMACFILEEPBACKEND;
+
+/**
+ * Global data for the file endpoint class.
+ */
+typedef struct PDMASYNCCOMPLETIONEPCLASSFILE
+{
+ /** Common data. */
+ PDMASYNCCOMPLETIONEPCLASS Core;
+ /** Override I/O manager type - set to SIMPLE after failure. */
+ PDMACEPFILEMGRTYPE enmMgrTypeOverride;
+ /** Default backend type for the endpoint. */
+ PDMACFILEEPBACKEND enmEpBackendDefault;
+ RTCRITSECT CritSect;
+ /** Pointer to the head of the async I/O managers. */
+ R3PTRTYPE(PPDMACEPFILEMGR) pAioMgrHead;
+ /** Number of async I/O managers currently running. */
+ unsigned cAioMgrs;
+ /** Maximum number of segments to cache per endpoint */
+ unsigned cTasksCacheMax;
+ /** Maximum number of simultaneous outstandingrequests. */
+ uint32_t cReqsOutstandingMax;
+ /** Bitmask for checking the alignment of a buffer. */
+ RTR3UINTPTR uBitmaskAlignment;
+ /** Flag whether the out of resources warning was printed already. */
+ bool fOutOfResourcesWarningPrinted;
+#ifdef PDM_ASYNC_COMPLETION_FILE_WITH_DELAY
+ /** Timer for delayed request completion. */
+ PTMTIMERR3 pTimer;
+ /** Milliseconds until the next delay expires. */
+ volatile uint64_t cMilliesNext;
+#endif
+} PDMASYNCCOMPLETIONEPCLASSFILE;
+/** Pointer to the endpoint class data. */
+typedef PDMASYNCCOMPLETIONEPCLASSFILE *PPDMASYNCCOMPLETIONEPCLASSFILE;
+
+typedef enum PDMACEPFILEBLOCKINGEVENT
+{
+ /** The invalid event type */
+ PDMACEPFILEBLOCKINGEVENT_INVALID = 0,
+ /** A task is about to be canceled */
+ PDMACEPFILEBLOCKINGEVENT_CANCEL,
+ /** Usual 32bit hack */
+ PDMACEPFILEBLOCKINGEVENT_32BIT_HACK = 0x7fffffff
+} PDMACEPFILEBLOCKINGEVENT;
+
+/**
+ * States of the endpoint.
+ */
+typedef enum PDMASYNCCOMPLETIONENDPOINTFILESTATE
+{
+ /** Invalid state. */
+ PDMASYNCCOMPLETIONENDPOINTFILESTATE_INVALID = 0,
+ /** Normal running state accepting new requests
+ * and processing them.
+ */
+ PDMASYNCCOMPLETIONENDPOINTFILESTATE_ACTIVE,
+ /** The endpoint is about to be closed - not accepting new tasks for endpoints but waiting for
+ * remaining ones to finish.
+ */
+ PDMASYNCCOMPLETIONENDPOINTFILESTATE_CLOSING,
+ /** Removing from current I/O manager state - not processing new tasks for endpoints but waiting
+ * for remaining ones to finish.
+ */
+ PDMASYNCCOMPLETIONENDPOINTFILESTATE_REMOVING,
+ /** The current endpoint will be migrated to another I/O manager. */
+ PDMASYNCCOMPLETIONENDPOINTFILESTATE_MIGRATING,
+ /** 32bit hack */
+ PDMASYNCCOMPLETIONENDPOINTFILESTATE_32BIT_HACK = 0x7fffffff
+} PDMASYNCCOMPLETIONENDPOINTFILESTATE;
+
+typedef enum PDMACFILEREQTYPEDELAY
+{
+ PDMACFILEREQTYPEDELAY_ANY = 0,
+ PDMACFILEREQTYPEDELAY_READ,
+ PDMACFILEREQTYPEDELAY_WRITE,
+ PDMACFILEREQTYPEDELAY_FLUSH,
+ PDMACFILEREQTYPEDELAY_32BIT_HACK = 0x7fffffff
+} PDMACFILEREQTYPEDELAY;
+
+/**
+ * Data for the file endpoint.
+ */
+typedef struct PDMASYNCCOMPLETIONENDPOINTFILE
+{
+ /** Common data. */
+ PDMASYNCCOMPLETIONENDPOINT Core;
+ /** Current state of the endpoint. */
+ PDMASYNCCOMPLETIONENDPOINTFILESTATE enmState;
+ /** The backend to use for this endpoint. */
+ PDMACFILEEPBACKEND enmBackendType;
+ /** async I/O manager this endpoint is assigned to. */
+ R3PTRTYPE(volatile PPDMACEPFILEMGR) pAioMgr;
+ /** Flags for opening the file. */
+ unsigned fFlags;
+ /** File handle. */
+ RTFILE hFile;
+ /** Real size of the file. Only updated if data is appended. */
+ volatile uint64_t cbFile;
+ /** List of new tasks. */
+ R3PTRTYPE(volatile PPDMACTASKFILE) pTasksNewHead;
+
+ /** Head of the small cache for allocated task segments for exclusive
+ * use by this endpoint. */
+ R3PTRTYPE(volatile PPDMACTASKFILE) pTasksFreeHead;
+ /** Tail of the small cache for allocated task segments for exclusive
+ * use by this endpoint. */
+ R3PTRTYPE(volatile PPDMACTASKFILE) pTasksFreeTail;
+ /** Number of elements in the cache. */
+ volatile uint32_t cTasksCached;
+
+ /** Flag whether a flush request is currently active */
+ PPDMACTASKFILE pFlushReq;
+
+#ifdef VBOX_WITH_STATISTICS
+ /** Time spend in a read. */
+ STAMPROFILEADV StatRead;
+ /** Time spend in a write. */
+ STAMPROFILEADV StatWrite;
+#endif
+
+ /** Event semaphore for blocking external events.
+ * The caller waits on it until the async I/O manager
+ * finished processing the event. */
+ RTSEMEVENT EventSemBlock;
+ /** Flag whether caching is enabled for this file. */
+ bool fCaching;
+ /** Flag whether the file was opened readonly. */
+ bool fReadonly;
+ /** Flag whether the host supports the async flush API. */
+ bool fAsyncFlushSupported;
+#ifdef VBOX_WITH_DEBUGGER
+ /** Status code to inject for the next complete read. */
+ volatile int rcReqRead;
+ /** Status code to inject for the next complete write. */
+ volatile int rcReqWrite;
+#endif
+#ifdef PDM_ASYNC_COMPLETION_FILE_WITH_DELAY
+ /** Request delay. */
+ volatile uint32_t msDelay;
+ /** Request delay jitter. */
+ volatile uint32_t msJitter;
+ /** Number of requests to delay. */
+ volatile uint32_t cReqsDelay;
+ /** Task type to delay. */
+ PDMACFILEREQTYPEDELAY enmTypeDelay;
+ /** The current task which gets delayed. */
+ PPDMASYNCCOMPLETIONTASKFILE pDelayedHead;
+#endif
+ /** Flag whether a blocking event is pending and needs
+ * processing by the I/O manager. */
+ bool fBlockingEventPending;
+ /** Blocking event type */
+ PDMACEPFILEBLOCKINGEVENT enmBlockingEvent;
+
+ /** Additional data needed for the event types. */
+ union
+ {
+ /** Cancelation event. */
+ struct
+ {
+ /** The task to cancel. */
+ PPDMACTASKFILE pTask;
+ } Cancel;
+ } BlockingEventData;
+ /** Data for exclusive use by the assigned async I/O manager. */
+ struct
+ {
+ /** Pointer to the next endpoint assigned to the manager. */
+ R3PTRTYPE(PPDMASYNCCOMPLETIONENDPOINTFILE) pEndpointNext;
+ /** Pointer to the previous endpoint assigned to the manager. */
+ R3PTRTYPE(PPDMASYNCCOMPLETIONENDPOINTFILE) pEndpointPrev;
+ /** List of pending requests (not submitted due to usage restrictions
+ * or a pending flush request) */
+ R3PTRTYPE(PPDMACTASKFILE) pReqsPendingHead;
+ /** Tail of pending requests. */
+ R3PTRTYPE(PPDMACTASKFILE) pReqsPendingTail;
+ /** Tree of currently locked ranges.
+ * If a write task is enqueued the range gets locked and any other
+ * task writing to that range has to wait until the task completes.
+ */
+ PAVLRFOFFTREE pTreeRangesLocked;
+ /** Number of requests with a range lock active. */
+ unsigned cLockedReqsActive;
+ /** Number of requests currently being processed for this endpoint
+ * (excluded flush requests). */
+ unsigned cRequestsActive;
+ /** Number of requests processed during the last second. */
+ unsigned cReqsPerSec;
+ /** Current number of processed requests for the current update period. */
+ unsigned cReqsProcessed;
+ /** Flag whether the endpoint is about to be moved to another manager. */
+ bool fMoving;
+ /** Destination I/O manager. */
+ PPDMACEPFILEMGR pAioMgrDst;
+ } AioMgr;
+} PDMASYNCCOMPLETIONENDPOINTFILE;
+/** Pointer to the endpoint class data. */
+typedef PDMASYNCCOMPLETIONENDPOINTFILE *PPDMASYNCCOMPLETIONENDPOINTFILE;
+#ifdef VBOX_WITH_STATISTICS
+AssertCompileMemberAlignment(PDMASYNCCOMPLETIONENDPOINTFILE, StatRead, sizeof(uint64_t));
+#endif
+
+/** Request completion function */
+typedef DECLCALLBACK(void) FNPDMACTASKCOMPLETED(PPDMACTASKFILE pTask, void *pvUser, int rc);
+/** Pointer to a request completion function. */
+typedef FNPDMACTASKCOMPLETED *PFNPDMACTASKCOMPLETED;
+
+/**
+ * Transfer type.
+ */
+typedef enum PDMACTASKFILETRANSFER
+{
+ /** Invalid. */
+ PDMACTASKFILETRANSFER_INVALID = 0,
+ /** Read transfer. */
+ PDMACTASKFILETRANSFER_READ,
+ /** Write transfer. */
+ PDMACTASKFILETRANSFER_WRITE,
+ /** Flush transfer. */
+ PDMACTASKFILETRANSFER_FLUSH
+} PDMACTASKFILETRANSFER;
+
+/**
+ * Data of a request.
+ */
+typedef struct PDMACTASKFILE
+{
+ /** Pointer to the range lock we are waiting for */
+ PPDMACFILERANGELOCK pRangeLock;
+ /** Next task in the list. (Depending on the state) */
+ struct PDMACTASKFILE *pNext;
+ /** Endpoint */
+ PPDMASYNCCOMPLETIONENDPOINTFILE pEndpoint;
+ /** Transfer type. */
+ PDMACTASKFILETRANSFER enmTransferType;
+ /** Start offset */
+ RTFOFF Off;
+ /** Amount of data transfered so far. */
+ size_t cbTransfered;
+ /** Data segment. */
+ RTSGSEG DataSeg;
+ /** When non-zero the segment uses a bounce buffer because the provided buffer
+ * doesn't meet host requirements. */
+ size_t cbBounceBuffer;
+ /** Pointer to the used bounce buffer if any. */
+ void *pvBounceBuffer;
+ /** Start offset in the bounce buffer to copy from. */
+ uint32_t offBounceBuffer;
+ /** Flag whether this is a prefetch request. */
+ bool fPrefetch;
+ /** Already prepared native I/O request.
+ * Used if the request is prepared already but
+ * was not queued because the host has not enough
+ * resources. */
+ RTFILEAIOREQ hReq;
+ /** Completion function to call on completion. */
+ PFNPDMACTASKCOMPLETED pfnCompleted;
+ /** User data */
+ void *pvUser;
+} PDMACTASKFILE;
+
+/**
+ * Per task data.
+ */
+typedef struct PDMASYNCCOMPLETIONTASKFILE
+{
+ /** Common data. */
+ PDMASYNCCOMPLETIONTASK Core;
+ /** Number of bytes to transfer until this task completes. */
+ volatile int32_t cbTransferLeft;
+ /** Flag whether the task completed. */
+ volatile bool fCompleted;
+ /** Return code. */
+ volatile int rc;
+#ifdef PDM_ASYNC_COMPLETION_FILE_WITH_DELAY
+ volatile PPDMASYNCCOMPLETIONTASKFILE pDelayedNext;
+ /** Timestamp when the delay expires. */
+ uint64_t tsDelayEnd;
+#endif
+} PDMASYNCCOMPLETIONTASKFILE;
+
+DECLCALLBACK(int) pdmacFileAioMgrFailsafe(RTTHREAD hThreadSelf, void *pvUser);
+DECLCALLBACK(int) pdmacFileAioMgrNormal(RTTHREAD hThreadSelf, void *pvUser);
+
+int pdmacFileAioMgrNormalInit(PPDMACEPFILEMGR pAioMgr);
+void pdmacFileAioMgrNormalDestroy(PPDMACEPFILEMGR pAioMgr);
+
+int pdmacFileAioMgrCreate(PPDMASYNCCOMPLETIONEPCLASSFILE pEpClass, PPPDMACEPFILEMGR ppAioMgr, PDMACEPFILEMGRTYPE enmMgrType);
+
+int pdmacFileAioMgrAddEndpoint(PPDMACEPFILEMGR pAioMgr, PPDMASYNCCOMPLETIONENDPOINTFILE pEndpoint);
+
+PPDMACTASKFILE pdmacFileEpGetNewTasks(PPDMASYNCCOMPLETIONENDPOINTFILE pEndpoint);
+PPDMACTASKFILE pdmacFileTaskAlloc(PPDMASYNCCOMPLETIONENDPOINTFILE pEndpoint);
+void pdmacFileTaskFree(PPDMASYNCCOMPLETIONENDPOINTFILE pEndpoint,
+ PPDMACTASKFILE pTask);
+
+int pdmacFileEpAddTask(PPDMASYNCCOMPLETIONENDPOINTFILE pEndpoint, PPDMACTASKFILE pTask);
+
+int pdmacFileCacheInit(PPDMASYNCCOMPLETIONEPCLASSFILE pClassFile, PCFGMNODE pCfgNode);
+void pdmacFileCacheDestroy(PPDMASYNCCOMPLETIONEPCLASSFILE pClassFile);
+int pdmacFileEpCacheInit(PPDMASYNCCOMPLETIONENDPOINTFILE pEndpoint, PPDMASYNCCOMPLETIONEPCLASSFILE pClassFile);
+void pdmacFileEpCacheDestroy(PPDMASYNCCOMPLETIONENDPOINTFILE pEndpoint);
+
+int pdmacFileEpCacheRead(PPDMASYNCCOMPLETIONENDPOINTFILE pEndpoint, PPDMASYNCCOMPLETIONTASKFILE pTask,
+ RTFOFF off, PCRTSGSEG paSegments, size_t cSegments,
+ size_t cbRead);
+int pdmacFileEpCacheWrite(PPDMASYNCCOMPLETIONENDPOINTFILE pEndpoint, PPDMASYNCCOMPLETIONTASKFILE pTask,
+ RTFOFF off, PCRTSGSEG paSegments, size_t cSegments,
+ size_t cbWrite);
+int pdmacFileEpCacheFlush(PPDMASYNCCOMPLETIONENDPOINTFILE pEndpoint);
+
+RT_C_DECLS_END
+
+#endif /* !VMM_INCLUDED_SRC_include_PDMAsyncCompletionFileInternal_h */
+