mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-08 05:24:12 +08:00
mdbx-windows: more for WindowsXP support.
Change-Id: Ide34048720989fc010f48e086569e12e8c1edca1
This commit is contained in:
parent
83f3d820f1
commit
c9e3dc373b
@ -137,6 +137,15 @@ typedef struct _FILE_PROVIDER_EXTERNAL_INFO_V1 {
|
|||||||
#define STATUS_INVALID_DEVICE_REQUEST ((NTSTATUS)0xC0000010L)
|
#define STATUS_INVALID_DEVICE_REQUEST ((NTSTATUS)0xC0000010L)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef FILE_DEVICE_FILE_SYSTEM
|
||||||
|
#define FILE_DEVICE_FILE_SYSTEM 0x00000009
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef FSCTL_GET_EXTERNAL_BACKING
|
||||||
|
#define FSCTL_GET_EXTERNAL_BACKING \
|
||||||
|
CTL_CODE(FILE_DEVICE_FILE_SYSTEM, 196, METHOD_BUFFERED, FILE_ANY_ACCESS)
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif /* _WIN32 || _WIN64 */
|
#endif /* _WIN32 || _WIN64 */
|
||||||
|
|
||||||
/*----------------------------------------------------------------------------*/
|
/*----------------------------------------------------------------------------*/
|
||||||
|
@ -649,7 +649,7 @@ static __inline uint32_t mdbx_atomic_add32(volatile uint32_t *p, uint32_t v) {
|
|||||||
return __sync_fetch_and_add(p, v);
|
return __sync_fetch_and_add(p, v);
|
||||||
#else
|
#else
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
return _InterlockedExchangeAdd(p, v);
|
return _InterlockedExchangeAdd((volatile long *)p, v);
|
||||||
#endif
|
#endif
|
||||||
#ifdef __APPLE__
|
#ifdef __APPLE__
|
||||||
return OSAtomicAdd32(v, (volatile int32_t *)p);
|
return OSAtomicAdd32(v, (volatile int32_t *)p);
|
||||||
@ -689,7 +689,7 @@ static __inline bool mdbx_atomic_compare_and_swap32(volatile uint32_t *p,
|
|||||||
return __sync_bool_compare_and_swap(p, c, v);
|
return __sync_bool_compare_and_swap(p, c, v);
|
||||||
#else
|
#else
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
return c == _InterlockedCompareExchange(p, v, c);
|
return c == _InterlockedCompareExchange((volatile long *)p, v, c);
|
||||||
#endif
|
#endif
|
||||||
#ifdef __APPLE__
|
#ifdef __APPLE__
|
||||||
return c == OSAtomicCompareAndSwap32Barrier(c, v, (volatile int32_t *)p);
|
return c == OSAtomicCompareAndSwap32Barrier(c, v, (volatile int32_t *)p);
|
||||||
|
@ -55,7 +55,7 @@ char *optarg;
|
|||||||
int getopt(int argc, char *const argv[], const char *opts) {
|
int getopt(int argc, char *const argv[], const char *opts) {
|
||||||
static int sp = 1;
|
static int sp = 1;
|
||||||
int c;
|
int c;
|
||||||
char *cp;
|
const char *cp;
|
||||||
|
|
||||||
if (sp == 1) {
|
if (sp == 1) {
|
||||||
if (optind >= argc || argv[optind][0] != '-' || argv[optind][1] == '\0')
|
if (optind >= argc || argv[optind][0] != '-' || argv[optind][1] == '\0')
|
||||||
|
Loading…
x
Reference in New Issue
Block a user