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
8ef254bb
Commit
8ef254bb
authored
Jan 03, 2014
by
Felix Abecassis
Committed by
Jean-Baptiste Kempf
Jan 03, 2014
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
vlc_atomic: fix compilation warnings with MSVC.
Signed-off-by:
Jean-Baptiste Kempf
<
jb@videolan.org
>
parent
66572ed7
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
10 additions
and
10 deletions
+10
-10
include/vlc_atomic.h
include/vlc_atomic.h
+10
-10
No files found.
include/vlc_atomic.h
View file @
8ef254bb
...
...
@@ -324,17 +324,17 @@ typedef uintmax_t atomic_uintmax_t;
/* Define macros in order to dispatch to the correct function depending on the type.
Several ranges are need because some operations are not implemented for all types. */
# define atomic_type_dispatch_32_64(operation, object, ...) \
(sizeof(*object) == 4 ? operation(object, __VA_ARGS__) : \
sizeof(*object) == 8 ? operation##64(
object, __VA_ARGS__) : \
(abort(), 0))
(sizeof(*object) == 4 ? operation(
(LONG *)
object, __VA_ARGS__) : \
sizeof(*object) == 8 ? operation##64((LONGLONG *)
object, __VA_ARGS__) : \
(abort(), 0))
# define atomic_type_dispatch_16_64(operation, object, ...) \
(sizeof(*object) == 2 ? operation##16(object, __VA_ARGS__) : \
atomic_type_dispatch_32_64(operation, object, __VA_ARGS__))
(sizeof(*object) == 2 ? operation##16(
(short *)
object, __VA_ARGS__) : \
atomic_type_dispatch_32_64(operation, object, __VA_ARGS__))
# define atomic_type_dispatch_8_64(operation, object, ...) \
(sizeof(*object) == 1 ? operation##8(object, __VA_ARGS__) : \
atomic_type_dispatch_16_64(operation, object, __VA_ARGS__))
(sizeof(*object) == 1 ? operation##8(
(char *)
object, __VA_ARGS__) : \
atomic_type_dispatch_16_64(operation, object, __VA_ARGS__))
# define atomic_store(object,desired) \
atomic_type_dispatch_8_64(InterlockedExchange, object, desired)
...
...
@@ -347,12 +347,12 @@ typedef uintmax_t atomic_uintmax_t;
atomic_load(object)
# define atomic_exchange(object,desired) \
atomic_type_dispatch_
8
_64(InterlockedExchange, object, desired)
atomic_type_dispatch_
16
_64(InterlockedExchange, object, desired)
# define atomic_exchange_explicit(object,desired,order) \
atomic_exchange(object, desired)
# define atomic_compare_exchange_strong(object,expected,desired) \
atomic_type_dispatch_16_64(InterlockedCompareExchange, object,
expected, desired) ==
expected
atomic_type_dispatch_16_64(InterlockedCompareExchange, object,
*expected, desired) == *
expected
# define atomic_compare_exchange_strong_explicit(object,expected,desired,order) \
atomic_compare_exchange_strong(object, expected, desired)
# define atomic_compare_exchange_weak(object,expected,desired) \
...
...
@@ -366,7 +366,7 @@ typedef uintmax_t atomic_uintmax_t;
atomic_fetch_add(object, operand)
# define atomic_fetch_sub(object,operand) \
atomic_type_dispatch_32_64(InterlockedExchangeAdd, object, -operand)
atomic_type_dispatch_32_64(InterlockedExchangeAdd, object, -
(LONGLONG)
operand)
# define atomic_fetch_sub_explicit(object,operand,order) \
atomic_fetch_sub(object, operand)
...
...
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