| 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 2124 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2135 | 2135 |
| 2136 allocation_info_.top = NULL; | 2136 allocation_info_.top = NULL; |
| 2137 allocation_info_.limit = NULL; | 2137 allocation_info_.limit = NULL; |
| 2138 } | 2138 } |
| 2139 } | 2139 } |
| 2140 | 2140 |
| 2141 | 2141 |
| 2142 HeapObject* PagedSpace::SlowAllocateRaw(int size_in_bytes) { | 2142 HeapObject* PagedSpace::SlowAllocateRaw(int size_in_bytes) { |
| 2143 // Allocation in this space has failed. | 2143 // Allocation in this space has failed. |
| 2144 | 2144 |
| 2145 // If there are unswept pages advance lazy sweeper then sweep one page before |
| 2146 // allocating a new page. |
| 2147 if (first_unswept_page_->is_valid()) { |
| 2148 AdvanceSweeper(size_in_bytes); |
| 2149 |
| 2150 // Retry the free list allocation. |
| 2151 HeapObject* object = free_list_.Allocate(size_in_bytes); |
| 2152 if (object != NULL) return object; |
| 2153 } |
| 2154 |
| 2145 // Free list allocation failed and there is no next page. Fail if we have | 2155 // Free list allocation failed and there is no next page. Fail if we have |
| 2146 // hit the old generation size limit that should cause a garbage | 2156 // hit the old generation size limit that should cause a garbage |
| 2147 // collection. | 2157 // collection. |
| 2148 if (!heap()->always_allocate() && | 2158 if (!heap()->always_allocate() && |
| 2149 heap()->OldGenerationAllocationLimitReached()) { | 2159 heap()->OldGenerationAllocationLimitReached()) { |
| 2150 return NULL; | 2160 return NULL; |
| 2151 } | 2161 } |
| 2152 | 2162 |
| 2153 // If there are unswept pages advance lazy sweeper. | |
| 2154 if (first_unswept_page_->is_valid()) { | |
| 2155 AdvanceSweeper(size_in_bytes); | |
| 2156 | |
| 2157 // Retry the free list allocation. | |
| 2158 HeapObject* object = free_list_.Allocate(size_in_bytes); | |
| 2159 if (object != NULL) return object; | |
| 2160 | |
| 2161 if (!IsSweepingComplete()) { | |
| 2162 AdvanceSweeper(kMaxInt); | |
| 2163 | |
| 2164 // Retry the free list allocation. | |
| 2165 object = free_list_.Allocate(size_in_bytes); | |
| 2166 if (object != NULL) return object; | |
| 2167 } | |
| 2168 } | |
| 2169 | |
| 2170 // Try to expand the space and allocate in the new next page. | 2163 // Try to expand the space and allocate in the new next page. |
| 2171 if (Expand()) { | 2164 if (Expand()) { |
| 2172 return free_list_.Allocate(size_in_bytes); | 2165 return free_list_.Allocate(size_in_bytes); |
| 2173 } | 2166 } |
| 2174 | 2167 |
| 2168 // Last ditch, sweep all the remaining pages to try to find space. This may |
| 2169 // cause a pause. |
| 2170 if (!IsSweepingComplete()) { |
| 2171 AdvanceSweeper(kMaxInt); |
| 2172 |
| 2173 // Retry the free list allocation. |
| 2174 HeapObject* object = free_list_.Allocate(size_in_bytes); |
| 2175 if (object != NULL) return object; |
| 2176 } |
| 2177 |
| 2175 // Finally, fail. | 2178 // Finally, fail. |
| 2176 return NULL; | 2179 return NULL; |
| 2177 } | 2180 } |
| 2178 | 2181 |
| 2179 | 2182 |
| 2180 #ifdef DEBUG | 2183 #ifdef DEBUG |
| 2181 void PagedSpace::ReportCodeStatistics() { | 2184 void PagedSpace::ReportCodeStatistics() { |
| 2182 Isolate* isolate = Isolate::Current(); | 2185 Isolate* isolate = Isolate::Current(); |
| 2183 CommentStatistic* comments_statistics = | 2186 CommentStatistic* comments_statistics = |
| 2184 isolate->paged_space_comments_statistics(); | 2187 isolate->paged_space_comments_statistics(); |
| (...skipping 465 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2650 object->ShortPrint(); | 2653 object->ShortPrint(); |
| 2651 PrintF("\n"); | 2654 PrintF("\n"); |
| 2652 } | 2655 } |
| 2653 printf(" --------------------------------------\n"); | 2656 printf(" --------------------------------------\n"); |
| 2654 printf(" Marked: %x, LiveCount: %x\n", mark_size, LiveBytes()); | 2657 printf(" Marked: %x, LiveCount: %x\n", mark_size, LiveBytes()); |
| 2655 } | 2658 } |
| 2656 | 2659 |
| 2657 #endif // DEBUG | 2660 #endif // DEBUG |
| 2658 | 2661 |
| 2659 } } // namespace v8::internal | 2662 } } // namespace v8::internal |
| OLD | NEW |