diff options
author | Jeff Hao <jeffhao@google.com> | 2014-01-15 13:49:50 -0800 |
---|---|---|
committer | Jeff Hao <jeffhao@google.com> | 2015-04-27 18:54:52 -0700 |
commit | 848f70a3d73833fc1bf3032a9ff6812e429661d9 (patch) | |
tree | b0349b3a40aab5a915af491b100659a5ca9fbbf6 /runtime/thread.h | |
parent | d14438f0c5071962be7fab572b54687d32d9d087 (diff) | |
download | art-848f70a3d73833fc1bf3032a9ff6812e429661d9.tar.gz art-848f70a3d73833fc1bf3032a9ff6812e429661d9.tar.bz2 art-848f70a3d73833fc1bf3032a9ff6812e429661d9.zip |
Replace String CharArray with internal uint16_t array.
Summary of high level changes:
- Adds compiler inliner support to identify string init methods
- Adds compiler support (quick & optimizing) with new invoke code path
that calls method off the thread pointer
- Adds thread entrypoints for all string init methods
- Adds map to verifier to log when receiver of string init has been
copied to other registers. used by compiler and interpreter
Change-Id: I797b992a8feb566f9ad73060011ab6f51eb7ce01
Diffstat (limited to 'runtime/thread.h')
-rw-r--r-- | runtime/thread.h | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/runtime/thread.h b/runtime/thread.h index 35b785df63..e766daabed 100644 --- a/runtime/thread.h +++ b/runtime/thread.h @@ -541,6 +541,16 @@ class Thread { } public: + static uint32_t QuickEntryPointOffsetWithSize(size_t quick_entrypoint_offset, + size_t pointer_size) { + DCHECK(pointer_size == 4 || pointer_size == 8) << pointer_size; + if (pointer_size == 4) { + return QuickEntryPointOffset<4>(quick_entrypoint_offset).Uint32Value(); + } else { + return QuickEntryPointOffset<8>(quick_entrypoint_offset).Uint32Value(); + } + } + template<size_t pointer_size> static ThreadOffset<pointer_size> QuickEntryPointOffset(size_t quick_entrypoint_offset) { return ThreadOffsetFromTlsPtr<pointer_size>( @@ -911,6 +921,8 @@ class Thread { void PushVerifier(verifier::MethodVerifier* verifier); void PopVerifier(verifier::MethodVerifier* verifier); + void InitStringEntryPoints(); + private: explicit Thread(bool daemon); ~Thread() LOCKS_EXCLUDED(Locks::mutator_lock_, |