diff options
author | Mathieu Chartier <mathieuc@google.com> | 2014-03-13 12:22:56 -0700 |
---|---|---|
committer | Mathieu Chartier <mathieuc@google.com> | 2014-03-14 10:15:18 -0700 |
commit | 8fa2dad7fe7909c8335101d6c8904ae997cdf29f (patch) | |
tree | b4809584363705a640b8a4d5c87f9fa2af59c41e /runtime/class_linker_test.cc | |
parent | 282cbe489046face5475991aaa1ecb5f1deba107 (diff) | |
download | art-8fa2dad7fe7909c8335101d6c8904ae997cdf29f.tar.gz art-8fa2dad7fe7909c8335101d6c8904ae997cdf29f.tar.bz2 art-8fa2dad7fe7909c8335101d6c8904ae997cdf29f.zip |
Refactor reference code into mirror namespace.
Added two new files: mirror/reference.h and mirror/reference-inl.h.
Change-Id: Ibe3ff6379aef7096ff130594535b7f7c0b7dabce
Diffstat (limited to 'runtime/class_linker_test.cc')
-rw-r--r-- | runtime/class_linker_test.cc | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/runtime/class_linker_test.cc b/runtime/class_linker_test.cc index d0555fff0f..7eb7b01e65 100644 --- a/runtime/class_linker_test.cc +++ b/runtime/class_linker_test.cc @@ -32,6 +32,7 @@ #include "mirror/object-inl.h" #include "mirror/object_array-inl.h" #include "mirror/proxy.h" +#include "mirror/reference.h" #include "mirror/stack_trace_element.h" #include "sirt_ref.h" @@ -624,6 +625,25 @@ struct DexCacheOffsets : public CheckOffsets<mirror::DexCache> { }; }; +struct ReferenceOffsets : public CheckOffsets<mirror::Reference> { + ReferenceOffsets() : CheckOffsets<mirror::Reference>(false, "Ljava/lang/ref/Reference;") { + // alphabetical references + offsets.push_back(CheckOffset(OFFSETOF_MEMBER(mirror::Reference, pending_next_), "pendingNext")); + offsets.push_back(CheckOffset(OFFSETOF_MEMBER(mirror::Reference, queue_), "queue")); + offsets.push_back(CheckOffset(OFFSETOF_MEMBER(mirror::Reference, queue_next_), "queueNext")); + offsets.push_back(CheckOffset(OFFSETOF_MEMBER(mirror::Reference, referent_), "referent")); + }; +}; + +struct FinalizerReferenceOffsets : public CheckOffsets<mirror::FinalizerReference> { + FinalizerReferenceOffsets() : CheckOffsets<mirror::FinalizerReference>(false, "Ljava/lang/ref/FinalizerReference;") { + // alphabetical references + offsets.push_back(CheckOffset(OFFSETOF_MEMBER(mirror::FinalizerReference, next_), "next")); + offsets.push_back(CheckOffset(OFFSETOF_MEMBER(mirror::FinalizerReference, prev_), "prev")); + offsets.push_back(CheckOffset(OFFSETOF_MEMBER(mirror::FinalizerReference, zombie_), "zombie")); + }; +}; + // C++ fields must exactly match the fields in the Java classes. If this fails, // reorder the fields in the C++ class. Managed class fields are ordered by // ClassLinker::LinkFields. @@ -639,6 +659,8 @@ TEST_F(ClassLinkerTest, ValidateFieldOrderOfJavaCppUnionClasses) { EXPECT_TRUE(ClassLoaderOffsets().Check()); EXPECT_TRUE(ProxyOffsets().Check()); EXPECT_TRUE(DexCacheOffsets().Check()); + EXPECT_TRUE(ReferenceOffsets().Check()); + EXPECT_TRUE(FinalizerReferenceOffsets().Check()); EXPECT_TRUE(ClassClassOffsets().Check()); EXPECT_TRUE(StringClassOffsets().Check()); |