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
0971efb1
Unverified
Commit
0971efb1
authored
Nov 09, 2017
by
Jisi Liu
Committed by
GitHub
Nov 09, 2017
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #3854 from pherl/3.5.x
Fix Atomic32/AtomicWord on some platforms.
parents
662e8b20
181e284b
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
2 additions
and
131 deletions
+2
-131
extract_includes.bat.in
cmake/extract_includes.bat.in
+0
-1
Makefile.am
src/Makefile.am
+0
-1
atomicops.h
src/google/protobuf/stubs/atomicops.h
+2
-7
atomicops_internals_atomicword_compat.h
...le/protobuf/stubs/atomicops_internals_atomicword_compat.h
+0
-122
No files found.
cmake/extract_includes.bat.in
View file @
0971efb1
...
...
@@ -83,7 +83,6 @@ copy "${PROTOBUF_SOURCE_WIN32_PATH}\..\src\google\protobuf\stubs\atomicops.h" in
copy "${PROTOBUF_SOURCE_WIN32_PATH}\..\src\google\protobuf\stubs\atomicops_internals_arm64_gcc.h" include\google\protobuf\stubs\atomicops_internals_arm64_gcc.h
copy "${PROTOBUF_SOURCE_WIN32_PATH}\..\src\google\protobuf\stubs\atomicops_internals_arm_gcc.h" include\google\protobuf\stubs\atomicops_internals_arm_gcc.h
copy "${PROTOBUF_SOURCE_WIN32_PATH}\..\src\google\protobuf\stubs\atomicops_internals_arm_qnx.h" include\google\protobuf\stubs\atomicops_internals_arm_qnx.h
copy "${PROTOBUF_SOURCE_WIN32_PATH}\..\src\google\protobuf\stubs\atomicops_internals_atomicword_compat.h" include\google\protobuf\stubs\atomicops_internals_atomicword_compat.h
copy "${PROTOBUF_SOURCE_WIN32_PATH}\..\src\google\protobuf\stubs\atomicops_internals_generic_c11_atomic.h" include\google\protobuf\stubs\atomicops_internals_generic_c11_atomic.h
copy "${PROTOBUF_SOURCE_WIN32_PATH}\..\src\google\protobuf\stubs\atomicops_internals_generic_gcc.h" include\google\protobuf\stubs\atomicops_internals_generic_gcc.h
copy "${PROTOBUF_SOURCE_WIN32_PATH}\..\src\google\protobuf\stubs\atomicops_internals_mips_gcc.h" include\google\protobuf\stubs\atomicops_internals_mips_gcc.h
...
...
src/Makefile.am
View file @
0971efb1
...
...
@@ -71,7 +71,6 @@ nobase_include_HEADERS = \
google/protobuf/stubs/atomicops_internals_arm64_gcc.h
\
google/protobuf/stubs/atomicops_internals_arm_gcc.h
\
google/protobuf/stubs/atomicops_internals_arm_qnx.h
\
google/protobuf/stubs/atomicops_internals_atomicword_compat.h
\
google/protobuf/stubs/atomicops_internals_generic_c11_atomic.h
\
google/protobuf/stubs/atomicops_internals_generic_gcc.h
\
google/protobuf/stubs/atomicops_internals_mips_gcc.h
\
...
...
src/google/protobuf/stubs/atomicops.h
View file @
0971efb1
...
...
@@ -67,15 +67,16 @@ namespace internal {
typedef
intptr_t
Atomic32
;
typedef
int64
Atomic64
;
#else
typedef
int32
Atomic32
;
// We need to be able to go between Atomic64 and AtomicWord implicitly. This
// means Atomic64 and AtomicWord should be the same type on 64-bit.
#if defined(__ILP32__) || defined(GOOGLE_PROTOBUF_OS_NACL)
// NaCl's intptr_t is not actually 64-bits on 64-bit!
// http://code.google.com/p/nativeclient/issues/detail?id=1162
// sparcv9's pointer type is 32bits
typedef
intptr_t
Atomic32
;
typedef
int64
Atomic64
;
#else
typedef
int32
Atomic32
;
typedef
intptr_t
Atomic64
;
#endif
#endif
...
...
@@ -229,12 +230,6 @@ Atomic64 Release_Load(volatile const Atomic64* ptr);
#error GOOGLE_PROTOBUF_ATOMICOPS_ERROR
#endif
// On some platforms we need additional declarations to make AtomicWord
// compatible with our other Atomic* types.
#if defined(GOOGLE_PROTOBUF_OS_APPLE)
#include <google/protobuf/stubs/atomicops_internals_atomicword_compat.h>
#endif
#undef GOOGLE_PROTOBUF_ATOMICOPS_ERROR
#endif // GOOGLE_PROTOBUF_NO_THREAD_SAFETY
...
...
src/google/protobuf/stubs/atomicops_internals_atomicword_compat.h
deleted
100644 → 0
View file @
662e8b20
// Protocol Buffers - Google's data interchange format
// Copyright 2012 Google Inc. All rights reserved.
// https://developers.google.com/protocol-buffers/
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
// met:
//
// * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above
// copyright notice, this list of conditions and the following disclaimer
// in the documentation and/or other materials provided with the
// distribution.
// * Neither the name of Google Inc. nor the names of its
// contributors may be used to endorse or promote products derived from
// this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// This file is an internal atomic implementation, use atomicops.h instead.
#ifndef GOOGLE_PROTOBUF_ATOMICOPS_INTERNALS_ATOMICWORD_COMPAT_H_
#define GOOGLE_PROTOBUF_ATOMICOPS_INTERNALS_ATOMICWORD_COMPAT_H_
// AtomicWord is a synonym for intptr_t, and Atomic32 is a synonym for int32,
// which in turn means int. On some LP32 platforms, intptr_t is an int, but
// on others, it's a long. When AtomicWord and Atomic32 are based on different
// fundamental types, their pointers are incompatible.
//
// This file defines function overloads to allow both AtomicWord and Atomic32
// data to be used with this interface.
//
// On LP64 platforms, AtomicWord and Atomic64 are both always long,
// so this problem doesn't occur.
#if !defined(GOOGLE_PROTOBUF_ARCH_64_BIT)
namespace
google
{
namespace
protobuf
{
namespace
internal
{
inline
AtomicWord
NoBarrier_CompareAndSwap
(
volatile
AtomicWord
*
ptr
,
AtomicWord
old_value
,
AtomicWord
new_value
)
{
return
NoBarrier_CompareAndSwap
(
reinterpret_cast
<
volatile
Atomic32
*>
(
ptr
),
old_value
,
new_value
);
}
inline
AtomicWord
NoBarrier_AtomicExchange
(
volatile
AtomicWord
*
ptr
,
AtomicWord
new_value
)
{
return
NoBarrier_AtomicExchange
(
reinterpret_cast
<
volatile
Atomic32
*>
(
ptr
),
new_value
);
}
inline
AtomicWord
NoBarrier_AtomicIncrement
(
volatile
AtomicWord
*
ptr
,
AtomicWord
increment
)
{
return
NoBarrier_AtomicIncrement
(
reinterpret_cast
<
volatile
Atomic32
*>
(
ptr
),
increment
);
}
inline
AtomicWord
Barrier_AtomicIncrement
(
volatile
AtomicWord
*
ptr
,
AtomicWord
increment
)
{
return
Barrier_AtomicIncrement
(
reinterpret_cast
<
volatile
Atomic32
*>
(
ptr
),
increment
);
}
inline
AtomicWord
Acquire_CompareAndSwap
(
volatile
AtomicWord
*
ptr
,
AtomicWord
old_value
,
AtomicWord
new_value
)
{
return
Acquire_CompareAndSwap
(
reinterpret_cast
<
volatile
Atomic32
*>
(
ptr
),
old_value
,
new_value
);
}
inline
AtomicWord
Release_CompareAndSwap
(
volatile
AtomicWord
*
ptr
,
AtomicWord
old_value
,
AtomicWord
new_value
)
{
return
Release_CompareAndSwap
(
reinterpret_cast
<
volatile
Atomic32
*>
(
ptr
),
old_value
,
new_value
);
}
inline
void
NoBarrier_Store
(
volatile
AtomicWord
*
ptr
,
AtomicWord
value
)
{
NoBarrier_Store
(
reinterpret_cast
<
volatile
Atomic32
*>
(
ptr
),
value
);
}
inline
void
Acquire_Store
(
volatile
AtomicWord
*
ptr
,
AtomicWord
value
)
{
return
Acquire_Store
(
reinterpret_cast
<
volatile
Atomic32
*>
(
ptr
),
value
);
}
inline
void
Release_Store
(
volatile
AtomicWord
*
ptr
,
AtomicWord
value
)
{
return
Release_Store
(
reinterpret_cast
<
volatile
Atomic32
*>
(
ptr
),
value
);
}
inline
AtomicWord
NoBarrier_Load
(
volatile
const
AtomicWord
*
ptr
)
{
return
NoBarrier_Load
(
reinterpret_cast
<
volatile
const
Atomic32
*>
(
ptr
));
}
inline
AtomicWord
Acquire_Load
(
volatile
const
AtomicWord
*
ptr
)
{
return
Acquire_Load
(
reinterpret_cast
<
volatile
const
Atomic32
*>
(
ptr
));
}
inline
AtomicWord
Release_Load
(
volatile
const
AtomicWord
*
ptr
)
{
return
Release_Load
(
reinterpret_cast
<
volatile
const
Atomic32
*>
(
ptr
));
}
}
// namespace internal
}
// namespace protobuf
}
// namespace google
#endif // !defined(GOOGLE_PROTOBUF_ARCH_64_BIT)
#endif // GOOGLE_PROTOBUF_ATOMICOPS_INTERNALS_ATOMICWORD_COMPAT_H_
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