| Index: src/objects.cc
|
| diff --git a/src/objects.cc b/src/objects.cc
|
| index f1ab81f3fe3a3e3cce43ab16dc4eb1bed63473c5..492f7528f0d4631558807e6c698dc42e0aca41e8 100644
|
| --- a/src/objects.cc
|
| +++ b/src/objects.cc
|
| @@ -10640,19 +10640,16 @@ void Code::ClearInlineCaches(Code::Kind* kind) {
|
| }
|
|
|
|
|
| -void Code::ClearTypeFeedbackInfo(Heap* heap) {
|
| - if (kind() != FUNCTION) return;
|
| - Object* raw_info = type_feedback_info();
|
| - if (raw_info->IsTypeFeedbackInfo()) {
|
| - FixedArray* feedback_vector =
|
| - TypeFeedbackInfo::cast(raw_info)->feedback_vector();
|
| - for (int i = 0; i < feedback_vector->length(); i++) {
|
| - Object* obj = feedback_vector->get(i);
|
| - if (!obj->IsAllocationSite()) {
|
| - // TODO(mvstanton): Can't I avoid a write barrier for this sentinel?
|
| - feedback_vector->set(i,
|
| - TypeFeedbackInfo::RawUninitializedSentinel(heap));
|
| - }
|
| +void SharedFunctionInfo::ClearTypeFeedbackInfo(Heap* heap) {
|
| + FixedArray* vector = feedback_vector();
|
| + for (int i = 0; i < vector->length(); i++) {
|
| + Object* obj = vector->get(i);
|
| + if (!obj->IsAllocationSite()) {
|
| + // The assert verifies we can skip the write barrier.
|
| + ASSERT(heap->uninitialized_symbol() ==
|
| + TypeFeedbackInfo::RawUninitializedSentinel(heap));
|
| + vector->set(i, TypeFeedbackInfo::RawUninitializedSentinel(heap),
|
| + SKIP_WRITE_BARRIER);
|
| }
|
| }
|
| }
|
|
|