forked from KolibriOS/kolibrios
libsupc++ Makefile
git-svn-id: svn://kolibrios.org@6556 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
b6f602747e
commit
3c17dd1ccd
@ -35,13 +35,13 @@ cxx98_sources = \
|
|||||||
src/c++98/compatibility-debug_list-2.cc
|
src/c++98/compatibility-debug_list-2.cc
|
||||||
|
|
||||||
cxx11_sources = \
|
cxx11_sources = \
|
||||||
compatibility-c++0x.cc \
|
src/c++11/compatibility-c++0x.cc \
|
||||||
compatibility-atomic-c++0x.cc \
|
src/c++11/compatibility-atomic-c++0x.cc \
|
||||||
compatibility-thread-c++0x.cc \
|
src/c++11/compatibility-thread-c++0x.cc \
|
||||||
compatibility-chrono.cc \
|
src/c++11/compatibility-chrono.cc \
|
||||||
compatibility-condvar.cc
|
src/c++11/compatibility-condvar.cc
|
||||||
|
|
||||||
compat_sources = $(cxx98_sources)
|
compat_sources = $(cxx98_sources) $(cxx11_sources)
|
||||||
|
|
||||||
cow_string_host_sources = \
|
cow_string_host_sources = \
|
||||||
src/c++98/collate_members_cow.cc \
|
src/c++98/collate_members_cow.cc \
|
||||||
@ -244,7 +244,19 @@ src/c++98/parallel_settings.o: src/c++98/parallel_settings.cc
|
|||||||
|
|
||||||
|
|
||||||
src/c++11/hashtable_c++0x.o: src/c++11/hashtable_c++0x.cc
|
src/c++11/hashtable_c++0x.o: src/c++11/hashtable_c++0x.cc
|
||||||
$(CXXCOMPILE) -fimplicit-templates -o $@ $<
|
$(CXXCOMPILE) -std=gnu++11 -fimplicit-templates -o $@ $<
|
||||||
|
|
||||||
|
src/c++11/compatibility-c++0x.o: src/c++11/compatibility-c++0x.cc
|
||||||
|
$(CXXCOMPILE) -std=gnu++11 -o $@ $<
|
||||||
|
|
||||||
|
src/c++11/compatibility-thread-c++0x.o: src/c++11/compatibility-thread-c++0x.cc
|
||||||
|
$(CXXCOMPILE) -std=gnu++11 -o $@ $<
|
||||||
|
|
||||||
|
src/c++11/compatibility-chrono.o: src/c++11/compatibility-chrono.cc
|
||||||
|
$(CXXCOMPILE) -std=gnu++11 -o $@ $<
|
||||||
|
|
||||||
|
src/c++11/compatibility-condvar.o: src/c++11/compatibility-condvar.cc
|
||||||
|
$(CXXCOMPILE) -std=gnu++11 -o $@ $<
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
-rm -f *.o
|
-rm -f *.o
|
||||||
|
@ -6,32 +6,45 @@ LD = kos32-ld
|
|||||||
CPP= kos32-g++
|
CPP= kos32-g++
|
||||||
STRIP = kos32-strip
|
STRIP = kos32-strip
|
||||||
|
|
||||||
|
INSTALLDIR:= /home/autobuild/tools/win32/mingw32/lib
|
||||||
|
|
||||||
|
export SDK_DIR:= $(abspath ../../../../../sdk)
|
||||||
|
|
||||||
CFLAGS = -U_Win32 -U_WIN32 -U__MINGW32__ -c -O2 -fno-ident -fomit-frame-pointer
|
CFLAGS = -U_Win32 -U_WIN32 -U__MINGW32__ -c -O2 -fno-ident -fomit-frame-pointer
|
||||||
CPPFLAGS = -fno-rtti
|
CFLAGSCPP = -nostdinc++ -fno-implicit-templates -Wall -Wextra -Wwrite-strings -Wcast-qual -Wabi
|
||||||
|
CFLAGSCPP+= -fdiagnostics-show-location=once -ffunction-sections -fdata-sections
|
||||||
|
|
||||||
ARFLAGS= crs
|
ARFLAGS= crs
|
||||||
|
|
||||||
INCLUDES= -I. -I../include/mingw32 -I../include -I../../newlib/libc/include -I/home/autobuild/tools/win32/include
|
GLIBCXX_INCLUDE_DIR= ../include
|
||||||
|
INCLUDES= -I../include/mingw32 -I../include -I./ -I$(SDK_DIR)/sources/newlib/libc/include
|
||||||
|
|
||||||
LIBS:= -ldll -lc.dll
|
DEFINES= -D_GLIBCXX_HAVE_TLS
|
||||||
|
|
||||||
DEFINES= -DHAVE_CONFIG_H -DIN_GCC -DIN_GLIBCPP_V3 -DUSE_EMUTLS=1 -D_GLIBCXX_HAVE_TLS
|
C_COMPILE= $(CC) $(CFLAGS) $(DEFINES) $(INCLUDES)
|
||||||
|
CXXCOMPILE= $(CPP) $(CFLAGS) $(CFLAGSCPP) $(INCLUDES) $(DEFINES)
|
||||||
|
|
||||||
|
|
||||||
SOURCES = \
|
SOURCES = \
|
||||||
cp-demangle.c \
|
cp-demangle.c \
|
||||||
array_type_info.cc \
|
array_type_info.cc \
|
||||||
|
atexit_arm.cc \
|
||||||
atexit_thread.cc \
|
atexit_thread.cc \
|
||||||
bad_alloc.cc \
|
bad_alloc.cc \
|
||||||
|
bad_array_length.cc \
|
||||||
|
bad_array_new.cc \
|
||||||
bad_cast.cc \
|
bad_cast.cc \
|
||||||
bad_typeid.cc \
|
bad_typeid.cc \
|
||||||
class_type_info.cc \
|
class_type_info.cc \
|
||||||
del_op.cc \
|
del_op.cc \
|
||||||
|
del_ops.cc \
|
||||||
del_opnt.cc \
|
del_opnt.cc \
|
||||||
del_opv.cc \
|
del_opv.cc \
|
||||||
|
del_opvs.cc \
|
||||||
del_opvnt.cc \
|
del_opvnt.cc \
|
||||||
dyncast.cc \
|
dyncast.cc \
|
||||||
eh_alloc.cc \
|
eh_alloc.cc \
|
||||||
|
eh_arm.cc \
|
||||||
eh_aux_runtime.cc \
|
eh_aux_runtime.cc \
|
||||||
eh_call.cc \
|
eh_call.cc \
|
||||||
eh_catch.cc \
|
eh_catch.cc \
|
||||||
@ -41,9 +54,9 @@ SOURCES = \
|
|||||||
eh_ptr.cc \
|
eh_ptr.cc \
|
||||||
eh_term_handler.cc \
|
eh_term_handler.cc \
|
||||||
eh_terminate.cc \
|
eh_terminate.cc \
|
||||||
eh_throw.cc \
|
|
||||||
eh_tm.cc \
|
eh_tm.cc \
|
||||||
eh_type.c \
|
eh_throw.cc \
|
||||||
|
eh_type.cc \
|
||||||
eh_unex_handler.cc \
|
eh_unex_handler.cc \
|
||||||
enum_type_info.cc \
|
enum_type_info.cc \
|
||||||
function_type_info.cc \
|
function_type_info.cc \
|
||||||
@ -77,28 +90,59 @@ all:$(LIBRARY).a
|
|||||||
|
|
||||||
$(LIBRARY).a: $(OBJECTS) Makefile
|
$(LIBRARY).a: $(OBJECTS) Makefile
|
||||||
$(AR) $(ARFLAGS) $(LIBRARY).a $(OBJECTS)
|
$(AR) $(ARFLAGS) $(LIBRARY).a $(OBJECTS)
|
||||||
mv -f $(LIBRARY).a ../../../lib
|
mv -f $(LIBRARY).a $(INSTALLDIR)
|
||||||
|
|
||||||
|
|
||||||
%.o : %.c Makefile
|
|
||||||
$(CC) $(CFLAGS) $(DEFINES) $(INCLUDES) -o $@ $<
|
|
||||||
|
|
||||||
%.o : %.cc Makefile
|
%.o : %.cc Makefile
|
||||||
$(CPP) $(CFLAGS) $(CPPFLAGS) $(DEFINES) $(INCLUDES) -o $@ $<
|
$(CXXCOMPILE) -o $@ $<
|
||||||
|
|
||||||
|
|
||||||
|
cp-demangle.o: cp-demangle.c
|
||||||
|
$(C_COMPILE) -DHAVE_CONFIG_H -D_USE_32BIT_TIME_T -DIN_GLIBCPP_V3 -Wno-error -o $@ $<
|
||||||
|
|
||||||
|
bad_array_length.o: bad_array_length.cc
|
||||||
|
$(CXXCOMPILE) -std=gnu++11 -o $@ $<
|
||||||
|
|
||||||
|
bad_array_new.o: bad_array_new.cc
|
||||||
|
$(CXXCOMPILE) -std=gnu++11 -o $@ $<
|
||||||
|
|
||||||
|
eh_aux_runtime.o: eh_aux_runtime.cc
|
||||||
|
$(CXXCOMPILE) -std=gnu++11 -o $@ $<
|
||||||
|
|
||||||
eh_ptr.o: eh_ptr.cc
|
eh_ptr.o: eh_ptr.cc
|
||||||
$(CPP) $(CFLAGS) -std=gnu++0x $(CPPFLAGS) $(DEFINES) $(INCLUDES) -o $@ $<
|
$(CXXCOMPILE) -std=gnu++11 -o $@ $<
|
||||||
|
|
||||||
|
eh_terminate.o: eh_terminate.cc
|
||||||
|
$(CXXCOMPILE) -std=gnu++11 -o $@ $<
|
||||||
|
|
||||||
eh_throw.o: eh_throw.cc
|
eh_throw.o: eh_throw.cc
|
||||||
$(CPP) $(CFLAGS) -std=gnu++0x $(CPPFLAGS) $(DEFINES) $(INCLUDES) -o $@ $<
|
$(CXXCOMPILE) -std=gnu++11 -o $@ $<
|
||||||
|
|
||||||
guard.o: guard.cc
|
guard.o: guard.cc
|
||||||
$(CPP) $(CFLAGS) -std=gnu++0x $(CPPFLAGS) $(DEFINES) $(INCLUDES) -o $@ $<
|
$(CXXCOMPILE) -std=gnu++11 -o $@ $<
|
||||||
|
|
||||||
atexit_thread.o: atexit_thread.cc
|
atexit_thread.o: atexit_thread.cc
|
||||||
$(CPP) $(CFLAGS) -std=gnu++0x $(CPPFLAGS) $(DEFINES) $(INCLUDES) -o $@ $<
|
$(CXXCOMPILE) -std=gnu++11 -o $@ $<
|
||||||
|
|
||||||
nested_exception.o: nested_exception.cc
|
nested_exception.o: nested_exception.cc
|
||||||
$(CPP) $(CFLAGS) -std=gnu++0x $(CPPFLAGS) $(DEFINES) $(INCLUDES) -o $@ $<
|
$(CXXCOMPILE) -std=gnu++11 -o $@ $<
|
||||||
|
|
||||||
|
new_handler.o: new_handler.cc
|
||||||
|
$(CXXCOMPILE) -std=gnu++11 -o $@ $<
|
||||||
|
|
||||||
|
new_op.o: new_op.cc
|
||||||
|
$(CXXCOMPILE) -std=gnu++11 -o $@ $<
|
||||||
|
|
||||||
|
new_opnt.o: new_opnt.cc
|
||||||
|
$(CXXCOMPILE) -std=gnu++11 -o $@ $<
|
||||||
|
|
||||||
|
del_ops.o: del_ops.cc
|
||||||
|
$(CXXCOMPILE) -std=gnu++14 -o $@ $<
|
||||||
|
|
||||||
|
del_opvs.o: del_opvs.cc
|
||||||
|
$(CXXCOMPILE) -std=gnu++14 -o $@ $<
|
||||||
|
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
-rm -f *.o
|
-rm -f *.o
|
||||||
|
@ -122,6 +122,11 @@ struct d_info
|
|||||||
mangled name to the demangled name, such as standard
|
mangled name to the demangled name, such as standard
|
||||||
substitutions and builtin types. */
|
substitutions and builtin types. */
|
||||||
int expansion;
|
int expansion;
|
||||||
|
/* Non-zero if we are parsing an expression. */
|
||||||
|
int is_expression;
|
||||||
|
/* Non-zero if we are parsing the type operand of a conversion
|
||||||
|
operator, but not when in an expression. */
|
||||||
|
int is_conversion;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* To avoid running past the ending '\0', don't:
|
/* To avoid running past the ending '\0', don't:
|
||||||
|
@ -63,9 +63,10 @@ extern "C" {
|
|||||||
#define DMGL_EDG (1 << 13)
|
#define DMGL_EDG (1 << 13)
|
||||||
#define DMGL_GNU_V3 (1 << 14)
|
#define DMGL_GNU_V3 (1 << 14)
|
||||||
#define DMGL_GNAT (1 << 15)
|
#define DMGL_GNAT (1 << 15)
|
||||||
|
#define DMGL_DLANG (1 << 16)
|
||||||
|
|
||||||
/* If none of these are set, use 'current_demangling_style' as the default. */
|
/* If none of these are set, use 'current_demangling_style' as the default. */
|
||||||
#define DMGL_STYLE_MASK (DMGL_AUTO|DMGL_GNU|DMGL_LUCID|DMGL_ARM|DMGL_HP|DMGL_EDG|DMGL_GNU_V3|DMGL_JAVA|DMGL_GNAT)
|
#define DMGL_STYLE_MASK (DMGL_AUTO|DMGL_GNU|DMGL_LUCID|DMGL_ARM|DMGL_HP|DMGL_EDG|DMGL_GNU_V3|DMGL_JAVA|DMGL_GNAT|DMGL_DLANG)
|
||||||
|
|
||||||
/* Enumeration of possible demangling styles.
|
/* Enumeration of possible demangling styles.
|
||||||
|
|
||||||
@ -87,7 +88,8 @@ extern enum demangling_styles
|
|||||||
edg_demangling = DMGL_EDG,
|
edg_demangling = DMGL_EDG,
|
||||||
gnu_v3_demangling = DMGL_GNU_V3,
|
gnu_v3_demangling = DMGL_GNU_V3,
|
||||||
java_demangling = DMGL_JAVA,
|
java_demangling = DMGL_JAVA,
|
||||||
gnat_demangling = DMGL_GNAT
|
gnat_demangling = DMGL_GNAT,
|
||||||
|
dlang_demangling = DMGL_DLANG
|
||||||
} current_demangling_style;
|
} current_demangling_style;
|
||||||
|
|
||||||
/* Define string names for the various demangling styles. */
|
/* Define string names for the various demangling styles. */
|
||||||
@ -102,6 +104,7 @@ extern enum demangling_styles
|
|||||||
#define GNU_V3_DEMANGLING_STYLE_STRING "gnu-v3"
|
#define GNU_V3_DEMANGLING_STYLE_STRING "gnu-v3"
|
||||||
#define JAVA_DEMANGLING_STYLE_STRING "java"
|
#define JAVA_DEMANGLING_STYLE_STRING "java"
|
||||||
#define GNAT_DEMANGLING_STYLE_STRING "gnat"
|
#define GNAT_DEMANGLING_STYLE_STRING "gnat"
|
||||||
|
#define DLANG_DEMANGLING_STYLE_STRING "dlang"
|
||||||
|
|
||||||
/* Some macros to test what demangling style is active. */
|
/* Some macros to test what demangling style is active. */
|
||||||
|
|
||||||
@ -115,6 +118,7 @@ extern enum demangling_styles
|
|||||||
#define GNU_V3_DEMANGLING (((int) CURRENT_DEMANGLING_STYLE) & DMGL_GNU_V3)
|
#define GNU_V3_DEMANGLING (((int) CURRENT_DEMANGLING_STYLE) & DMGL_GNU_V3)
|
||||||
#define JAVA_DEMANGLING (((int) CURRENT_DEMANGLING_STYLE) & DMGL_JAVA)
|
#define JAVA_DEMANGLING (((int) CURRENT_DEMANGLING_STYLE) & DMGL_JAVA)
|
||||||
#define GNAT_DEMANGLING (((int) CURRENT_DEMANGLING_STYLE) & DMGL_GNAT)
|
#define GNAT_DEMANGLING (((int) CURRENT_DEMANGLING_STYLE) & DMGL_GNAT)
|
||||||
|
#define DLANG_DEMANGLING (((int) CURRENT_DEMANGLING_STYLE) & DMGL_DLANG)
|
||||||
|
|
||||||
/* Provide information about the available demangle styles. This code is
|
/* Provide information about the available demangle styles. This code is
|
||||||
pulled from gdb into libiberty because it is useful to binutils also. */
|
pulled from gdb into libiberty because it is useful to binutils also. */
|
||||||
@ -169,10 +173,17 @@ java_demangle_v3 (const char *mangled);
|
|||||||
char *
|
char *
|
||||||
ada_demangle (const char *mangled, int options);
|
ada_demangle (const char *mangled, int options);
|
||||||
|
|
||||||
|
extern char *
|
||||||
|
dlang_demangle (const char *mangled, int options);
|
||||||
|
|
||||||
enum gnu_v3_ctor_kinds {
|
enum gnu_v3_ctor_kinds {
|
||||||
gnu_v3_complete_object_ctor = 1,
|
gnu_v3_complete_object_ctor = 1,
|
||||||
gnu_v3_base_object_ctor,
|
gnu_v3_base_object_ctor,
|
||||||
gnu_v3_complete_object_allocating_ctor,
|
gnu_v3_complete_object_allocating_ctor,
|
||||||
|
/* These are not part of the V3 ABI. Unified constructors are generated
|
||||||
|
as a speed-for-space optimization when the -fdeclone-ctor-dtor option
|
||||||
|
is used, and are always internal symbols. */
|
||||||
|
gnu_v3_unified_ctor,
|
||||||
gnu_v3_object_ctor_group
|
gnu_v3_object_ctor_group
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -188,6 +199,10 @@ enum gnu_v3_dtor_kinds {
|
|||||||
gnu_v3_deleting_dtor = 1,
|
gnu_v3_deleting_dtor = 1,
|
||||||
gnu_v3_complete_object_dtor,
|
gnu_v3_complete_object_dtor,
|
||||||
gnu_v3_base_object_dtor,
|
gnu_v3_base_object_dtor,
|
||||||
|
/* These are not part of the V3 ABI. Unified destructors are generated
|
||||||
|
as a speed-for-space optimization when the -fdeclone-ctor-dtor option
|
||||||
|
is used, and are always internal symbols. */
|
||||||
|
gnu_v3_unified_dtor,
|
||||||
gnu_v3_object_dtor_group
|
gnu_v3_object_dtor_group
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -365,6 +380,10 @@ enum demangle_component_type
|
|||||||
/* A typecast, represented as a unary operator. The one subtree is
|
/* A typecast, represented as a unary operator. The one subtree is
|
||||||
the type to which the argument should be cast. */
|
the type to which the argument should be cast. */
|
||||||
DEMANGLE_COMPONENT_CAST,
|
DEMANGLE_COMPONENT_CAST,
|
||||||
|
/* A conversion operator, represented as a unary operator. The one
|
||||||
|
subtree is the type to which the argument should be converted
|
||||||
|
to. */
|
||||||
|
DEMANGLE_COMPONENT_CONVERSION,
|
||||||
/* A nullary expression. The left subtree is the operator. */
|
/* A nullary expression. The left subtree is the operator. */
|
||||||
DEMANGLE_COMPONENT_NULLARY,
|
DEMANGLE_COMPONENT_NULLARY,
|
||||||
/* A unary expression. The left subtree is the operator, and the
|
/* A unary expression. The left subtree is the operator, and the
|
||||||
|
@ -1,150 +0,0 @@
|
|||||||
#include <stdlib.h>
|
|
||||||
#include <sys/errno.h>
|
|
||||||
#include <kos32sys.h>
|
|
||||||
|
|
||||||
void __mutex_lock(volatile int *val);
|
|
||||||
|
|
||||||
static inline int tls_get(int key)
|
|
||||||
{
|
|
||||||
int val;
|
|
||||||
__asm__ __volatile__(
|
|
||||||
"movl %%fs:(%1), %0"
|
|
||||||
:"=r"(val)
|
|
||||||
:"r"(key));
|
|
||||||
|
|
||||||
return val;
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
int done;
|
|
||||||
long started;
|
|
||||||
} __gthread_once_t;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
int counter;
|
|
||||||
void *sema;
|
|
||||||
} __gthread_mutex_t;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
int counter;
|
|
||||||
int depth;
|
|
||||||
unsigned long owner;
|
|
||||||
int sema;
|
|
||||||
} __gthread_recursive_mutex_t;
|
|
||||||
|
|
||||||
|
|
||||||
int
|
|
||||||
__gthr_win32_once (__gthread_once_t *once, void (*func) (void))
|
|
||||||
{
|
|
||||||
if (once == NULL || func == NULL)
|
|
||||||
return EINVAL;
|
|
||||||
|
|
||||||
if (! once->done)
|
|
||||||
{
|
|
||||||
if (__sync_add_and_fetch (&(once->started), 1) == 0)
|
|
||||||
{
|
|
||||||
(*func) ();
|
|
||||||
once->done = 1;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* Another thread is currently executing the code, so wait for it
|
|
||||||
to finish; yield the CPU in the meantime. If performance
|
|
||||||
does become an issue, the solution is to use an Event that
|
|
||||||
we wait on here (and set above), but that implies a place to
|
|
||||||
create the event before this routine is called. */
|
|
||||||
while (! once->done)
|
|
||||||
delay(1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void __gthr_win32_mutex_init_function (__gthread_mutex_t *mutex)
|
|
||||||
{
|
|
||||||
mutex->counter = 0;
|
|
||||||
mutex->sema = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int __gthr_win32_mutex_lock (__gthread_mutex_t *mutex)
|
|
||||||
{
|
|
||||||
__mutex_lock(&mutex->counter);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
__gthr_win32_mutex_unlock (__gthread_mutex_t *mutex)
|
|
||||||
{
|
|
||||||
mutex->counter = 0;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
__gthr_win32_recursive_mutex_init_function (__gthread_recursive_mutex_t *mutex)
|
|
||||||
{
|
|
||||||
mutex->counter = -1;
|
|
||||||
mutex->depth = 0;
|
|
||||||
mutex->owner = 0;
|
|
||||||
mutex->sema = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
__gthr_win32_mutex_destroy (__gthread_mutex_t *mutex)
|
|
||||||
{ }
|
|
||||||
|
|
||||||
int
|
|
||||||
__gthr_win32_recursive_mutex_lock (__gthread_recursive_mutex_t *mutex)
|
|
||||||
{
|
|
||||||
int me = tls_get(0);
|
|
||||||
if ( __sync_add_and_fetch(&mutex->counter, 1) == 0)
|
|
||||||
{
|
|
||||||
mutex->depth = 1;
|
|
||||||
mutex->owner = me;
|
|
||||||
mutex->sema = 1;
|
|
||||||
}
|
|
||||||
else if (mutex->owner == me)
|
|
||||||
{
|
|
||||||
__sync_sub_and_fetch(&mutex->counter, 1);
|
|
||||||
++(mutex->depth);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
__mutex_lock(&mutex->sema);
|
|
||||||
mutex->depth = 1;
|
|
||||||
mutex->owner = me;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
__gthr_win32_recursive_mutex_trylock (__gthread_recursive_mutex_t *mutex)
|
|
||||||
{
|
|
||||||
int me = tls_get(0);
|
|
||||||
if (__sync_val_compare_and_swap (&mutex->counter, -1, 0) < 0)
|
|
||||||
{
|
|
||||||
mutex->depth = 1;
|
|
||||||
mutex->owner = me;
|
|
||||||
mutex->sema = 1;
|
|
||||||
}
|
|
||||||
else if (mutex->owner == me)
|
|
||||||
++(mutex->depth);
|
|
||||||
else
|
|
||||||
return 1;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
__gthr_win32_recursive_mutex_unlock (__gthread_recursive_mutex_t *mutex)
|
|
||||||
{
|
|
||||||
--(mutex->depth);
|
|
||||||
if (mutex->depth == 0)
|
|
||||||
{
|
|
||||||
mutex->owner = 0;
|
|
||||||
|
|
||||||
if (__sync_sub_and_fetch (&mutex->counter, 1) >= 0)
|
|
||||||
mutex->sema = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
Binary file not shown.
Loading…
Reference in New Issue
Block a user