diff options
author | Nicolas Geoffray <ngeoffray@google.com> | 2014-12-09 14:26:32 +0000 |
---|---|---|
committer | Nicolas Geoffray <ngeoffray@google.com> | 2014-12-09 14:49:02 +0000 |
commit | 376b2bbf7c39108223a7a01568a7b4b04d84eeac (patch) | |
tree | f6fdbe6180c3d330bc24aa35a7d9fa51f3eb1c55 /compiler/compiled_method.cc | |
parent | b1a38e246cfbfb21100d9c9e57f33970e824f075 (diff) | |
download | art-376b2bbf7c39108223a7a01568a7b4b04d84eeac.zip art-376b2bbf7c39108223a7a01568a7b4b04d84eeac.tar.gz art-376b2bbf7c39108223a7a01568a7b4b04d84eeac.tar.bz2 |
Ensure stack maps are 4 byte aligned.
With the recent move to gcc 4.9, we are hitting alignment
SIGBUS on ARM. The reason is that gcc will optimize two consecutive
32bits loads into one 64bits load, and the instruction (ldrd)
will fail if the data is not aligned.
Also removed the emission of mapping table when a method is optimized.
The information can be found in the StackMap itself.
Change-Id: Icf79406c18a3f4db3c05d52fc2c0dd2e35bf0f8f
Diffstat (limited to 'compiler/compiled_method.cc')
-rw-r--r-- | compiler/compiled_method.cc | 3 |
1 files changed, 1 insertions, 2 deletions
diff --git a/compiler/compiled_method.cc b/compiler/compiled_method.cc index 698bf3b..e292834 100644 --- a/compiler/compiled_method.cc +++ b/compiler/compiled_method.cc @@ -170,14 +170,13 @@ CompiledMethod::CompiledMethod(CompilerDriver* driver, const size_t frame_size_in_bytes, const uint32_t core_spill_mask, const uint32_t fp_spill_mask, - const std::vector<uint8_t>& mapping_table, const std::vector<uint8_t>& stack_map) : CompiledCode(driver, instruction_set, quick_code), frame_size_in_bytes_(frame_size_in_bytes), core_spill_mask_(core_spill_mask), fp_spill_mask_(fp_spill_mask), src_mapping_table_(driver->DeduplicateSrcMappingTable(SrcMap())), - mapping_table_(driver->DeduplicateMappingTable(mapping_table)), + mapping_table_(nullptr), vmap_table_(driver->DeduplicateVMapTable(stack_map)), gc_map_(nullptr), cfi_info_(nullptr), |