aboutsummaryrefslogtreecommitdiff
path: root/common
diff options
context:
space:
mode:
authorPaul Gilbert2012-05-29 21:51:10 +1000
committerPaul Gilbert2012-05-29 21:51:10 +1000
commit415831987d542e249ef9032fdab49bece24934fa (patch)
tree40e679e1f4f29aba2b3abbba8c11b3b7d96e6fb4 /common
parent5ba886ce8b3dc5b543d81e3f3a655b328749d778 (diff)
downloadscummvm-rg350-415831987d542e249ef9032fdab49bece24934fa.tar.gz
scummvm-rg350-415831987d542e249ef9032fdab49bece24934fa.tar.bz2
scummvm-rg350-415831987d542e249ef9032fdab49bece24934fa.zip
COMMON: Copied coroutine doxygen method descriptions to the header file
Diffstat (limited to 'common')
-rw-r--r--common/coroutines.h34
1 files changed, 32 insertions, 2 deletions
diff --git a/common/coroutines.h b/common/coroutines.h
index 06af245ba7..5daec4b426 100644
--- a/common/coroutines.h
+++ b/common/coroutines.h
@@ -356,7 +356,6 @@ private:
PROCESS *getProcess(uint32 pid);
EVENT *getEvent(uint32 pid);
public:
-
CoroutineScheduler();
~CoroutineScheduler();
@@ -366,31 +365,62 @@ public:
void printStats();
#endif
+ /** Give all active processes a chance to run */
void schedule();
+
+ /** Reschedules all the processes to run again this tick */
void rescheduleAll();
+
+ /** If the specified process has already run on this tick, make it run again on the current tick. */
void reschedule(PPROCESS pReSchedProc = NULL);
+
+ /** Moves the specified process to the end of the dispatch queue, so it can again in the current tick */
void giveWay(PPROCESS pReSchedProc = NULL);
+
+ /** Continously makes a given process wait for another process to finish or event to signal. */
void waitForSingleObject(CORO_PARAM, int pid, uint32 duration, bool *expired = NULL);
+
+ /** Continously makes a given process wait for given prcesses to finished or events to be set */
void waitForMultipleObjects(CORO_PARAM, int nCount, uint32 *pidList, bool bWaitAll,
uint32 duration, bool *expired = NULL);
- void sleep(CORO_PARAM, uint32 duration);
+ /** Make the active process sleep for the given duration in milliseconds */
+ void sleep(CORO_PARAM, uint32 duration);
+
+ /** Creates a new process. */
PROCESS *createProcess(uint32 pid, CORO_ADDR coroAddr, const void *pParam, int sizeParam);
uint32 createProcess(CORO_ADDR coroAddr, const void *pParam, int sizeParam);
uint32 createProcess(CORO_ADDR coroAddr, const void *pParam);
+
+ /** Kills the specified process. */
void killProcess(PROCESS *pKillProc);
+ /** Returns a pointer to the currently running process. */
PROCESS *getCurrentProcess();
+
+ /** Returns the process identifier of the specified process. */
int getCurrentPID() const;
+
+ /** Kills any process matching the specified PID. The current process cannot be killed. */
int killMatchingProcess(uint32 pidKill, int pidMask = -1);
+ /** Set pointer to a function to be called by killProcess() */
void setResourceCallback(VFPTRPP pFunc);
/* Event methods */
+ /** Creates a new event (semaphore) object */
uint32 createEvent(bool bManualReset, bool bInitialState);
+
+ /** Destroys the given event */
void closeEvent(uint32 pidEvent);
+
+ /** Sets the event */
void setEvent(uint32 pidEvent);
+
+ /** Resets the event */
void resetEvent(uint32 pidEvent);
+
+ /** Temporarily sets a given event to true, allowing other waiting processes to fire */
void pulseEvent(uint32 pidEvent);
};