Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
G
git2
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
git2
Commits
9560203d
Commit
9560203d
authored
Jun 08, 2014
by
Vicent Marti
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #2409 from phkelley/win32_thread_fixes
Win32: Fix object::cache::threadmania test on x64
parents
df192198
1b4e29b7
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
101 additions
and
65 deletions
+101
-65
src/global.c
+2
-2
src/pack-objects.c
+1
-1
src/thread-utils.h
+12
-8
src/win32/pthread.c
+55
-42
src/win32/pthread.h
+26
-7
tests/object/cache.c
+2
-2
tests/threads/refdb.c
+2
-2
tests/threads/thread_helpers.c
+1
-1
No files found.
src/global.c
View file @
9560203d
...
@@ -78,7 +78,7 @@ static void git__shutdown(void)
...
@@ -78,7 +78,7 @@ static void git__shutdown(void)
static
DWORD
_tls_index
;
static
DWORD
_tls_index
;
static
volatile
LONG
_mutex
=
0
;
static
volatile
LONG
_mutex
=
0
;
static
int
synchronized_threads_init
()
static
int
synchronized_threads_init
(
void
)
{
{
int
error
;
int
error
;
...
@@ -112,7 +112,7 @@ int git_threads_init(void)
...
@@ -112,7 +112,7 @@ int git_threads_init(void)
return
error
;
return
error
;
}
}
static
void
synchronized_threads_shutdown
()
static
void
synchronized_threads_shutdown
(
void
)
{
{
/* Shut down any subsystems that have global state */
/* Shut down any subsystems that have global state */
git__shutdown
();
git__shutdown
();
...
...
src/pack-objects.c
View file @
9560203d
...
@@ -1209,7 +1209,7 @@ static int ll_find_deltas(git_packbuilder *pb, git_pobject **list,
...
@@ -1209,7 +1209,7 @@ static int ll_find_deltas(git_packbuilder *pb, git_pobject **list,
git_mutex_unlock
(
&
target
->
mutex
);
git_mutex_unlock
(
&
target
->
mutex
);
if
(
!
sub_size
)
{
if
(
!
sub_size
)
{
git_thread_join
(
target
->
thread
,
NULL
);
git_thread_join
(
&
target
->
thread
,
NULL
);
git_cond_free
(
&
target
->
cond
);
git_cond_free
(
&
target
->
cond
);
git_mutex_free
(
&
target
->
mutex
);
git_mutex_free
(
&
target
->
mutex
);
active_threads
--
;
active_threads
--
;
...
...
src/thread-utils.h
View file @
9560203d
...
@@ -40,12 +40,18 @@ typedef git_atomic git_atomic_ssize;
...
@@ -40,12 +40,18 @@ typedef git_atomic git_atomic_ssize;
#ifdef GIT_THREADS
#ifdef GIT_THREADS
#define git_thread pthread_t
#if !defined(GIT_WIN32)
#define git_thread_create(thread, attr, start_routine, arg) \
pthread_create(thread, attr, start_routine, arg)
typedef
struct
{
#define git_thread_kill(thread) pthread_cancel(thread)
pthread_t
thread
;
#define git_thread_exit(status) pthread_exit(status)
}
git_thread
;
#define git_thread_join(id, status) pthread_join(id, status)
#define git_thread_create(git_thread_ptr, attr, start_routine, arg) \
pthread_create(&(git_thread_ptr)->thread, attr, start_routine, arg)
#define git_thread_join(git_thread_ptr, status) \
pthread_join((git_thread_ptr)->thread, status)
#endif
#if defined(GIT_WIN32)
#if defined(GIT_WIN32)
#define git_thread_yield() Sleep(0)
#define git_thread_yield() Sleep(0)
...
@@ -179,8 +185,6 @@ GIT_INLINE(int64_t) git_atomic64_add(git_atomic64 *a, int64_t addend)
...
@@ -179,8 +185,6 @@ GIT_INLINE(int64_t) git_atomic64_add(git_atomic64 *a, int64_t addend)
#define git_thread unsigned int
#define git_thread unsigned int
#define git_thread_create(thread, attr, start_routine, arg) 0
#define git_thread_create(thread, attr, start_routine, arg) 0
#define git_thread_kill(thread) (void)0
#define git_thread_exit(status) (void)0
#define git_thread_join(id, status) (void)0
#define git_thread_join(id, status) (void)0
#define git_thread_yield() (void)0
#define git_thread_yield() (void)0
...
...
src/win32/pthread.c
View file @
9560203d
...
@@ -8,32 +8,64 @@
...
@@ -8,32 +8,64 @@
#include "pthread.h"
#include "pthread.h"
#include "../global.h"
#include "../global.h"
int
pthread_create
(
#define CLEAN_THREAD_EXIT 0x6F012842
pthread_t
*
GIT_RESTRICT
thread
,
/* The thread procedure stub used to invoke the caller's procedure
* and capture the return value for later collection. Windows will
* only hold a DWORD, but we need to be able to store an entire
* void pointer. This requires the indirection. */
static
DWORD
WINAPI
git_win32__threadproc
(
LPVOID
lpParameter
)
{
git_win32_thread
*
thread
=
lpParameter
;
thread
->
result
=
thread
->
proc
(
thread
->
param
);
return
CLEAN_THREAD_EXIT
;
}
int
git_win32__thread_create
(
git_win32_thread
*
GIT_RESTRICT
thread
,
const
pthread_attr_t
*
GIT_RESTRICT
attr
,
const
pthread_attr_t
*
GIT_RESTRICT
attr
,
void
*
(
*
start_routine
)(
void
*
),
void
*
(
*
start_routine
)(
void
*
),
void
*
GIT_RESTRICT
arg
)
void
*
GIT_RESTRICT
arg
)
{
{
GIT_UNUSED
(
attr
);
GIT_UNUSED
(
attr
);
*
thread
=
CreateThread
(
NULL
,
0
,
(
LPTHREAD_START_ROUTINE
)
start_routine
,
arg
,
0
,
NULL
);
thread
->
result
=
NULL
;
return
*
thread
?
0
:
-
1
;
thread
->
param
=
arg
;
thread
->
proc
=
start_routine
;
thread
->
thread
=
CreateThread
(
NULL
,
0
,
git_win32__threadproc
,
thread
,
0
,
NULL
);
return
thread
->
thread
?
0
:
-
1
;
}
}
int
pthread_join
(
pthread_t
thread
,
void
**
value_ptr
)
int
git_win32__thread_join
(
git_win32_thread
*
thread
,
void
**
value_ptr
)
{
{
DWORD
ret
=
WaitForSingleObject
(
thread
,
INFINITE
)
;
DWORD
exit
;
if
(
ret
==
WAIT_OBJECT_0
)
{
if
(
WaitForSingleObject
(
thread
->
thread
,
INFINITE
)
!=
WAIT_OBJECT_0
)
if
(
value_ptr
!=
NULL
)
{
return
-
1
;
*
value_ptr
=
NULL
;
GetExitCodeThread
(
thread
,
(
void
*
)
value_ptr
);
if
(
!
GetExitCodeThread
(
thread
->
thread
,
&
exit
))
{
CloseHandle
(
thread
->
thread
);
return
-
1
;
}
}
CloseHandle
(
thread
);
return
0
;
/* Check for the thread having exited uncleanly. If exit was unclean,
* then we don't have a return value to give back to the caller. */
if
(
exit
!=
CLEAN_THREAD_EXIT
)
{
assert
(
false
);
thread
->
result
=
NULL
;
}
}
return
-
1
;
if
(
value_ptr
)
*
value_ptr
=
thread
->
result
;
CloseHandle
(
thread
->
thread
);
return
0
;
}
}
int
pthread_mutex_init
(
int
pthread_mutex_init
(
...
@@ -144,9 +176,6 @@ int pthread_num_processors_np(void)
...
@@ -144,9 +176,6 @@ int pthread_num_processors_np(void)
return
n
?
n
:
1
;
return
n
?
n
:
1
;
}
}
static
HINSTANCE
win32_kernel32_dll
;
typedef
void
(
WINAPI
*
win32_srwlock_fn
)(
GIT_SRWLOCK
*
);
typedef
void
(
WINAPI
*
win32_srwlock_fn
)(
GIT_SRWLOCK
*
);
static
win32_srwlock_fn
win32_srwlock_initialize
;
static
win32_srwlock_fn
win32_srwlock_initialize
;
...
@@ -159,7 +188,7 @@ int pthread_rwlock_init(
...
@@ -159,7 +188,7 @@ int pthread_rwlock_init(
pthread_rwlock_t
*
GIT_RESTRICT
lock
,
pthread_rwlock_t
*
GIT_RESTRICT
lock
,
const
pthread_rwlockattr_t
*
GIT_RESTRICT
attr
)
const
pthread_rwlockattr_t
*
GIT_RESTRICT
attr
)
{
{
(
void
)
attr
;
GIT_UNUSED
(
attr
)
;
if
(
win32_srwlock_initialize
)
if
(
win32_srwlock_initialize
)
win32_srwlock_initialize
(
&
lock
->
native
.
srwl
);
win32_srwlock_initialize
(
&
lock
->
native
.
srwl
);
...
@@ -217,38 +246,22 @@ int pthread_rwlock_destroy(pthread_rwlock_t *lock)
...
@@ -217,38 +246,22 @@ int pthread_rwlock_destroy(pthread_rwlock_t *lock)
return
0
;
return
0
;
}
}
static
void
win32_pthread_shutdown
(
void
)
{
if
(
win32_kernel32_dll
)
{
FreeLibrary
(
win32_kernel32_dll
);
win32_kernel32_dll
=
NULL
;
}
}
int
win32_pthread_initialize
(
void
)
int
win32_pthread_initialize
(
void
)
{
{
if
(
win32_kernel32_dll
)
HMODULE
hModule
=
GetModuleHandleW
(
L"kernel32"
);
return
0
;
win32_kernel32_dll
=
LoadLibrary
(
"Kernel32.dll"
);
if
(
!
win32_kernel32_dll
)
{
giterr_set
(
GITERR_OS
,
"Could not load Kernel32.dll!"
);
return
-
1
;
}
if
(
hModule
)
{
win32_srwlock_initialize
=
(
win32_srwlock_fn
)
win32_srwlock_initialize
=
(
win32_srwlock_fn
)
GetProcAddress
(
win32_kernel32_dll
,
"InitializeSRWLock"
);
GetProcAddress
(
hModule
,
"InitializeSRWLock"
);
win32_srwlock_acquire_shared
=
(
win32_srwlock_fn
)
win32_srwlock_acquire_shared
=
(
win32_srwlock_fn
)
GetProcAddress
(
win32_kernel32_dll
,
"AcquireSRWLockShared"
);
GetProcAddress
(
hModule
,
"AcquireSRWLockShared"
);
win32_srwlock_release_shared
=
(
win32_srwlock_fn
)
win32_srwlock_release_shared
=
(
win32_srwlock_fn
)
GetProcAddress
(
win32_kernel32_dll
,
"ReleaseSRWLockShared"
);
GetProcAddress
(
hModule
,
"ReleaseSRWLockShared"
);
win32_srwlock_acquire_exclusive
=
(
win32_srwlock_fn
)
win32_srwlock_acquire_exclusive
=
(
win32_srwlock_fn
)
GetProcAddress
(
win32_kernel32_dll
,
"AcquireSRWLockExclusive"
);
GetProcAddress
(
hModule
,
"AcquireSRWLockExclusive"
);
win32_srwlock_release_exclusive
=
(
win32_srwlock_fn
)
win32_srwlock_release_exclusive
=
(
win32_srwlock_fn
)
GetProcAddress
(
win32_kernel32_dll
,
"ReleaseSRWLockExclusive"
);
GetProcAddress
(
hModule
,
"ReleaseSRWLockExclusive"
);
}
git__on_shutdown
(
win32_pthread_shutdown
);
return
0
;
return
0
;
}
}
src/win32/pthread.h
View file @
9560203d
...
@@ -16,13 +16,19 @@
...
@@ -16,13 +16,19 @@
# define GIT_RESTRICT __restrict__
# define GIT_RESTRICT __restrict__
#endif
#endif
typedef
struct
{
HANDLE
thread
;
void
*
(
*
proc
)(
void
*
);
void
*
param
;
void
*
result
;
}
git_win32_thread
;
typedef
int
pthread_mutexattr_t
;
typedef
int
pthread_mutexattr_t
;
typedef
int
pthread_condattr_t
;
typedef
int
pthread_condattr_t
;
typedef
int
pthread_attr_t
;
typedef
int
pthread_attr_t
;
typedef
int
pthread_rwlockattr_t
;
typedef
int
pthread_rwlockattr_t
;
typedef
CRITICAL_SECTION
pthread_mutex_t
;
typedef
CRITICAL_SECTION
pthread_mutex_t
;
typedef
HANDLE
pthread_t
;
typedef
HANDLE
pthread_cond_t
;
typedef
HANDLE
pthread_cond_t
;
typedef
struct
{
void
*
Ptr
;
}
GIT_SRWLOCK
;
typedef
struct
{
void
*
Ptr
;
}
GIT_SRWLOCK
;
...
@@ -36,13 +42,26 @@ typedef struct {
...
@@ -36,13 +42,26 @@ typedef struct {
#define PTHREAD_MUTEX_INITIALIZER {(void*)-1}
#define PTHREAD_MUTEX_INITIALIZER {(void*)-1}
int
pthread_create
(
int
git_win32__thread_create
(
pthread_t
*
GIT_RESTRICT
thread
,
git_win32_thread
*
GIT_RESTRICT
,
const
pthread_attr_t
*
GIT_RESTRICT
attr
,
const
pthread_attr_t
*
GIT_RESTRICT
,
void
*
(
*
start_routine
)(
void
*
),
void
*
(
*
)
(
void
*
),
void
*
GIT_RESTRICT
arg
);
void
*
GIT_RESTRICT
);
int
git_win32__thread_join
(
git_win32_thread
*
,
void
**
);
#ifdef GIT_THREADS
int
pthread_join
(
pthread_t
,
void
**
);
typedef
git_win32_thread
git_thread
;
#define git_thread_create(git_thread_ptr, attr, start_routine, arg) \
git_win32__thread_create(git_thread_ptr, attr, start_routine, arg)
#define git_thread_join(git_thread_ptr, status) \
git_win32__thread_join(git_thread_ptr, status)
#endif
int
pthread_mutex_init
(
int
pthread_mutex_init
(
pthread_mutex_t
*
GIT_RESTRICT
mutex
,
pthread_mutex_t
*
GIT_RESTRICT
mutex
,
...
...
tests/object/cache.c
View file @
9560203d
...
@@ -229,7 +229,7 @@ void test_object_cache__threadmania(void)
...
@@ -229,7 +229,7 @@ void test_object_cache__threadmania(void)
#ifdef GIT_THREADS
#ifdef GIT_THREADS
for
(
th
=
0
;
th
<
THREADCOUNT
;
++
th
)
{
for
(
th
=
0
;
th
<
THREADCOUNT
;
++
th
)
{
cl_git_pass
(
git_thread_join
(
t
[
th
],
&
data
));
cl_git_pass
(
git_thread_join
(
&
t
[
th
],
&
data
));
cl_assert_equal_i
(
th
,
((
int
*
)
data
)[
0
]);
cl_assert_equal_i
(
th
,
((
int
*
)
data
)[
0
]);
git__free
(
data
);
git__free
(
data
);
}
}
...
@@ -276,7 +276,7 @@ void test_object_cache__fast_thread_rush(void)
...
@@ -276,7 +276,7 @@ void test_object_cache__fast_thread_rush(void)
#ifdef GIT_THREADS
#ifdef GIT_THREADS
for
(
th
=
0
;
th
<
THREADCOUNT
*
2
;
++
th
)
{
for
(
th
=
0
;
th
<
THREADCOUNT
*
2
;
++
th
)
{
void
*
rval
;
void
*
rval
;
cl_git_pass
(
git_thread_join
(
t
[
th
],
&
rval
));
cl_git_pass
(
git_thread_join
(
&
t
[
th
],
&
rval
));
cl_assert_equal_i
(
th
,
*
((
int
*
)
rval
));
cl_assert_equal_i
(
th
,
*
((
int
*
)
rval
));
}
}
#endif
#endif
...
...
tests/threads/refdb.c
View file @
9560203d
...
@@ -84,7 +84,7 @@ void test_threads_refdb__iterator(void)
...
@@ -84,7 +84,7 @@ void test_threads_refdb__iterator(void)
#ifdef GIT_THREADS
#ifdef GIT_THREADS
for
(
t
=
0
;
t
<
THREADS
;
++
t
)
{
for
(
t
=
0
;
t
<
THREADS
;
++
t
)
{
cl_git_pass
(
git_thread_join
(
th
[
t
],
NULL
));
cl_git_pass
(
git_thread_join
(
&
th
[
t
],
NULL
));
}
}
#endif
#endif
...
@@ -215,7 +215,7 @@ void test_threads_refdb__edit_while_iterate(void)
...
@@ -215,7 +215,7 @@ void test_threads_refdb__edit_while_iterate(void)
}
}
for
(
t
=
0
;
t
<
THREADS
;
++
t
)
{
for
(
t
=
0
;
t
<
THREADS
;
++
t
)
{
cl_git_pass
(
git_thread_join
(
th
[
t
],
NULL
));
cl_git_pass
(
git_thread_join
(
&
th
[
t
],
NULL
));
}
}
#endif
#endif
}
}
tests/threads/thread_helpers.c
View file @
9560203d
...
@@ -32,7 +32,7 @@ void run_in_parallel(
...
@@ -32,7 +32,7 @@ void run_in_parallel(
#ifdef GIT_THREADS
#ifdef GIT_THREADS
for
(
t
=
0
;
t
<
threads
;
++
t
)
for
(
t
=
0
;
t
<
threads
;
++
t
)
cl_git_pass
(
git_thread_join
(
th
[
t
],
NULL
));
cl_git_pass
(
git_thread_join
(
&
th
[
t
],
NULL
));
memset
(
th
,
0
,
threads
*
sizeof
(
git_thread
));
memset
(
th
,
0
,
threads
*
sizeof
(
git_thread
));
#endif
#endif
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment