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 |