Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
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
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
4419edd7
Commit
4419edd7
authored
May 12, 2015
by
Grazvydas Ignotas
Committed by
Alexandre Julliard
May 12, 2015
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
port.h: Make use of compiler support for 32bit atomic ops.
parent
eea6ba9a
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
28 additions
and
2 deletions
+28
-2
port.h
include/wine/port.h
+22
-2
interlocked.c
libs/port/interlocked.c
+6
-0
No files found.
include/wine/port.h
View file @
4419edd7
...
...
@@ -435,12 +435,32 @@ static inline unsigned char interlocked_cmpxchg128( __int64 *dest, __int64 xchg_
#else
/* __GNUC__ */
#ifdef __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4
static
inline
int
interlocked_cmpxchg
(
int
*
dest
,
int
xchg
,
int
compare
)
{
return
__sync_val_compare_and_swap
(
dest
,
compare
,
xchg
);
}
static
inline
int
interlocked_xchg_add
(
int
*
dest
,
int
incr
)
{
return
__sync_fetch_and_add
(
dest
,
incr
);
}
static
inline
int
interlocked_xchg
(
int
*
dest
,
int
val
)
{
int
ret
;
do
ret
=
*
dest
;
while
(
!
__sync_bool_compare_and_swap
(
dest
,
ret
,
val
));
return
ret
;
}
#else
extern
int
interlocked_cmpxchg
(
int
*
dest
,
int
xchg
,
int
compare
);
extern
int
interlocked_xchg_add
(
int
*
dest
,
int
incr
);
extern
int
interlocked_xchg
(
int
*
dest
,
int
val
);
#endif
extern
void
*
interlocked_cmpxchg_ptr
(
void
**
dest
,
void
*
xchg
,
void
*
compare
);
extern
__int64
interlocked_cmpxchg64
(
__int64
*
dest
,
__int64
xchg
,
__int64
compare
);
extern
int
interlocked_xchg
(
int
*
dest
,
int
val
);
extern
void
*
interlocked_xchg_ptr
(
void
**
dest
,
void
*
val
);
extern
int
interlocked_xchg_add
(
int
*
dest
,
int
incr
);
#if defined(__x86_64__) || defined(__aarch64__) || defined(_WIN64)
extern
unsigned
char
interlocked_cmpxchg128
(
__int64
*
dest
,
__int64
xchg_high
,
__int64
xchg_low
,
__int64
*
compare
);
...
...
libs/port/interlocked.c
View file @
4419edd7
...
...
@@ -274,6 +274,7 @@ void* interlocked_xchg_ptr( void** dest, void* val )
static
pthread_mutex_t
interlocked_mutex
=
PTHREAD_MUTEX_INITIALIZER
;
#ifndef __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4
int
interlocked_cmpxchg
(
int
*
dest
,
int
xchg
,
int
compare
)
{
pthread_mutex_lock
(
&
interlocked_mutex
);
...
...
@@ -286,6 +287,7 @@ int interlocked_cmpxchg( int *dest, int xchg, int compare )
pthread_mutex_unlock
(
&
interlocked_mutex
);
return
compare
;
}
#endif
void
*
interlocked_cmpxchg_ptr
(
void
**
dest
,
void
*
xchg
,
void
*
compare
)
{
...
...
@@ -313,6 +315,7 @@ __int64 interlocked_cmpxchg64( __int64 *dest, __int64 xchg, __int64 compare )
return
compare
;
}
#ifndef __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4
int
interlocked_xchg
(
int
*
dest
,
int
val
)
{
int
retv
;
...
...
@@ -322,6 +325,7 @@ int interlocked_xchg( int *dest, int val )
pthread_mutex_unlock
(
&
interlocked_mutex
);
return
retv
;
}
#endif
void
*
interlocked_xchg_ptr
(
void
**
dest
,
void
*
val
)
{
...
...
@@ -333,6 +337,7 @@ void *interlocked_xchg_ptr( void **dest, void *val )
return
retv
;
}
#ifndef __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4
int
interlocked_xchg_add
(
int
*
dest
,
int
incr
)
{
int
retv
;
...
...
@@ -342,6 +347,7 @@ int interlocked_xchg_add( int *dest, int incr )
pthread_mutex_unlock
(
&
interlocked_mutex
);
return
retv
;
}
#endif
unsigned
char
interlocked_cmpxchg128
(
__int64
*
dest
,
__int64
xchg_high
,
__int64
xchg_low
,
__int64
*
compare
)
{
...
...
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