Chromium Code Reviews| 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 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 76 PrintF("Setting AllocationSite (%p, %p) transition_info %p\n", | 76 PrintF("Setting AllocationSite (%p, %p) transition_info %p\n", |
| 77 static_cast<void*>(*top()), | 77 static_cast<void*>(*top()), |
| 78 static_cast<void*>(*scope_site), | 78 static_cast<void*>(*scope_site), |
| 79 static_cast<void*>(*object)); | 79 static_cast<void*>(*object)); |
| 80 } | 80 } |
| 81 } | 81 } |
| 82 } | 82 } |
| 83 } | 83 } |
| 84 | 84 |
| 85 | 85 |
| 86 bool AllocationSiteUsageContext::ShouldCreateMemento(Handle<JSObject> object) { | |
| 87 bool result = false; | |
| 88 if (activated_ && AllocationSite::CanTrack(object->map()->instance_type())) { | |
| 89 if (FLAG_allocation_site_pretenuring) { | |
|
Hannes Payer (out of office)
2013/11/27 10:51:37
This method looks too complicated.
What about:
if
mvstanton
2013/11/27 13:27:58
great idea, thx.
| |
| 90 result = true; | |
| 91 } else { | |
| 92 ASSERT(object->IsJSArray()); | |
| 93 if (AllocationSite::GetMode(object->GetElementsKind()) == | |
| 94 TRACK_ALLOCATION_SITE) { | |
| 95 result = true; | |
| 96 } | |
| 97 } | |
| 98 } | |
| 99 | |
| 100 if (FLAG_trace_creation_allocation_sites) { | |
| 101 PrintF("*** Creating Memento for %s %p\n", | |
| 102 object->IsJSArray() ? "JSArray" : "JSObject", | |
| 103 static_cast<void*>(*object)); | |
| 104 } | |
| 105 | |
| 106 return result; | |
| 107 } | |
| 108 | |
| 109 | |
| 86 Handle<AllocationSite> AllocationSiteUsageContext::EnterNewScope() { | 110 Handle<AllocationSite> AllocationSiteUsageContext::EnterNewScope() { |
| 87 if (top().is_null()) { | 111 if (top().is_null()) { |
| 88 InitializeTraversal(top_site_); | 112 InitializeTraversal(top_site_); |
| 89 } else { | 113 } else { |
| 90 // Advance current site | 114 // Advance current site |
| 91 Object* nested_site = current()->nested_site(); | 115 Object* nested_site = current()->nested_site(); |
| 92 // Something is wrong if we advance to the end of the list here. | 116 // Something is wrong if we advance to the end of the list here. |
| 93 ASSERT(nested_site->IsAllocationSite()); | 117 ASSERT(nested_site->IsAllocationSite()); |
| 94 update_current_site(AllocationSite::cast(nested_site)); | 118 update_current_site(AllocationSite::cast(nested_site)); |
| 95 } | 119 } |
| 96 return Handle<AllocationSite>(*current(), isolate()); | 120 return Handle<AllocationSite>(*current(), isolate()); |
| 97 } | 121 } |
| 98 | 122 |
| 99 | 123 |
| 100 void AllocationSiteUsageContext::ExitScope( | 124 void AllocationSiteUsageContext::ExitScope( |
| 101 Handle<AllocationSite> scope_site, | 125 Handle<AllocationSite> scope_site, |
| 102 Handle<JSObject> object) { | 126 Handle<JSObject> object) { |
| 103 // This assert ensures that we are pointing at the right sub-object in a | 127 // This assert ensures that we are pointing at the right sub-object in a |
| 104 // recursive walk of a nested literal. | 128 // recursive walk of a nested literal. |
| 105 ASSERT(object.is_null() || *object == scope_site->transition_info()); | 129 ASSERT(object.is_null() || *object == scope_site->transition_info()); |
| 106 } | 130 } |
| 107 | 131 |
| 108 } } // namespace v8::internal | 132 } } // namespace v8::internal |
| OLD | NEW |