diff options
| author | 2015-06-17 17:01:16 +0000 | |
|---|---|---|
| committer | 2015-06-17 17:01:16 +0000 | |
| commit | 43d154bed3ad0bba766211af1f2637500d30a93f (patch) | |
| tree | 53de01908990954cdf0f46168cb437d5c12ebf2e /compiler/optimizing | |
| parent | cb5dc7f4b795c3ef7ec48989542efdbe44898b94 (diff) | |
| parent | 15875b0d36fce555534bb840b13b39d61fd108f2 (diff) | |
Merge "Revert "ART: Allow PackedSwitch instructions with zero targets""
Diffstat (limited to 'compiler/optimizing')
| -rw-r--r-- | compiler/optimizing/builder.cc | 14 | 
1 files changed, 2 insertions, 12 deletions
| diff --git a/compiler/optimizing/builder.cc b/compiler/optimizing/builder.cc index cdd7636c0b..1f9287cbfc 100644 --- a/compiler/optimizing/builder.cc +++ b/compiler/optimizing/builder.cc @@ -1210,20 +1210,14 @@ bool HGraphBuilder::NeedsAccessCheck(uint32_t type_index) const {  }  void HGraphBuilder::BuildPackedSwitch(const Instruction& instruction, uint32_t dex_pc) { -  // Verifier guarantees that the payload for PackedSwitch contains: -  //   (a) number of entries (may be zero) -  //   (b) first and lowest switch case value (entry 0, always present) -  //   (c) list of target pcs (entries 1 <= i <= N)    SwitchTable table(instruction, dex_pc, false);    // Value to test against.    HInstruction* value = LoadLocal(instruction.VRegA(), Primitive::kPrimInt); -  // Retrieve number of entries.    uint16_t num_entries = table.GetNumEntries(); -  if (num_entries == 0) { -    return; -  } +  // There should be at least one entry here. +  DCHECK_GT(num_entries, 0U);    // Chained cmp-and-branch, starting from starting_key.    int32_t starting_key = table.GetEntryAt(0); @@ -1235,10 +1229,6 @@ void HGraphBuilder::BuildPackedSwitch(const Instruction& instruction, uint32_t d  }  void HGraphBuilder::BuildSparseSwitch(const Instruction& instruction, uint32_t dex_pc) { -  // Verifier guarantees that the payload for SparseSwitch contains: -  //   (a) number of entries (may be zero) -  //   (b) sorted key values (entries 0 <= i < N) -  //   (c) target pcs corresponding to the switch values (entries N <= i < 2*N)    SwitchTable table(instruction, dex_pc, true);    // Value to test against. |