mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-08 04:34:12 +08:00
mdbx: add mdbx_fastmutex_t.
This commit is contained in:
parent
8c18622592
commit
132c9c994e
38
src/osal.c
38
src/osal.c
@ -267,6 +267,44 @@ int mdbx_condmutex_wait(mdbx_condmutex_t *condmutex) {
|
|||||||
|
|
||||||
/*----------------------------------------------------------------------------*/
|
/*----------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
int mdbx_fastmutex_init(mdbx_fastmutex_t *fastmutex) {
|
||||||
|
#if defined(_WIN32) || defined(_WIN64)
|
||||||
|
InitializeCriticalSection(fastmutex);
|
||||||
|
return MDB_SUCCESS;
|
||||||
|
#else
|
||||||
|
return pthread_mutex_init(fastmutex, NULL);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
int mdbx_fastmutex_destroy(mdbx_fastmutex_t *fastmutex) {
|
||||||
|
#if defined(_WIN32) || defined(_WIN64)
|
||||||
|
DeleteCriticalSection(fastmutex);
|
||||||
|
return MDB_SUCCESS;
|
||||||
|
#else
|
||||||
|
return pthread_mutex_destroy(fastmutex);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
int mdbx_fastmutex_acquire(mdbx_fastmutex_t *fastmutex) {
|
||||||
|
#if defined(_WIN32) || defined(_WIN64)
|
||||||
|
EnterCriticalSection(fastmutex);
|
||||||
|
return MDB_SUCCESS;
|
||||||
|
#else
|
||||||
|
return pthread_mutex_lock(fastmutex);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
int mdbx_fastmutex_release(mdbx_fastmutex_t *fastmutex) {
|
||||||
|
#if defined(_WIN32) || defined(_WIN64)
|
||||||
|
LeaveCriticalSection(fastmutex);
|
||||||
|
return MDB_SUCCESS;
|
||||||
|
#else
|
||||||
|
return pthread_mutex_unlock(fastmutex);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/*----------------------------------------------------------------------------*/
|
||||||
|
|
||||||
int mdbx_openfile(const char *pathname, int flags, mode_t mode,
|
int mdbx_openfile(const char *pathname, int flags, mode_t mode,
|
||||||
mdbx_filehandle_t *fd) {
|
mdbx_filehandle_t *fd) {
|
||||||
*fd = INVALID_HANDLE_VALUE;
|
*fd = INVALID_HANDLE_VALUE;
|
||||||
|
@ -68,6 +68,7 @@ typedef struct {
|
|||||||
HANDLE mutex;
|
HANDLE mutex;
|
||||||
HANDLE event;
|
HANDLE event;
|
||||||
} mdbx_condmutex_t;
|
} mdbx_condmutex_t;
|
||||||
|
typedef CRITICAL_SECTION mdbx_fastmutex_t;
|
||||||
#else
|
#else
|
||||||
#include <pthread.h>
|
#include <pthread.h>
|
||||||
#include <sys/file.h>
|
#include <sys/file.h>
|
||||||
@ -85,6 +86,7 @@ typedef struct {
|
|||||||
pthread_mutex_t mutex;
|
pthread_mutex_t mutex;
|
||||||
pthread_cond_t cond;
|
pthread_cond_t cond;
|
||||||
} mdbx_condmutex_t;
|
} mdbx_condmutex_t;
|
||||||
|
typedef pthread_mutex_t mdbx_fastmutex_t;
|
||||||
#endif /* Platform */
|
#endif /* Platform */
|
||||||
|
|
||||||
#ifndef SSIZE_MAX
|
#ifndef SSIZE_MAX
|
||||||
@ -395,6 +397,11 @@ int mdbx_condmutex_signal(mdbx_condmutex_t *condmutex);
|
|||||||
int mdbx_condmutex_wait(mdbx_condmutex_t *condmutex);
|
int mdbx_condmutex_wait(mdbx_condmutex_t *condmutex);
|
||||||
int mdbx_condmutex_destroy(mdbx_condmutex_t *condmutex);
|
int mdbx_condmutex_destroy(mdbx_condmutex_t *condmutex);
|
||||||
|
|
||||||
|
int mdbx_fastmutex_init(mdbx_fastmutex_t *fastmutex);
|
||||||
|
int mdbx_fastmutex_acquire(mdbx_fastmutex_t *fastmutex);
|
||||||
|
int mdbx_fastmutex_release(mdbx_fastmutex_t *fastmutex);
|
||||||
|
int mdbx_fastmutex_destroy(mdbx_fastmutex_t *fastmutex);
|
||||||
|
|
||||||
int mdbx_pwritev(mdbx_filehandle_t fd, struct iovec *iov, int iovcnt,
|
int mdbx_pwritev(mdbx_filehandle_t fd, struct iovec *iov, int iovcnt,
|
||||||
off_t offset, size_t expected_written);
|
off_t offset, size_t expected_written);
|
||||||
int mdbx_pread(mdbx_filehandle_t fd, void *buf, size_t count, off_t offset);
|
int mdbx_pread(mdbx_filehandle_t fd, void *buf, size_t count, off_t offset);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user