diff options
author | Vladimir Marko <vmarko@google.com> | 2014-05-02 14:40:15 +0100 |
---|---|---|
committer | Vladimir Marko <vmarko@google.com> | 2014-05-13 11:43:22 +0100 |
commit | 7624d25dad2d1ba25969ae704fccf68649103ae5 (patch) | |
tree | de72194b76a4e23e0b15ec4085447ae7e4425815 /runtime/arch/x86/context_x86.cc | |
parent | e1910f1d802dff79bba5ef61e1c4fd0b95f6e5b0 (diff) | |
download | android_art-7624d25dad2d1ba25969ae704fccf68649103ae5.tar.gz android_art-7624d25dad2d1ba25969ae704fccf68649103ae5.tar.bz2 android_art-7624d25dad2d1ba25969ae704fccf68649103ae5.zip |
Move quick frame info to OatQuickMethodHeader.
Rename OatMethodHeader to OatQuickMethodHeader, move frame
info from OatMethodOffsets to OatQuickMethodHeader. Retrieve
the info from other places for non-quick methods (portable
compiled bytecode or jni stub, generic jni, runtime,
abstract and proxy).
This change has a libcore/ companion CL
"Remove ArtMethod's quick fields for frame size and spills."
https://android-review.googlesource.com/94164
Bug: 11767815
Change-Id: I0e31a7875d76732e1ec479c86b9b5ca01203507f
Diffstat (limited to 'runtime/arch/x86/context_x86.cc')
-rw-r--r-- | runtime/arch/x86/context_x86.cc | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/runtime/arch/x86/context_x86.cc b/runtime/arch/x86/context_x86.cc index c68d76a471..8c98d910c5 100644 --- a/runtime/arch/x86/context_x86.cc +++ b/runtime/arch/x86/context_x86.cc @@ -16,8 +16,9 @@ #include "context_x86.h" -#include "mirror/art_method.h" +#include "mirror/art_method-inl.h" #include "mirror/object-inl.h" +#include "quick/quick_method_frame_info.h" #include "stack.h" namespace art { @@ -37,16 +38,15 @@ void X86Context::Reset() { void X86Context::FillCalleeSaves(const StackVisitor& fr) { mirror::ArtMethod* method = fr.GetMethod(); - uint32_t core_spills = method->GetCoreSpillMask(); - size_t spill_count = POPCOUNT(core_spills); - DCHECK_EQ(method->GetFpSpillMask(), 0u); - size_t frame_size = method->GetFrameSizeInBytes(); + const QuickMethodFrameInfo frame_info = method->GetQuickFrameInfo(); + size_t spill_count = POPCOUNT(frame_info.CoreSpillMask()); + DCHECK_EQ(frame_info.FpSpillMask(), 0u); if (spill_count > 0) { // Lowest number spill is farthest away, walk registers and fill into context. int j = 2; // Offset j to skip return address spill. for (int i = 0; i < kNumberOfCpuRegisters; i++) { - if (((core_spills >> i) & 1) != 0) { - gprs_[i] = fr.CalleeSaveAddress(spill_count - j, frame_size); + if (((frame_info.CoreSpillMask() >> i) & 1) != 0) { + gprs_[i] = fr.CalleeSaveAddress(spill_count - j, frame_info.FrameSizeInBytes()); j++; } } |