diff options
author | 2017-08-02 18:17:21 +0000 | |
---|---|---|
committer | 2017-08-02 18:17:21 +0000 | |
commit | 42e88a0e5ffaba52fcf0888b5cab0eff3e2ec351 (patch) | |
tree | 7f0f8d3ce411e3544f1b2e41f2459287bbbc1a38 /compiler/driver/compiler_driver.cc | |
parent | d335e7b4d034bc8b69efde641779c6e1cd7bba42 (diff) | |
parent | bf755fefbfcfbb2677a519c12efe7890f3879854 (diff) |
Merge "Fix verifier deps determinism"
Diffstat (limited to 'compiler/driver/compiler_driver.cc')
-rw-r--r-- | compiler/driver/compiler_driver.cc | 8 |
1 files changed, 3 insertions, 5 deletions
diff --git a/compiler/driver/compiler_driver.cc b/compiler/driver/compiler_driver.cc index 0b1bce62c9..bd530ac6a6 100644 --- a/compiler/driver/compiler_driver.cc +++ b/compiler/driver/compiler_driver.cc @@ -1935,14 +1935,12 @@ bool CompilerDriver::FastVerify(jobject jclass_loader, // time. So instead we assume these classes still need to be verified at // runtime. for (const DexFile* dex_file : dex_files) { - // Fetch the list of unverified classes and turn it into a set for faster - // lookups. - const std::vector<dex::TypeIndex>& unverified_classes = + // Fetch the list of unverified classes. + const std::set<dex::TypeIndex>& unverified_classes = verifier_deps->GetUnverifiedClasses(*dex_file); - std::set<dex::TypeIndex> set(unverified_classes.begin(), unverified_classes.end()); for (uint32_t i = 0; i < dex_file->NumClassDefs(); ++i) { const DexFile::ClassDef& class_def = dex_file->GetClassDef(i); - if (set.find(class_def.class_idx_) == set.end()) { + if (unverified_classes.find(class_def.class_idx_) == unverified_classes.end()) { if (compiler_only_verifies) { // Just update the compiled_classes_ map. The compiler doesn't need to resolve // the type. |