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
a2e0eaa1
Commit
a2e0eaa1
authored
Sep 21, 2008
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Use OP then fetch, more straight forward with most atomic APIs
parent
3519bb1d
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
16 additions
and
18 deletions
+16
-18
src/libvlc.c
src/libvlc.c
+16
-18
No files found.
src/libvlc.c
View file @
a2e0eaa1
...
...
@@ -127,7 +127,7 @@ void *vlc_gc_init (gc_object_t *p_gc, void (*pf_destruct) (gc_object_t *))
p_gc
->
refs
=
1
;
#if defined (__GCC_HAVE_SYNC_COMPARE_AND_SWAP_4)
__sync_synchronize
();
#elif defined (WIN32)
#elif defined (WIN32)
&& defined (__GNUC__)
#elif defined(__APPLE__)
OSMemoryBarrier
();
#else
...
...
@@ -150,20 +150,19 @@ void *vlc_hold (gc_object_t * p_gc)
assert
(
p_gc
);
#if defined (__GCC_HAVE_SYNC_COMPARE_AND_SWAP_4)
refs
=
__sync_fetch_and_add
(
&
p_gc
->
refs
,
1
);
#elif defined (WIN32)
refs
=
-
1
+
__builtin_choose_expr
(
sizeof
(
uintptr_t
)
==
4
,
InterlockedIncrement
(
&
p_gc
->
refs
),
InterlockedIncrement64
(
&
p_gc
->
refs
));
refs
=
__sync_add_and_fetch
(
&
p_gc
->
refs
,
1
);
#elif defined (WIN32) && defined (__GNUC__)
refs
=
__builtin_choose_expr
(
sizeof
(
uintptr_t
)
==
4
,
InterlockedIncrement
(
&
p_gc
->
refs
),
InterlockedIncrement64
(
&
p_gc
->
refs
));
#elif defined(__APPLE__)
refs
=
OSAtomicIncrement32Barrier
((
int
*
)
&
p_gc
->
refs
)
-
1
;
refs
=
OSAtomicIncrement32Barrier
((
int
*
)
&
p_gc
->
refs
);
#else
vlc_spin_lock
(
&
p_gc
->
spin
);
refs
=
p_gc
->
refs
++
;
vlc_spin_unlock
(
&
p_gc
->
spin
);
#endif
assert
(
refs
>
0
);
assert
(
refs
!=
1
);
/* there had to be a reference already */
return
p_gc
;
}
...
...
@@ -178,22 +177,21 @@ void vlc_release (gc_object_t *p_gc)
assert
(
p_gc
);
#if defined (__GCC_HAVE_SYNC_COMPARE_AND_SWAP_4)
refs
=
__sync_fetch_and_sub
(
&
p_gc
->
refs
,
1
);
#elif defined (WIN32)
refs
=
1
+
__builtin_choose_expr
(
sizeof
(
uintptr_t
)
==
4
,
InterlockedDecrement
(
&
p_gc
->
refs
),
InterlockedDecrement64
(
&
p_gc
->
refs
));
refs
=
__sync_sub_and_fetch
(
&
p_gc
->
refs
,
1
);
#elif defined (WIN32) && defined (__GNUC__)
refs
=
__builtin_choose_expr
(
sizeof
(
uintptr_t
)
==
4
,
InterlockedDecrement
(
&
p_gc
->
refs
),
InterlockedDecrement64
(
&
p_gc
->
refs
));
#elif defined(__APPLE__)
refs
=
OSAtomicDecrement32Barrier
((
int
*
)
&
p_gc
->
refs
)
+
1
;
refs
=
OSAtomicDecrement32Barrier
((
int
*
)
&
p_gc
->
refs
);
#else
vlc_spin_lock
(
&
p_gc
->
spin
);
refs
=
p_gc
->
refs
--
;
vlc_spin_unlock
(
&
p_gc
->
spin
);
#endif
assert
(
refs
>
0
);
if
(
refs
==
1
)
assert
(
refs
!=
(
uintptr_t
)(
-
1
));
/* reference underflow?! */
if
(
refs
==
0
)
{
#ifdef USE_SYNC
#elif defined(__APPLE__)
...
...
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