Commit 82bc7d1a authored by Leszek Swirski's avatar Leszek Swirski Committed by Commit Bot

[map] Make NextFreePropertyIndex search backwards

Now that fields are always in the same order as descriptors, we can
change the property scan during NextFreePropertyIndex into a faster
reverse search that simply tries to find the last field.

Change-Id: I24d0781cd7d7c5b15998c35f281be69cd492d5ee
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1667402Reviewed-by: 's avatarIgor Sheludko <ishell@chromium.org>
Commit-Queue: Leszek Swirski <leszeks@chromium.org>
Cr-Commit-Position: refs/heads/master@{#62286}
parent 8cad802e
...@@ -1346,17 +1346,16 @@ int Map::NumberOfEnumerableProperties() const { ...@@ -1346,17 +1346,16 @@ int Map::NumberOfEnumerableProperties() const {
} }
int Map::NextFreePropertyIndex() const { int Map::NextFreePropertyIndex() const {
int free_index = 0;
int number_of_own_descriptors = NumberOfOwnDescriptors(); int number_of_own_descriptors = NumberOfOwnDescriptors();
DescriptorArray descs = instance_descriptors(); DescriptorArray descs = instance_descriptors();
for (int i = 0; i < number_of_own_descriptors; i++) { // Search properties backwards to find the last field.
for (int i = number_of_own_descriptors - 1; i >= 0; --i) {
PropertyDetails details = descs.GetDetails(i); PropertyDetails details = descs.GetDetails(i);
if (details.location() == kField) { if (details.location() == kField) {
int candidate = details.field_index() + details.field_width_in_words(); return details.field_index() + details.field_width_in_words();
if (candidate > free_index) free_index = candidate;
} }
} }
return free_index; return 0;
} }
bool Map::OnlyHasSimpleProperties() const { bool Map::OnlyHasSimpleProperties() const {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment