2016-01-07 12:07:13 +00:00
|
|
|
#pragma once
|
|
|
|
#include <wut.h>
|
|
|
|
#include "threadqueue.h"
|
|
|
|
|
2016-01-07 05:02:17 -08:00
|
|
|
WUT_LIB_HEADER_START
|
2016-01-07 12:07:13 +00:00
|
|
|
|
2016-01-07 04:45:18 -08:00
|
|
|
typedef struct OSThread;
|
2016-01-07 12:07:13 +00:00
|
|
|
|
|
|
|
typedef struct OSCondition OSCondition;
|
|
|
|
typedef struct OSMutex OSMutex;
|
|
|
|
typedef struct OSMutexLink OSMutexLink;
|
|
|
|
|
|
|
|
struct OSMutexLink
|
|
|
|
{
|
|
|
|
OSMutex *next;
|
|
|
|
OSMutex *prev;
|
|
|
|
};
|
|
|
|
CHECK_OFFSET(OSMutexLink, 0x00, next);
|
|
|
|
CHECK_OFFSET(OSMutexLink, 0x04, prev);
|
|
|
|
CHECK_SIZE(OSMutexLink, 0x8);
|
|
|
|
|
2016-01-07 04:44:44 -08:00
|
|
|
#define OS_MUTEX_TAG 0x6D557458u
|
|
|
|
|
2016-01-07 12:07:13 +00:00
|
|
|
struct OSMutex
|
|
|
|
{
|
|
|
|
// OSMutex::Tag
|
|
|
|
uint32_t tag;
|
|
|
|
|
|
|
|
// Name set by OSInitMutexEx(mutex, name)
|
|
|
|
const char *name;
|
|
|
|
UNKNOWN(4);
|
|
|
|
|
|
|
|
// Queue of threads waiting for this mutex to unlock
|
|
|
|
OSThreadQueue queue;
|
|
|
|
|
|
|
|
// Current owner of mutex
|
|
|
|
OSThread *owner;
|
|
|
|
|
|
|
|
// Current recursion lock count of mutex
|
|
|
|
int32_t count;
|
|
|
|
|
|
|
|
// Link used inside OSThread's mutex queue
|
|
|
|
OSMutexLink link;
|
|
|
|
};
|
|
|
|
CHECK_OFFSET(OSMutex, 0x00, tag);
|
|
|
|
CHECK_OFFSET(OSMutex, 0x04, name);
|
|
|
|
CHECK_OFFSET(OSMutex, 0x0c, queue);
|
|
|
|
CHECK_OFFSET(OSMutex, 0x1c, owner);
|
|
|
|
CHECK_OFFSET(OSMutex, 0x20, count);
|
|
|
|
CHECK_OFFSET(OSMutex, 0x24, link);
|
|
|
|
CHECK_SIZE(OSMutex, 0x2c);
|
|
|
|
|
|
|
|
void
|
|
|
|
OSInitMutex(OSMutex *mutex);
|
|
|
|
|
|
|
|
void
|
|
|
|
OSInitMutexEx(OSMutex *mutex,
|
|
|
|
const char *name);
|
|
|
|
|
|
|
|
void
|
|
|
|
OSLockMutex(OSMutex *mutex);
|
|
|
|
|
|
|
|
void
|
|
|
|
OSUnlockMutex(OSMutex *mutex);
|
|
|
|
|
|
|
|
BOOL
|
|
|
|
OSTryLockMutex(OSMutex *mutex);
|
|
|
|
|
2016-01-07 05:02:17 -08:00
|
|
|
WUT_LIB_HEADER_END
|