summaryrefslogtreecommitdiffstats
path: root/runtime
diff options
context:
space:
mode:
authorBrian Carlstrom <bdc@google.com>2013-07-19 11:24:52 -0700
committerAndroid Git Automerger <android-git-automerger@android.com>2013-07-19 11:24:52 -0700
commitbe45988e2ea837e73fe96f08a0a8be4112786877 (patch)
treec59c80ab2957f48f23ce96439685c87a000fba8f /runtime
parentd35311bcf4da508aefda65e6328cd18b878cb094 (diff)
parent6eb5288264d68276085855bd041fa74fbca6827c (diff)
downloadart-be45988e2ea837e73fe96f08a0a8be4112786877.zip
art-be45988e2ea837e73fe96f08a0a8be4112786877.tar.gz
art-be45988e2ea837e73fe96f08a0a8be4112786877.tar.bz2
am 6eb52882: Conditionally define non-Android pthread structures
* commit '6eb5288264d68276085855bd041fa74fbca6827c': Conditionally define non-Android pthread structures
Diffstat (limited to 'runtime')
-rw-r--r--runtime/base/mutex.cc12
1 files changed, 10 insertions, 2 deletions
diff --git a/runtime/base/mutex.cc b/runtime/base/mutex.cc
index cb66240..3265a13 100644
--- a/runtime/base/mutex.cc
+++ b/runtime/base/mutex.cc
@@ -30,9 +30,11 @@
namespace art {
+#if defined(__APPLE__)
+
// This works on Mac OS 10.6 but hasn't been tested on older releases.
struct __attribute__((__may_alias__)) darwin_pthread_mutex_t {
- long padding0; // NOLINT(runtime/int)
+ long padding0; // NOLINT(runtime/int) exact match to darwin type
int padding1;
uint32_t padding2;
int16_t padding3;
@@ -43,7 +45,7 @@ struct __attribute__((__may_alias__)) darwin_pthread_mutex_t {
};
struct __attribute__((__may_alias__)) darwin_pthread_rwlock_t {
- long padding0; // NOLINT(runtime/int)
+ long padding0; // NOLINT(runtime/int) exact match to darwin type
pthread_mutex_t padding1;
int padding2;
pthread_cond_t padding3;
@@ -54,6 +56,10 @@ struct __attribute__((__may_alias__)) darwin_pthread_rwlock_t {
// ...other stuff we don't care about.
};
+#endif // __APPLE__
+
+#if defined(__GLIBC__)
+
struct __attribute__((__may_alias__)) glibc_pthread_mutex_t {
int32_t padding0[2];
int owner;
@@ -70,6 +76,8 @@ struct __attribute__((__may_alias__)) glibc_pthread_rwlock_t {
// ...other stuff we don't care about.
};
+#endif // __GLIBC__
+
#if ART_USE_FUTEXES
static bool ComputeRelativeTimeSpec(timespec* result_ts, const timespec& lhs, const timespec& rhs) {
const int32_t one_sec = 1000 * 1000 * 1000; // one second in nanoseconds.