Optimize numeric comparison with known successors.
R=svenpanne@chromium.org Review URL: https://codereview.chromium.org/246133005 git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@20880 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
This commit is contained in:
parent
eeb1d7020e
commit
376bff2411
@ -1676,6 +1676,8 @@ LInstruction* LChunkBuilder::DoCompareGeneric(HCompareGeneric* instr) {
|
|||||||
|
|
||||||
LInstruction* LChunkBuilder::DoCompareNumericAndBranch(
|
LInstruction* LChunkBuilder::DoCompareNumericAndBranch(
|
||||||
HCompareNumericAndBranch* instr) {
|
HCompareNumericAndBranch* instr) {
|
||||||
|
LInstruction* goto_instr = CheckElideControlInstruction(instr);
|
||||||
|
if (goto_instr != NULL) return goto_instr;
|
||||||
Representation r = instr->representation();
|
Representation r = instr->representation();
|
||||||
if (r.IsSmiOrInteger32()) {
|
if (r.IsSmiOrInteger32()) {
|
||||||
ASSERT(instr->left()->representation().Equals(r));
|
ASSERT(instr->left()->representation().Equals(r));
|
||||||
|
@ -1251,8 +1251,9 @@ LInstruction* LChunkBuilder::DoClassOfTestAndBranch(
|
|||||||
|
|
||||||
LInstruction* LChunkBuilder::DoCompareNumericAndBranch(
|
LInstruction* LChunkBuilder::DoCompareNumericAndBranch(
|
||||||
HCompareNumericAndBranch* instr) {
|
HCompareNumericAndBranch* instr) {
|
||||||
|
LInstruction* goto_instr = CheckElideControlInstruction(instr);
|
||||||
|
if (goto_instr != NULL) return goto_instr;
|
||||||
Representation r = instr->representation();
|
Representation r = instr->representation();
|
||||||
|
|
||||||
if (r.IsSmiOrInteger32()) {
|
if (r.IsSmiOrInteger32()) {
|
||||||
ASSERT(instr->left()->representation().Equals(r));
|
ASSERT(instr->left()->representation().Equals(r));
|
||||||
ASSERT(instr->right()->representation().Equals(r));
|
ASSERT(instr->right()->representation().Equals(r));
|
||||||
|
@ -3303,6 +3303,21 @@ void HCompareHoleAndBranch::InferRepresentation(
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool HCompareNumericAndBranch::KnownSuccessorBlock(HBasicBlock** block) {
|
||||||
|
if (left() == right() &&
|
||||||
|
left()->representation().IsSmiOrInteger32()) {
|
||||||
|
*block = (token() == Token::EQ ||
|
||||||
|
token() == Token::EQ_STRICT ||
|
||||||
|
token() == Token::LTE ||
|
||||||
|
token() == Token::GTE)
|
||||||
|
? FirstSuccessor() : SecondSuccessor();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
*block = NULL;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
bool HCompareMinusZeroAndBranch::KnownSuccessorBlock(HBasicBlock** block) {
|
bool HCompareMinusZeroAndBranch::KnownSuccessorBlock(HBasicBlock** block) {
|
||||||
if (FLAG_fold_constants && value()->IsConstant()) {
|
if (FLAG_fold_constants && value()->IsConstant()) {
|
||||||
HConstant* constant = HConstant::cast(value());
|
HConstant* constant = HConstant::cast(value());
|
||||||
|
@ -4218,6 +4218,9 @@ class HCompareNumericAndBranch : public HTemplateControlInstruction<2, 2> {
|
|||||||
virtual Representation observed_input_representation(int index) V8_OVERRIDE {
|
virtual Representation observed_input_representation(int index) V8_OVERRIDE {
|
||||||
return observed_input_representation_[index];
|
return observed_input_representation_[index];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
virtual bool KnownSuccessorBlock(HBasicBlock** block) V8_OVERRIDE;
|
||||||
|
|
||||||
virtual void PrintDataTo(StringStream* stream) V8_OVERRIDE;
|
virtual void PrintDataTo(StringStream* stream) V8_OVERRIDE;
|
||||||
|
|
||||||
void SetOperandPositions(Zone* zone,
|
void SetOperandPositions(Zone* zone,
|
||||||
|
@ -1314,11 +1314,8 @@ HValue* HGraphBuilder::BuildCheckForCapacityGrow(
|
|||||||
|
|
||||||
HValue* max_gap = Add<HConstant>(static_cast<int32_t>(JSObject::kMaxGap));
|
HValue* max_gap = Add<HConstant>(static_cast<int32_t>(JSObject::kMaxGap));
|
||||||
HValue* max_capacity = AddUncasted<HAdd>(current_capacity, max_gap);
|
HValue* max_capacity = AddUncasted<HAdd>(current_capacity, max_gap);
|
||||||
IfBuilder key_checker(this);
|
|
||||||
key_checker.If<HCompareNumericAndBranch>(key, max_capacity, Token::LT);
|
Add<HBoundsCheck>(key, max_capacity);
|
||||||
key_checker.Then();
|
|
||||||
key_checker.ElseDeopt("Key out of capacity range");
|
|
||||||
key_checker.End();
|
|
||||||
|
|
||||||
HValue* new_capacity = BuildNewElementsCapacity(key);
|
HValue* new_capacity = BuildNewElementsCapacity(key);
|
||||||
HValue* new_elements = BuildGrowElementsCapacity(object, elements,
|
HValue* new_elements = BuildGrowElementsCapacity(object, elements,
|
||||||
|
@ -1677,6 +1677,8 @@ LInstruction* LChunkBuilder::DoCompareGeneric(HCompareGeneric* instr) {
|
|||||||
|
|
||||||
LInstruction* LChunkBuilder::DoCompareNumericAndBranch(
|
LInstruction* LChunkBuilder::DoCompareNumericAndBranch(
|
||||||
HCompareNumericAndBranch* instr) {
|
HCompareNumericAndBranch* instr) {
|
||||||
|
LInstruction* goto_instr = CheckElideControlInstruction(instr);
|
||||||
|
if (goto_instr != NULL) return goto_instr;
|
||||||
Representation r = instr->representation();
|
Representation r = instr->representation();
|
||||||
if (r.IsSmiOrInteger32()) {
|
if (r.IsSmiOrInteger32()) {
|
||||||
ASSERT(instr->left()->representation().Equals(r));
|
ASSERT(instr->left()->representation().Equals(r));
|
||||||
|
@ -1626,6 +1626,8 @@ LInstruction* LChunkBuilder::DoCompareGeneric(HCompareGeneric* instr) {
|
|||||||
|
|
||||||
LInstruction* LChunkBuilder::DoCompareNumericAndBranch(
|
LInstruction* LChunkBuilder::DoCompareNumericAndBranch(
|
||||||
HCompareNumericAndBranch* instr) {
|
HCompareNumericAndBranch* instr) {
|
||||||
|
LInstruction* goto_instr = CheckElideControlInstruction(instr);
|
||||||
|
if (goto_instr != NULL) return goto_instr;
|
||||||
Representation r = instr->representation();
|
Representation r = instr->representation();
|
||||||
if (r.IsSmiOrInteger32()) {
|
if (r.IsSmiOrInteger32()) {
|
||||||
ASSERT(instr->left()->representation().Equals(r));
|
ASSERT(instr->left()->representation().Equals(r));
|
||||||
|
@ -1621,6 +1621,8 @@ LInstruction* LChunkBuilder::DoCompareGeneric(HCompareGeneric* instr) {
|
|||||||
|
|
||||||
LInstruction* LChunkBuilder::DoCompareNumericAndBranch(
|
LInstruction* LChunkBuilder::DoCompareNumericAndBranch(
|
||||||
HCompareNumericAndBranch* instr) {
|
HCompareNumericAndBranch* instr) {
|
||||||
|
LInstruction* goto_instr = CheckElideControlInstruction(instr);
|
||||||
|
if (goto_instr != NULL) return goto_instr;
|
||||||
Representation r = instr->representation();
|
Representation r = instr->representation();
|
||||||
if (r.IsSmiOrInteger32()) {
|
if (r.IsSmiOrInteger32()) {
|
||||||
ASSERT(instr->left()->representation().Equals(r));
|
ASSERT(instr->left()->representation().Equals(r));
|
||||||
|
Loading…
Reference in New Issue
Block a user