Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(332)

Side by Side Diff: src/compiler/instruction-selector.cc

Issue 1811333002: Ensure Schedules generated by the RawMachineAssembler are in edge-split form (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Added and fixed tests Created 4 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | src/compiler/raw-machine-assembler.cc » ('j') | src/compiler/schedule.cc » ('J')
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 the V8 project authors. All rights reserved. 1 // Copyright 2014 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "src/compiler/instruction-selector.h" 5 #include "src/compiler/instruction-selector.h"
6 6
7 #include <limits> 7 #include <limits>
8 8
9 #include "src/base/adapters.h" 9 #include "src/base/adapters.h"
10 #include "src/compiler/instruction-selector-impl.h" 10 #include "src/compiler/instruction-selector-impl.h"
(...skipping 769 matching lines...) Expand 10 before | Expand all | Expand 10 after
780 BasicBlock* tbranch = block->SuccessorAt(0); 780 BasicBlock* tbranch = block->SuccessorAt(0);
781 BasicBlock* fbranch = block->SuccessorAt(1); 781 BasicBlock* fbranch = block->SuccessorAt(1);
782 if (tbranch == fbranch) return VisitGoto(tbranch); 782 if (tbranch == fbranch) return VisitGoto(tbranch);
783 return VisitBranch(input, tbranch, fbranch); 783 return VisitBranch(input, tbranch, fbranch);
784 } 784 }
785 case BasicBlock::kSwitch: { 785 case BasicBlock::kSwitch: {
786 DCHECK_EQ(IrOpcode::kSwitch, input->opcode()); 786 DCHECK_EQ(IrOpcode::kSwitch, input->opcode());
787 SwitchInfo sw; 787 SwitchInfo sw;
788 // Last successor must be Default. 788 // Last successor must be Default.
789 sw.default_branch = block->successors().back(); 789 sw.default_branch = block->successors().back();
790 DCHECK_EQ(IrOpcode::kIfDefault, sw.default_branch->front()->opcode()); 790 BasicBlock* branch = sw.default_branch;
791 // The scheduler may have inserted a split-edge block between the switch
792 // and the default label, skip it if necessary.
793 if (branch->size() == 0) {
794 DCHECK_EQ(BasicBlock::kGoto, branch->control());
795 DCHECK_EQ(1, branch->SuccessorCount());
796 DCHECK_EQ(1, branch->PredecessorCount());
797 branch = branch->SuccessorAt(0);
798 }
799 USE(branch);
800 DCHECK_EQ(IrOpcode::kIfDefault, branch->front()->opcode());
791 // All other successors must be cases. 801 // All other successors must be cases.
792 sw.case_count = block->SuccessorCount() - 1; 802 sw.case_count = block->SuccessorCount() - 1;
793 sw.case_branches = &block->successors().front(); 803 sw.case_branches = &block->successors().front();
794 // Determine case values and their min/max. 804 // Determine case values and their min/max.
795 sw.case_values = zone()->NewArray<int32_t>(sw.case_count); 805 sw.case_values = zone()->NewArray<int32_t>(sw.case_count);
796 sw.min_value = std::numeric_limits<int32_t>::max(); 806 sw.min_value = std::numeric_limits<int32_t>::max();
797 sw.max_value = std::numeric_limits<int32_t>::min(); 807 sw.max_value = std::numeric_limits<int32_t>::min();
798 for (size_t index = 0; index < sw.case_count; ++index) { 808 for (size_t index = 0; index < sw.case_count; ++index) {
799 BasicBlock* branch = sw.case_branches[index]; 809 branch = sw.case_branches[index];
810 // The scheduler may have inserted a split-edge block between the switch
titzer 2016/03/21 08:06:03 Not sure this is sound. The split-edge blocks are
danno 2016/03/22 07:53:44 As discussed, moved the logic to ensure the extra
811 // and the label, skip it if necessary.
812 if (branch->size() == 0) {
813 DCHECK_EQ(BasicBlock::kGoto, branch->control());
814 DCHECK_EQ(1, branch->SuccessorCount());
815 DCHECK_EQ(1, branch->PredecessorCount());
816 branch = branch->SuccessorAt(0);
817 }
800 int32_t value = OpParameter<int32_t>(branch->front()->op()); 818 int32_t value = OpParameter<int32_t>(branch->front()->op());
801 sw.case_values[index] = value; 819 sw.case_values[index] = value;
802 if (sw.min_value > value) sw.min_value = value; 820 if (sw.min_value > value) sw.min_value = value;
803 if (sw.max_value < value) sw.max_value = value; 821 if (sw.max_value < value) sw.max_value = value;
804 } 822 }
805 DCHECK_LE(sw.min_value, sw.max_value); 823 DCHECK_LE(sw.min_value, sw.max_value);
806 // Note that {value_range} can be 0 if {min_value} is -2^31 and 824 // Note that {value_range} can be 0 if {min_value} is -2^31 and
807 // {max_value} 825 // {max_value}
808 // is 2^31-1, so don't assume that it's non-zero below. 826 // is 2^31-1, so don't assume that it's non-zero below.
809 sw.value_range = 1u + bit_cast<uint32_t>(sw.max_value) - 827 sw.value_range = 1u + bit_cast<uint32_t>(sw.max_value) -
(...skipping 975 matching lines...) Expand 10 before | Expand all | Expand 10 after
1785 return new (instruction_zone()) FrameStateDescriptor( 1803 return new (instruction_zone()) FrameStateDescriptor(
1786 instruction_zone(), state_info.type(), state_info.bailout_id(), 1804 instruction_zone(), state_info.type(), state_info.bailout_id(),
1787 state_info.state_combine(), parameters, locals, stack, 1805 state_info.state_combine(), parameters, locals, stack,
1788 state_info.shared_info(), outer_state); 1806 state_info.shared_info(), outer_state);
1789 } 1807 }
1790 1808
1791 1809
1792 } // namespace compiler 1810 } // namespace compiler
1793 } // namespace internal 1811 } // namespace internal
1794 } // namespace v8 1812 } // namespace v8
OLDNEW
« no previous file with comments | « no previous file | src/compiler/raw-machine-assembler.cc » ('j') | src/compiler/schedule.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698