diff options
| author | 2016-12-13 09:34:11 +0000 | |
|---|---|---|
| committer | 2016-12-13 09:34:12 +0000 | |
| commit | fb678bfaad7f432861d26bde8343d53fadd68c07 (patch) | |
| tree | b39b2c10875b15207e9de9b7474b1834aa9aa6ff /compiler/optimizing/code_generator.cc | |
| parent | 7c73bf3518eea7544406eadfed6946411c54a267 (diff) | |
| parent | 22384aeab988df7fa5ccdc48a668589c5f602c39 (diff) | |
Merge "Revert "Revert "Add kJitTableAddress for HLoadClass."""
Diffstat (limited to 'compiler/optimizing/code_generator.cc')
| -rw-r--r-- | compiler/optimizing/code_generator.cc | 8 | 
1 files changed, 8 insertions, 0 deletions
| diff --git a/compiler/optimizing/code_generator.cc b/compiler/optimizing/code_generator.cc index fa6a5225e7..402eeee65f 100644 --- a/compiler/optimizing/code_generator.cc +++ b/compiler/optimizing/code_generator.cc @@ -1402,6 +1402,14 @@ void CodeGenerator::EmitJitRoots(uint8_t* code,      entry.second = index;      ++index;    } +  for (auto& entry : jit_class_roots_) { +    // Update the `roots` with the class, and replace the address temporarily +    // stored to the index in the table. +    uint64_t address = entry.second; +    roots->Set(index, reinterpret_cast<StackReference<mirror::Class>*>(address)->AsMirrorPtr()); +    entry.second = index; +    ++index; +  }    EmitJitRootPatches(code, roots_data);  } |