OLD | NEW |
1 // Copyright 2011 the V8 project authors. All rights reserved. | 1 // Copyright 2011 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 1717 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1728 } | 1728 } |
1729 | 1729 |
1730 | 1730 |
1731 MaybeObject* KeyedStoreIC::GetElementStubWithoutMapCheck( | 1731 MaybeObject* KeyedStoreIC::GetElementStubWithoutMapCheck( |
1732 bool is_js_array, | 1732 bool is_js_array, |
1733 ElementsKind elements_kind) { | 1733 ElementsKind elements_kind) { |
1734 return KeyedStoreElementStub(is_js_array, elements_kind).TryGetCode(); | 1734 return KeyedStoreElementStub(is_js_array, elements_kind).TryGetCode(); |
1735 } | 1735 } |
1736 | 1736 |
1737 | 1737 |
1738 // If |map| is contained in |maps_list|, returns |map|; otherwise returns NULL. | |
1739 Map* GetMapIfPresent(Map* map, MapList* maps_list) { | |
1740 for (int i = 0; i < maps_list->length(); ++i) { | |
1741 if (maps_list->at(i) == map) return map; | |
1742 } | |
1743 return NULL; | |
1744 } | |
1745 | |
1746 | |
1747 // Returns the most generic transitioned map for |map| that's found in | |
1748 // |maps_list|, or NULL if no transitioned map for |map| is found at all. | |
1749 Map* GetTransitionedMap(Map* map, MapList* maps_list) { | |
1750 ElementsKind elements_kind = map->elements_kind(); | |
1751 if (elements_kind == FAST_ELEMENTS) { | |
1752 return NULL; | |
1753 } | |
1754 if (elements_kind == FAST_DOUBLE_ELEMENTS) { | |
1755 bool dummy = true; | |
1756 Map* fast_map = map->LookupElementsTransitionMap(FAST_ELEMENTS, &dummy); | |
1757 if (fast_map == NULL) return NULL; | |
1758 return GetMapIfPresent(fast_map, maps_list); | |
1759 } | |
1760 if (elements_kind == FAST_SMI_ONLY_ELEMENTS) { | |
1761 bool dummy = true; | |
1762 Map* double_map = map->LookupElementsTransitionMap(FAST_DOUBLE_ELEMENTS, | |
1763 &dummy); | |
1764 // In the current implementation, if the DOUBLE map doesn't exist, the | |
1765 // FAST map can't exist either. | |
1766 if (double_map == NULL) return NULL; | |
1767 Map* fast_map = map->LookupElementsTransitionMap(FAST_ELEMENTS, &dummy); | |
1768 if (fast_map == NULL) { | |
1769 return GetMapIfPresent(double_map, maps_list); | |
1770 } | |
1771 // Both double_map and fast_map are non-NULL. Return fast_map if it's in | |
1772 // maps_list, double_map otherwise. | |
1773 Map* fast_map_present = GetMapIfPresent(fast_map, maps_list); | |
1774 if (fast_map_present != NULL) return fast_map_present; | |
1775 return GetMapIfPresent(double_map, maps_list); | |
1776 } | |
1777 return NULL; | |
1778 } | |
1779 | |
1780 | |
1781 MaybeObject* KeyedStoreIC::ComputePolymorphicStub( | 1738 MaybeObject* KeyedStoreIC::ComputePolymorphicStub( |
1782 MapList* receiver_maps, | 1739 MapList* receiver_maps, |
1783 StrictModeFlag strict_mode) { | 1740 StrictModeFlag strict_mode) { |
1784 // Collect MONOMORPHIC stubs for all target_receiver_maps. | 1741 // Collect MONOMORPHIC stubs for all target_receiver_maps. |
1785 CodeList handler_ics(receiver_maps->length()); | 1742 CodeList handler_ics(receiver_maps->length()); |
1786 MapList transitioned_maps(receiver_maps->length()); | 1743 MapList transitioned_maps(receiver_maps->length()); |
1787 for (int i = 0; i < receiver_maps->length(); ++i) { | 1744 for (int i = 0; i < receiver_maps->length(); ++i) { |
1788 Map* receiver_map(receiver_maps->at(i)); | 1745 Map* receiver_map(receiver_maps->at(i)); |
1789 MaybeObject* maybe_cached_stub = NULL; | 1746 MaybeObject* maybe_cached_stub = NULL; |
1790 Map* transitioned_map = GetTransitionedMap(receiver_map, receiver_maps); | 1747 Map* transitioned_map = receiver_map->FindTransitionedMap(receiver_maps); |
1791 if (transitioned_map != NULL) { | 1748 if (transitioned_map != NULL) { |
1792 maybe_cached_stub = FastElementsConversionStub( | 1749 maybe_cached_stub = FastElementsConversionStub( |
1793 receiver_map->elements_kind(), // original elements_kind | 1750 receiver_map->elements_kind(), // original elements_kind |
1794 transitioned_map->elements_kind(), | 1751 transitioned_map->elements_kind(), |
1795 receiver_map->instance_type() == JS_ARRAY_TYPE, // is_js_array | 1752 receiver_map->instance_type() == JS_ARRAY_TYPE, // is_js_array |
1796 strict_mode).TryGetCode(); | 1753 strict_mode).TryGetCode(); |
1797 } else { | 1754 } else { |
1798 maybe_cached_stub = ComputeMonomorphicStubWithoutMapCheck( | 1755 maybe_cached_stub = ComputeMonomorphicStubWithoutMapCheck( |
1799 receiver_map, strict_mode); | 1756 receiver_map, strict_mode); |
1800 } | 1757 } |
(...skipping 807 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2608 #undef ADDR | 2565 #undef ADDR |
2609 }; | 2566 }; |
2610 | 2567 |
2611 | 2568 |
2612 Address IC::AddressFromUtilityId(IC::UtilityId id) { | 2569 Address IC::AddressFromUtilityId(IC::UtilityId id) { |
2613 return IC_utilities[id]; | 2570 return IC_utilities[id]; |
2614 } | 2571 } |
2615 | 2572 |
2616 | 2573 |
2617 } } // namespace v8::internal | 2574 } } // namespace v8::internal |
OLD | NEW |