Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc
Commits
952a943a
Commit
952a943a
authored
Sep 21, 2008
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Use GCC predefines for atomic builtins
parent
1c6ba8c0
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
8 additions
and
13 deletions
+8
-13
src/libvlc.c
src/libvlc.c
+8
-13
No files found.
src/libvlc.c
View file @
952a943a
...
@@ -76,12 +76,6 @@
...
@@ -76,12 +76,6 @@
# include <hal/libhal.h>
# include <hal/libhal.h>
#endif
#endif
#if defined(__GNUC__)
#if __GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 1)
#define USE_SYNC
#endif
#endif
#include <vlc_playlist.h>
#include <vlc_playlist.h>
#include <vlc_interface.h>
#include <vlc_interface.h>
...
@@ -131,8 +125,9 @@ void *vlc_gc_init (gc_object_t *p_gc, void (*pf_destruct) (gc_object_t *))
...
@@ -131,8 +125,9 @@ void *vlc_gc_init (gc_object_t *p_gc, void (*pf_destruct) (gc_object_t *))
p_gc
->
pf_destructor
=
pf_destruct
;
p_gc
->
pf_destructor
=
pf_destruct
;
p_gc
->
refs
=
1
;
p_gc
->
refs
=
1
;
#if
def USE_SYNC
#if
defined (__GCC_HAVE_SYNC_COMPARE_AND_SWAP_4)
__sync_synchronize
();
__sync_synchronize
();
#elif defined (WIN32)
#elif defined(__APPLE__)
#elif defined(__APPLE__)
OSMemoryBarrier
();
OSMemoryBarrier
();
#else
#else
...
@@ -154,13 +149,13 @@ void *vlc_hold (gc_object_t * p_gc)
...
@@ -154,13 +149,13 @@ void *vlc_hold (gc_object_t * p_gc)
uintptr_t
refs
;
uintptr_t
refs
;
assert
(
p_gc
);
assert
(
p_gc
);
#if defined (WIN32)
#if defined (__GCC_HAVE_SYNC_COMPARE_AND_SWAP_4)
refs
=
__sync_fetch_and_add
(
&
p_gc
->
refs
,
1
);
#elif defined (WIN32)
refs
=
-
1
+
refs
=
-
1
+
__builtin_choose_expr
(
sizeof
(
uintptr_t
)
==
4
,
__builtin_choose_expr
(
sizeof
(
uintptr_t
)
==
4
,
InterlockedIncrement
(
&
p_gc
->
refs
),
InterlockedIncrement
(
&
p_gc
->
refs
),
InterlockedIncrement64
(
&
p_gc
->
refs
));
InterlockedIncrement64
(
&
p_gc
->
refs
));
#elif defined (USE_SYNC)
refs
=
__sync_fetch_and_add
(
&
p_gc
->
refs
,
1
);
#elif defined(__APPLE__)
#elif defined(__APPLE__)
refs
=
OSAtomicIncrement32Barrier
((
int
*
)
&
p_gc
->
refs
)
-
1
;
refs
=
OSAtomicIncrement32Barrier
((
int
*
)
&
p_gc
->
refs
)
-
1
;
#else
#else
...
@@ -182,13 +177,13 @@ void vlc_release (gc_object_t *p_gc)
...
@@ -182,13 +177,13 @@ void vlc_release (gc_object_t *p_gc)
assert
(
p_gc
);
assert
(
p_gc
);
#if defined (WIN32)
#if defined (__GCC_HAVE_SYNC_COMPARE_AND_SWAP_4)
refs
=
__sync_fetch_and_sub
(
&
p_gc
->
refs
,
1
);
#elif defined (WIN32)
refs
=
1
+
refs
=
1
+
__builtin_choose_expr
(
sizeof
(
uintptr_t
)
==
4
,
__builtin_choose_expr
(
sizeof
(
uintptr_t
)
==
4
,
InterlockedDecrement
(
&
p_gc
->
refs
),
InterlockedDecrement
(
&
p_gc
->
refs
),
InterlockedDecrement64
(
&
p_gc
->
refs
));
InterlockedDecrement64
(
&
p_gc
->
refs
));
#elif defined (USE_SYNC)
refs
=
__sync_fetch_and_sub
(
&
p_gc
->
refs
,
1
);
#elif defined(__APPLE__)
#elif defined(__APPLE__)
refs
=
OSAtomicDecrement32Barrier
((
int
*
)
&
p_gc
->
refs
)
+
1
;
refs
=
OSAtomicDecrement32Barrier
((
int
*
)
&
p_gc
->
refs
)
+
1
;
#else
#else
...
...
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