OLD | NEW |
1 // Copyright 2013 the V8 project authors. All rights reserved. | 1 // Copyright 2013 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 2622 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2633 ASSERT(allocation_site != NULL); | 2633 ASSERT(allocation_site != NULL); |
2634 HInnerAllocatedObject* allocation_memento = Add<HInnerAllocatedObject>( | 2634 HInnerAllocatedObject* allocation_memento = Add<HInnerAllocatedObject>( |
2635 previous_object, previous_object_size); | 2635 previous_object, previous_object_size); |
2636 AddStoreMapConstant( | 2636 AddStoreMapConstant( |
2637 allocation_memento, isolate()->factory()->allocation_memento_map()); | 2637 allocation_memento, isolate()->factory()->allocation_memento_map()); |
2638 Add<HStoreNamedField>( | 2638 Add<HStoreNamedField>( |
2639 allocation_memento, | 2639 allocation_memento, |
2640 HObjectAccess::ForAllocationMementoSite(), | 2640 HObjectAccess::ForAllocationMementoSite(), |
2641 allocation_site); | 2641 allocation_site); |
2642 if (FLAG_allocation_site_pretenuring) { | 2642 if (FLAG_allocation_site_pretenuring) { |
2643 HValue* memento_create_count = Add<HLoadNamedField>( | 2643 // We want to add 1 to the memento create count. The field is actually a smi |
| 2644 // bitfield, but the memento create count is in the lower 14 bits. Therefore |
| 2645 // we don't need to mask and shift. |
| 2646 STATIC_ASSERT(AllocationSite::MementoCreateCountBits::kShift == 0); |
| 2647 HValue* pretenure_data = Add<HLoadNamedField>( |
2644 allocation_site, HObjectAccess::ForAllocationSiteOffset( | 2648 allocation_site, HObjectAccess::ForAllocationSiteOffset( |
2645 AllocationSite::kMementoCreateCountOffset)); | 2649 AllocationSite::kPretenureDataOffset)); |
2646 memento_create_count = AddUncasted<HAdd>( | 2650 pretenure_data = AddUncasted<HAdd>( |
2647 memento_create_count, graph()->GetConstant1()); | 2651 pretenure_data, graph()->GetConstant1()); |
2648 // This smi value is reset to zero after every gc, overflow isn't a problem | 2652 // This smi value is reset to zero after every gc, overflow isn't a problem |
2649 // since the counter is bounded by the new space size. | 2653 // since the counter is bounded by the new space size. |
2650 memento_create_count->ClearFlag(HValue::kCanOverflow); | 2654 pretenure_data->ClearFlag(HValue::kCanOverflow); |
2651 HStoreNamedField* store = Add<HStoreNamedField>( | 2655 HStoreNamedField* store = Add<HStoreNamedField>( |
2652 allocation_site, HObjectAccess::ForAllocationSiteOffset( | 2656 allocation_site, HObjectAccess::ForAllocationSiteOffset( |
2653 AllocationSite::kMementoCreateCountOffset), memento_create_count); | 2657 AllocationSite::kPretenureDataOffset), pretenure_data); |
2654 // No write barrier needed to store a smi. | 2658 // No write barrier needed to store a smi. |
2655 store->SkipWriteBarrier(); | 2659 store->SkipWriteBarrier(); |
2656 } | 2660 } |
2657 } | 2661 } |
2658 | 2662 |
2659 | 2663 |
2660 HInstruction* HGraphBuilder::BuildGetNativeContext(HValue* closure) { | 2664 HInstruction* HGraphBuilder::BuildGetNativeContext(HValue* closure) { |
2661 // Get the global context, then the native context | 2665 // Get the global context, then the native context |
2662 HInstruction* context = | 2666 HInstruction* context = |
2663 Add<HLoadNamedField>(closure, HObjectAccess::ForFunctionContextPointer()); | 2667 Add<HLoadNamedField>(closure, HObjectAccess::ForFunctionContextPointer()); |
(...skipping 8297 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
10961 if (ShouldProduceTraceOutput()) { | 10965 if (ShouldProduceTraceOutput()) { |
10962 isolate()->GetHTracer()->TraceHydrogen(name(), graph_); | 10966 isolate()->GetHTracer()->TraceHydrogen(name(), graph_); |
10963 } | 10967 } |
10964 | 10968 |
10965 #ifdef DEBUG | 10969 #ifdef DEBUG |
10966 graph_->Verify(false); // No full verify. | 10970 graph_->Verify(false); // No full verify. |
10967 #endif | 10971 #endif |
10968 } | 10972 } |
10969 | 10973 |
10970 } } // namespace v8::internal | 10974 } } // namespace v8::internal |
OLD | NEW |