Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
P
protobuf
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
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
protobuf
Commits
b7aebe40
Commit
b7aebe40
authored
Jul 30, 2014
by
jieluo@google.com
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Change MemoryBarrier() to MemoryBarrierInternal(). Resolve name conflict in mingw gcc 4.8.1
parent
db9f7dd1
Show whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
56 additions
and
56 deletions
+56
-56
atomicops.h
src/google/protobuf/stubs/atomicops.h
+3
-3
atomicops_internals_arm64_gcc.h
src/google/protobuf/stubs/atomicops_internals_arm64_gcc.h
+13
-13
atomicops_internals_arm_gcc.h
src/google/protobuf/stubs/atomicops_internals_arm_gcc.h
+5
-5
atomicops_internals_arm_qnx.h
src/google/protobuf/stubs/atomicops_internals_arm_qnx.h
+5
-5
atomicops_internals_macosx.h
src/google/protobuf/stubs/atomicops_internals_macosx.h
+9
-9
atomicops_internals_mips_gcc.h
src/google/protobuf/stubs/atomicops_internals_mips_gcc.h
+7
-7
atomicops_internals_pnacl.h
src/google/protobuf/stubs/atomicops_internals_pnacl.h
+4
-4
atomicops_internals_tsan.h
src/google/protobuf/stubs/atomicops_internals_tsan.h
+1
-1
atomicops_internals_x86_gcc.h
src/google/protobuf/stubs/atomicops_internals_x86_gcc.h
+6
-6
atomicops_internals_x86_msvc.cc
src/google/protobuf/stubs/atomicops_internals_x86_msvc.cc
+1
-1
atomicops_internals_x86_msvc.h
src/google/protobuf/stubs/atomicops_internals_x86_msvc.h
+2
-2
No files found.
src/google/protobuf/stubs/atomicops.h
View file @
b7aebe40
...
@@ -111,8 +111,8 @@ Atomic32 Barrier_AtomicIncrement(volatile Atomic32* ptr,
...
@@ -111,8 +111,8 @@ Atomic32 Barrier_AtomicIncrement(volatile Atomic32* ptr,
// ensure that no later memory access can be reordered ahead of the operation.
// ensure that no later memory access can be reordered ahead of the operation.
// "Release" operations ensure that no previous memory access can be reordered
// "Release" operations ensure that no previous memory access can be reordered
// after the operation. "Barrier" operations have both "Acquire" and "Release"
// after the operation. "Barrier" operations have both "Acquire" and "Release"
// semantics. A MemoryBarrier
() has "Barrier" semantics, but does no memory
// semantics. A MemoryBarrier
Internal() has "Barrier" semantics, but does no
// access.
//
memory
access.
Atomic32
Acquire_CompareAndSwap
(
volatile
Atomic32
*
ptr
,
Atomic32
Acquire_CompareAndSwap
(
volatile
Atomic32
*
ptr
,
Atomic32
old_value
,
Atomic32
old_value
,
Atomic32
new_value
);
Atomic32
new_value
);
...
@@ -120,7 +120,7 @@ Atomic32 Release_CompareAndSwap(volatile Atomic32* ptr,
...
@@ -120,7 +120,7 @@ Atomic32 Release_CompareAndSwap(volatile Atomic32* ptr,
Atomic32
old_value
,
Atomic32
old_value
,
Atomic32
new_value
);
Atomic32
new_value
);
void
MemoryBarrier
();
void
MemoryBarrier
Internal
();
void
NoBarrier_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
);
void
NoBarrier_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
);
void
Acquire_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
);
void
Acquire_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
);
void
Release_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
);
void
Release_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
);
...
...
src/google/protobuf/stubs/atomicops_internals_arm64_gcc.h
View file @
b7aebe40
...
@@ -37,7 +37,7 @@ namespace google {
...
@@ -37,7 +37,7 @@ namespace google {
namespace
protobuf
{
namespace
protobuf
{
namespace
internal
{
namespace
internal
{
inline
void
MemoryBarrier
()
{
inline
void
MemoryBarrier
Internal
()
{
__asm__
__volatile__
(
"dmb ish"
:::
"memory"
);
// NOLINT
__asm__
__volatile__
(
"dmb ish"
:::
"memory"
);
// NOLINT
}
}
...
@@ -117,9 +117,9 @@ inline Atomic32 NoBarrier_AtomicIncrement(volatile Atomic32* ptr,
...
@@ -117,9 +117,9 @@ inline Atomic32 NoBarrier_AtomicIncrement(volatile Atomic32* ptr,
inline
Atomic32
Barrier_AtomicIncrement
(
volatile
Atomic32
*
ptr
,
inline
Atomic32
Barrier_AtomicIncrement
(
volatile
Atomic32
*
ptr
,
Atomic32
increment
)
{
Atomic32
increment
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
Atomic32
result
=
NoBarrier_AtomicIncrement
(
ptr
,
increment
);
Atomic32
result
=
NoBarrier_AtomicIncrement
(
ptr
,
increment
);
MemoryBarrier
();
MemoryBarrier
Internal
();
return
result
;
return
result
;
}
}
...
@@ -128,7 +128,7 @@ inline Atomic32 Acquire_CompareAndSwap(volatile Atomic32* ptr,
...
@@ -128,7 +128,7 @@ inline Atomic32 Acquire_CompareAndSwap(volatile Atomic32* ptr,
Atomic32
old_value
,
Atomic32
old_value
,
Atomic32
new_value
)
{
Atomic32
new_value
)
{
Atomic32
prev
=
NoBarrier_CompareAndSwap
(
ptr
,
old_value
,
new_value
);
Atomic32
prev
=
NoBarrier_CompareAndSwap
(
ptr
,
old_value
,
new_value
);
MemoryBarrier
();
MemoryBarrier
Internal
();
return
prev
;
return
prev
;
}
}
...
@@ -136,7 +136,7 @@ inline Atomic32 Acquire_CompareAndSwap(volatile Atomic32* ptr,
...
@@ -136,7 +136,7 @@ inline Atomic32 Acquire_CompareAndSwap(volatile Atomic32* ptr,
inline
Atomic32
Release_CompareAndSwap
(
volatile
Atomic32
*
ptr
,
inline
Atomic32
Release_CompareAndSwap
(
volatile
Atomic32
*
ptr
,
Atomic32
old_value
,
Atomic32
old_value
,
Atomic32
new_value
)
{
Atomic32
new_value
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
Atomic32
prev
=
NoBarrier_CompareAndSwap
(
ptr
,
old_value
,
new_value
);
Atomic32
prev
=
NoBarrier_CompareAndSwap
(
ptr
,
old_value
,
new_value
);
return
prev
;
return
prev
;
...
@@ -148,7 +148,7 @@ inline void NoBarrier_Store(volatile Atomic32* ptr, Atomic32 value) {
...
@@ -148,7 +148,7 @@ inline void NoBarrier_Store(volatile Atomic32* ptr, Atomic32 value) {
inline
void
Acquire_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
inline
void
Acquire_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
*
ptr
=
value
;
*
ptr
=
value
;
MemoryBarrier
();
MemoryBarrier
Internal
();
}
}
inline
void
Release_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
inline
void
Release_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
...
@@ -178,7 +178,7 @@ inline Atomic32 Acquire_Load(volatile const Atomic32* ptr) {
...
@@ -178,7 +178,7 @@ inline Atomic32 Acquire_Load(volatile const Atomic32* ptr) {
}
}
inline
Atomic32
Release_Load
(
volatile
const
Atomic32
*
ptr
)
{
inline
Atomic32
Release_Load
(
volatile
const
Atomic32
*
ptr
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
return
*
ptr
;
return
*
ptr
;
}
}
...
@@ -253,9 +253,9 @@ inline Atomic64 NoBarrier_AtomicIncrement(volatile Atomic64* ptr,
...
@@ -253,9 +253,9 @@ inline Atomic64 NoBarrier_AtomicIncrement(volatile Atomic64* ptr,
inline
Atomic64
Barrier_AtomicIncrement
(
volatile
Atomic64
*
ptr
,
inline
Atomic64
Barrier_AtomicIncrement
(
volatile
Atomic64
*
ptr
,
Atomic64
increment
)
{
Atomic64
increment
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
Atomic64
result
=
NoBarrier_AtomicIncrement
(
ptr
,
increment
);
Atomic64
result
=
NoBarrier_AtomicIncrement
(
ptr
,
increment
);
MemoryBarrier
();
MemoryBarrier
Internal
();
return
result
;
return
result
;
}
}
...
@@ -264,7 +264,7 @@ inline Atomic64 Acquire_CompareAndSwap(volatile Atomic64* ptr,
...
@@ -264,7 +264,7 @@ inline Atomic64 Acquire_CompareAndSwap(volatile Atomic64* ptr,
Atomic64
old_value
,
Atomic64
old_value
,
Atomic64
new_value
)
{
Atomic64
new_value
)
{
Atomic64
prev
=
NoBarrier_CompareAndSwap
(
ptr
,
old_value
,
new_value
);
Atomic64
prev
=
NoBarrier_CompareAndSwap
(
ptr
,
old_value
,
new_value
);
MemoryBarrier
();
MemoryBarrier
Internal
();
return
prev
;
return
prev
;
}
}
...
@@ -272,7 +272,7 @@ inline Atomic64 Acquire_CompareAndSwap(volatile Atomic64* ptr,
...
@@ -272,7 +272,7 @@ inline Atomic64 Acquire_CompareAndSwap(volatile Atomic64* ptr,
inline
Atomic64
Release_CompareAndSwap
(
volatile
Atomic64
*
ptr
,
inline
Atomic64
Release_CompareAndSwap
(
volatile
Atomic64
*
ptr
,
Atomic64
old_value
,
Atomic64
old_value
,
Atomic64
new_value
)
{
Atomic64
new_value
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
Atomic64
prev
=
NoBarrier_CompareAndSwap
(
ptr
,
old_value
,
new_value
);
Atomic64
prev
=
NoBarrier_CompareAndSwap
(
ptr
,
old_value
,
new_value
);
return
prev
;
return
prev
;
...
@@ -284,7 +284,7 @@ inline void NoBarrier_Store(volatile Atomic64* ptr, Atomic64 value) {
...
@@ -284,7 +284,7 @@ inline void NoBarrier_Store(volatile Atomic64* ptr, Atomic64 value) {
inline
void
Acquire_Store
(
volatile
Atomic64
*
ptr
,
Atomic64
value
)
{
inline
void
Acquire_Store
(
volatile
Atomic64
*
ptr
,
Atomic64
value
)
{
*
ptr
=
value
;
*
ptr
=
value
;
MemoryBarrier
();
MemoryBarrier
Internal
();
}
}
inline
void
Release_Store
(
volatile
Atomic64
*
ptr
,
Atomic64
value
)
{
inline
void
Release_Store
(
volatile
Atomic64
*
ptr
,
Atomic64
value
)
{
...
@@ -314,7 +314,7 @@ inline Atomic64 Acquire_Load(volatile const Atomic64* ptr) {
...
@@ -314,7 +314,7 @@ inline Atomic64 Acquire_Load(volatile const Atomic64* ptr) {
}
}
inline
Atomic64
Release_Load
(
volatile
const
Atomic64
*
ptr
)
{
inline
Atomic64
Release_Load
(
volatile
const
Atomic64
*
ptr
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
return
*
ptr
;
return
*
ptr
;
}
}
...
...
src/google/protobuf/stubs/atomicops_internals_arm_gcc.h
View file @
b7aebe40
...
@@ -115,17 +115,17 @@ inline void NoBarrier_Store(volatile Atomic32* ptr, Atomic32 value) {
...
@@ -115,17 +115,17 @@ inline void NoBarrier_Store(volatile Atomic32* ptr, Atomic32 value) {
*
ptr
=
value
;
*
ptr
=
value
;
}
}
inline
void
MemoryBarrier
()
{
inline
void
MemoryBarrier
Internal
()
{
pLinuxKernelMemoryBarrier
();
pLinuxKernelMemoryBarrier
();
}
}
inline
void
Acquire_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
inline
void
Acquire_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
*
ptr
=
value
;
*
ptr
=
value
;
MemoryBarrier
();
MemoryBarrier
Internal
();
}
}
inline
void
Release_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
inline
void
Release_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
*
ptr
=
value
;
*
ptr
=
value
;
}
}
...
@@ -135,12 +135,12 @@ inline Atomic32 NoBarrier_Load(volatile const Atomic32* ptr) {
...
@@ -135,12 +135,12 @@ inline Atomic32 NoBarrier_Load(volatile const Atomic32* ptr) {
inline
Atomic32
Acquire_Load
(
volatile
const
Atomic32
*
ptr
)
{
inline
Atomic32
Acquire_Load
(
volatile
const
Atomic32
*
ptr
)
{
Atomic32
value
=
*
ptr
;
Atomic32
value
=
*
ptr
;
MemoryBarrier
();
MemoryBarrier
Internal
();
return
value
;
return
value
;
}
}
inline
Atomic32
Release_Load
(
volatile
const
Atomic32
*
ptr
)
{
inline
Atomic32
Release_Load
(
volatile
const
Atomic32
*
ptr
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
return
*
ptr
;
return
*
ptr
;
}
}
...
...
src/google/protobuf/stubs/atomicops_internals_arm_qnx.h
View file @
b7aebe40
...
@@ -110,17 +110,17 @@ inline void NoBarrier_Store(volatile Atomic32* ptr, Atomic32 value) {
...
@@ -110,17 +110,17 @@ inline void NoBarrier_Store(volatile Atomic32* ptr, Atomic32 value) {
*
ptr
=
value
;
*
ptr
=
value
;
}
}
inline
void
MemoryBarrier
()
{
inline
void
MemoryBarrier
Internal
()
{
__sync_synchronize
();
__sync_synchronize
();
}
}
inline
void
Acquire_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
inline
void
Acquire_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
*
ptr
=
value
;
*
ptr
=
value
;
MemoryBarrier
();
MemoryBarrier
Internal
();
}
}
inline
void
Release_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
inline
void
Release_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
*
ptr
=
value
;
*
ptr
=
value
;
}
}
...
@@ -130,12 +130,12 @@ inline Atomic32 NoBarrier_Load(volatile const Atomic32* ptr) {
...
@@ -130,12 +130,12 @@ inline Atomic32 NoBarrier_Load(volatile const Atomic32* ptr) {
inline
Atomic32
Acquire_Load
(
volatile
const
Atomic32
*
ptr
)
{
inline
Atomic32
Acquire_Load
(
volatile
const
Atomic32
*
ptr
)
{
Atomic32
value
=
*
ptr
;
Atomic32
value
=
*
ptr
;
MemoryBarrier
();
MemoryBarrier
Internal
();
return
value
;
return
value
;
}
}
inline
Atomic32
Release_Load
(
volatile
const
Atomic32
*
ptr
)
{
inline
Atomic32
Release_Load
(
volatile
const
Atomic32
*
ptr
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
return
*
ptr
;
return
*
ptr
;
}
}
...
...
src/google/protobuf/stubs/atomicops_internals_macosx.h
View file @
b7aebe40
...
@@ -73,7 +73,7 @@ inline Atomic32 Barrier_AtomicIncrement(volatile Atomic32* ptr,
...
@@ -73,7 +73,7 @@ inline Atomic32 Barrier_AtomicIncrement(volatile Atomic32* ptr,
return
OSAtomicAdd32Barrier
(
increment
,
const_cast
<
Atomic32
*>
(
ptr
));
return
OSAtomicAdd32Barrier
(
increment
,
const_cast
<
Atomic32
*>
(
ptr
));
}
}
inline
void
MemoryBarrier
()
{
inline
void
MemoryBarrier
Internal
()
{
OSMemoryBarrier
();
OSMemoryBarrier
();
}
}
...
@@ -103,11 +103,11 @@ inline void NoBarrier_Store(volatile Atomic32* ptr, Atomic32 value) {
...
@@ -103,11 +103,11 @@ inline void NoBarrier_Store(volatile Atomic32* ptr, Atomic32 value) {
inline
void
Acquire_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
inline
void
Acquire_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
*
ptr
=
value
;
*
ptr
=
value
;
MemoryBarrier
();
MemoryBarrier
Internal
();
}
}
inline
void
Release_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
inline
void
Release_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
*
ptr
=
value
;
*
ptr
=
value
;
}
}
...
@@ -117,12 +117,12 @@ inline Atomic32 NoBarrier_Load(volatile const Atomic32* ptr) {
...
@@ -117,12 +117,12 @@ inline Atomic32 NoBarrier_Load(volatile const Atomic32* ptr) {
inline
Atomic32
Acquire_Load
(
volatile
const
Atomic32
*
ptr
)
{
inline
Atomic32
Acquire_Load
(
volatile
const
Atomic32
*
ptr
)
{
Atomic32
value
=
*
ptr
;
Atomic32
value
=
*
ptr
;
MemoryBarrier
();
MemoryBarrier
Internal
();
return
value
;
return
value
;
}
}
inline
Atomic32
Release_Load
(
volatile
const
Atomic32
*
ptr
)
{
inline
Atomic32
Release_Load
(
volatile
const
Atomic32
*
ptr
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
return
*
ptr
;
return
*
ptr
;
}
}
...
@@ -193,11 +193,11 @@ inline void NoBarrier_Store(volatile Atomic64* ptr, Atomic64 value) {
...
@@ -193,11 +193,11 @@ inline void NoBarrier_Store(volatile Atomic64* ptr, Atomic64 value) {
inline
void
Acquire_Store
(
volatile
Atomic64
*
ptr
,
Atomic64
value
)
{
inline
void
Acquire_Store
(
volatile
Atomic64
*
ptr
,
Atomic64
value
)
{
*
ptr
=
value
;
*
ptr
=
value
;
MemoryBarrier
();
MemoryBarrier
Internal
();
}
}
inline
void
Release_Store
(
volatile
Atomic64
*
ptr
,
Atomic64
value
)
{
inline
void
Release_Store
(
volatile
Atomic64
*
ptr
,
Atomic64
value
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
*
ptr
=
value
;
*
ptr
=
value
;
}
}
...
@@ -207,12 +207,12 @@ inline Atomic64 NoBarrier_Load(volatile const Atomic64* ptr) {
...
@@ -207,12 +207,12 @@ inline Atomic64 NoBarrier_Load(volatile const Atomic64* ptr) {
inline
Atomic64
Acquire_Load
(
volatile
const
Atomic64
*
ptr
)
{
inline
Atomic64
Acquire_Load
(
volatile
const
Atomic64
*
ptr
)
{
Atomic64
value
=
*
ptr
;
Atomic64
value
=
*
ptr
;
MemoryBarrier
();
MemoryBarrier
Internal
();
return
value
;
return
value
;
}
}
inline
Atomic64
Release_Load
(
volatile
const
Atomic64
*
ptr
)
{
inline
Atomic64
Release_Load
(
volatile
const
Atomic64
*
ptr
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
return
*
ptr
;
return
*
ptr
;
}
}
...
...
src/google/protobuf/stubs/atomicops_internals_mips_gcc.h
View file @
b7aebe40
...
@@ -125,8 +125,8 @@ inline Atomic32 Barrier_AtomicIncrement(volatile Atomic32* ptr,
...
@@ -125,8 +125,8 @@ inline Atomic32 Barrier_AtomicIncrement(volatile Atomic32* ptr,
// ensure that no later memory access can be reordered ahead of the operation.
// ensure that no later memory access can be reordered ahead of the operation.
// "Release" operations ensure that no previous memory access can be reordered
// "Release" operations ensure that no previous memory access can be reordered
// after the operation. "Barrier" operations have both "Acquire" and "Release"
// after the operation. "Barrier" operations have both "Acquire" and "Release"
// semantics. A MemoryBarrier
() has "Barrier" semantics, but does no memory
// semantics. A MemoryBarrier
Internal() has "Barrier" semantics, but does no
// access.
//
memory
access.
inline
Atomic32
Acquire_CompareAndSwap
(
volatile
Atomic32
*
ptr
,
inline
Atomic32
Acquire_CompareAndSwap
(
volatile
Atomic32
*
ptr
,
Atomic32
old_value
,
Atomic32
old_value
,
Atomic32
new_value
)
{
Atomic32
new_value
)
{
...
@@ -149,17 +149,17 @@ inline void NoBarrier_Store(volatile Atomic32* ptr, Atomic32 value) {
...
@@ -149,17 +149,17 @@ inline void NoBarrier_Store(volatile Atomic32* ptr, Atomic32 value) {
*
ptr
=
value
;
*
ptr
=
value
;
}
}
inline
void
MemoryBarrier
()
{
inline
void
MemoryBarrier
Internal
()
{
__asm__
__volatile__
(
"sync"
:
:
:
"memory"
);
__asm__
__volatile__
(
"sync"
:
:
:
"memory"
);
}
}
inline
void
Acquire_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
inline
void
Acquire_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
*
ptr
=
value
;
*
ptr
=
value
;
MemoryBarrier
();
MemoryBarrier
Internal
();
}
}
inline
void
Release_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
inline
void
Release_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
*
ptr
=
value
;
*
ptr
=
value
;
}
}
...
@@ -169,12 +169,12 @@ inline Atomic32 NoBarrier_Load(volatile const Atomic32* ptr) {
...
@@ -169,12 +169,12 @@ inline Atomic32 NoBarrier_Load(volatile const Atomic32* ptr) {
inline
Atomic32
Acquire_Load
(
volatile
const
Atomic32
*
ptr
)
{
inline
Atomic32
Acquire_Load
(
volatile
const
Atomic32
*
ptr
)
{
Atomic32
value
=
*
ptr
;
Atomic32
value
=
*
ptr
;
MemoryBarrier
();
MemoryBarrier
Internal
();
return
value
;
return
value
;
}
}
inline
Atomic32
Release_Load
(
volatile
const
Atomic32
*
ptr
)
{
inline
Atomic32
Release_Load
(
volatile
const
Atomic32
*
ptr
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
return
*
ptr
;
return
*
ptr
;
}
}
...
...
src/google/protobuf/stubs/atomicops_internals_pnacl.h
View file @
b7aebe40
...
@@ -43,7 +43,7 @@ inline Atomic32 NoBarrier_CompareAndSwap(volatile Atomic32* ptr,
...
@@ -43,7 +43,7 @@ inline Atomic32 NoBarrier_CompareAndSwap(volatile Atomic32* ptr,
return
__sync_val_compare_and_swap
(
ptr
,
old_value
,
new_value
);
return
__sync_val_compare_and_swap
(
ptr
,
old_value
,
new_value
);
}
}
inline
void
MemoryBarrier
()
{
inline
void
MemoryBarrier
Internal
()
{
__sync_synchronize
();
__sync_synchronize
();
}
}
...
@@ -51,18 +51,18 @@ inline Atomic32 Acquire_CompareAndSwap(volatile Atomic32* ptr,
...
@@ -51,18 +51,18 @@ inline Atomic32 Acquire_CompareAndSwap(volatile Atomic32* ptr,
Atomic32
old_value
,
Atomic32
old_value
,
Atomic32
new_value
)
{
Atomic32
new_value
)
{
Atomic32
ret
=
NoBarrier_CompareAndSwap
(
ptr
,
old_value
,
new_value
);
Atomic32
ret
=
NoBarrier_CompareAndSwap
(
ptr
,
old_value
,
new_value
);
MemoryBarrier
();
MemoryBarrier
Internal
();
return
ret
;
return
ret
;
}
}
inline
void
Release_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
inline
void
Release_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
*
ptr
=
value
;
*
ptr
=
value
;
}
}
inline
Atomic32
Acquire_Load
(
volatile
const
Atomic32
*
ptr
)
{
inline
Atomic32
Acquire_Load
(
volatile
const
Atomic32
*
ptr
)
{
Atomic32
value
=
*
ptr
;
Atomic32
value
=
*
ptr
;
MemoryBarrier
();
MemoryBarrier
Internal
();
return
value
;
return
value
;
}
}
...
...
src/google/protobuf/stubs/atomicops_internals_tsan.h
View file @
b7aebe40
...
@@ -206,7 +206,7 @@ inline Atomic64 Release_CompareAndSwap(volatile Atomic64 *ptr,
...
@@ -206,7 +206,7 @@ inline Atomic64 Release_CompareAndSwap(volatile Atomic64 *ptr,
return
cmp
;
return
cmp
;
}
}
inline
void
MemoryBarrier
()
{
inline
void
MemoryBarrier
Internal
()
{
__tsan_atomic_thread_fence
(
__tsan_memory_order_seq_cst
);
__tsan_atomic_thread_fence
(
__tsan_memory_order_seq_cst
);
}
}
...
...
src/google/protobuf/stubs/atomicops_internals_x86_gcc.h
View file @
b7aebe40
...
@@ -119,18 +119,18 @@ inline void NoBarrier_Store(volatile Atomic32* ptr, Atomic32 value) {
...
@@ -119,18 +119,18 @@ inline void NoBarrier_Store(volatile Atomic32* ptr, Atomic32 value) {
// 64-bit implementations of memory barrier can be simpler, because it
// 64-bit implementations of memory barrier can be simpler, because it
// "mfence" is guaranteed to exist.
// "mfence" is guaranteed to exist.
inline
void
MemoryBarrier
()
{
inline
void
MemoryBarrier
Internal
()
{
__asm__
__volatile__
(
"mfence"
:
:
:
"memory"
);
__asm__
__volatile__
(
"mfence"
:
:
:
"memory"
);
}
}
inline
void
Acquire_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
inline
void
Acquire_Store
(
volatile
Atomic32
*
ptr
,
Atomic32
value
)
{
*
ptr
=
value
;
*
ptr
=
value
;
MemoryBarrier
();
MemoryBarrier
Internal
();
}
}
#else
#else
inline
void
MemoryBarrier
()
{
inline
void
MemoryBarrier
Internal
()
{
if
(
AtomicOps_Internalx86CPUFeatures
.
has_sse2
)
{
if
(
AtomicOps_Internalx86CPUFeatures
.
has_sse2
)
{
__asm__
__volatile__
(
"mfence"
:
:
:
"memory"
);
__asm__
__volatile__
(
"mfence"
:
:
:
"memory"
);
}
else
{
// mfence is faster but not present on PIII
}
else
{
// mfence is faster but not present on PIII
...
@@ -168,7 +168,7 @@ inline Atomic32 Acquire_Load(volatile const Atomic32* ptr) {
...
@@ -168,7 +168,7 @@ inline Atomic32 Acquire_Load(volatile const Atomic32* ptr) {
}
}
inline
Atomic32
Release_Load
(
volatile
const
Atomic32
*
ptr
)
{
inline
Atomic32
Release_Load
(
volatile
const
Atomic32
*
ptr
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
return
*
ptr
;
return
*
ptr
;
}
}
...
@@ -225,7 +225,7 @@ inline void NoBarrier_Store(volatile Atomic64* ptr, Atomic64 value) {
...
@@ -225,7 +225,7 @@ inline void NoBarrier_Store(volatile Atomic64* ptr, Atomic64 value) {
inline
void
Acquire_Store
(
volatile
Atomic64
*
ptr
,
Atomic64
value
)
{
inline
void
Acquire_Store
(
volatile
Atomic64
*
ptr
,
Atomic64
value
)
{
*
ptr
=
value
;
*
ptr
=
value
;
MemoryBarrier
();
MemoryBarrier
Internal
();
}
}
inline
void
Release_Store
(
volatile
Atomic64
*
ptr
,
Atomic64
value
)
{
inline
void
Release_Store
(
volatile
Atomic64
*
ptr
,
Atomic64
value
)
{
...
@@ -262,7 +262,7 @@ inline Atomic64 Acquire_Load(volatile const Atomic64* ptr) {
...
@@ -262,7 +262,7 @@ inline Atomic64 Acquire_Load(volatile const Atomic64* ptr) {
}
}
inline
Atomic64
Release_Load
(
volatile
const
Atomic64
*
ptr
)
{
inline
Atomic64
Release_Load
(
volatile
const
Atomic64
*
ptr
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
return
*
ptr
;
return
*
ptr
;
}
}
...
...
src/google/protobuf/stubs/atomicops_internals_x86_msvc.cc
View file @
b7aebe40
...
@@ -44,7 +44,7 @@ namespace google {
...
@@ -44,7 +44,7 @@ namespace google {
namespace
protobuf
{
namespace
protobuf
{
namespace
internal
{
namespace
internal
{
inline
void
MemoryBarrier
()
{
inline
void
MemoryBarrier
Internal
()
{
// We use MemoryBarrier from WinNT.h
// We use MemoryBarrier from WinNT.h
::
MemoryBarrier
();
::
MemoryBarrier
();
}
}
...
...
src/google/protobuf/stubs/atomicops_internals_x86_msvc.h
View file @
b7aebe40
...
@@ -82,7 +82,7 @@ inline Atomic32 Acquire_Load(volatile const Atomic32* ptr) {
...
@@ -82,7 +82,7 @@ inline Atomic32 Acquire_Load(volatile const Atomic32* ptr) {
}
}
inline
Atomic32
Release_Load
(
volatile
const
Atomic32
*
ptr
)
{
inline
Atomic32
Release_Load
(
volatile
const
Atomic32
*
ptr
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
return
*
ptr
;
return
*
ptr
;
}
}
...
@@ -125,7 +125,7 @@ inline Atomic64 Acquire_Load(volatile const Atomic64* ptr) {
...
@@ -125,7 +125,7 @@ inline Atomic64 Acquire_Load(volatile const Atomic64* ptr) {
}
}
inline
Atomic64
Release_Load
(
volatile
const
Atomic64
*
ptr
)
{
inline
Atomic64
Release_Load
(
volatile
const
Atomic64
*
ptr
)
{
MemoryBarrier
();
MemoryBarrier
Internal
();
return
*
ptr
;
return
*
ptr
;
}
}
...
...
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