OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/zone/zone.h" | 5 #include "src/zone/zone.h" |
6 | 6 |
7 #include <cstring> | 7 #include <cstring> |
8 | 8 |
9 #include "src/utils.h" | 9 #include "src/utils.h" |
10 #include "src/v8.h" | 10 #include "src/v8.h" |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
42 | 42 |
43 } // namespace | 43 } // namespace |
44 | 44 |
45 Zone::Zone(AccountingAllocator* allocator, const char* name) | 45 Zone::Zone(AccountingAllocator* allocator, const char* name) |
46 : allocation_size_(0), | 46 : allocation_size_(0), |
47 segment_bytes_allocated_(0), | 47 segment_bytes_allocated_(0), |
48 position_(0), | 48 position_(0), |
49 limit_(0), | 49 limit_(0), |
50 allocator_(allocator), | 50 allocator_(allocator), |
51 segment_head_(nullptr), | 51 segment_head_(nullptr), |
52 name_(name) { | 52 name_(name), |
| 53 sealed_(false) { |
53 allocator_->ZoneCreation(this); | 54 allocator_->ZoneCreation(this); |
54 } | 55 } |
55 | 56 |
56 Zone::~Zone() { | 57 Zone::~Zone() { |
57 allocator_->ZoneDestruction(this); | 58 allocator_->ZoneDestruction(this); |
58 | 59 |
59 DeleteAll(); | 60 DeleteAll(); |
60 | 61 |
61 DCHECK(segment_bytes_allocated_ == 0); | 62 DCHECK(segment_bytes_allocated_ == 0); |
62 } | 63 } |
63 | 64 |
64 void* Zone::New(size_t size) { | 65 void* Zone::New(size_t size) { |
| 66 CHECK(!sealed_); |
| 67 |
65 // Round up the requested size to fit the alignment. | 68 // Round up the requested size to fit the alignment. |
66 size = RoundUp(size, kAlignment); | 69 size = RoundUp(size, kAlignment); |
67 | 70 |
68 // If the allocation size is divisible by 8 then we return an 8-byte aligned | 71 // If the allocation size is divisible by 8 then we return an 8-byte aligned |
69 // address. | 72 // address. |
70 if (kPointerSize == 4 && kAlignment == 4) { | 73 if (kPointerSize == 4 && kAlignment == 4) { |
71 position_ += ((~size) & 4) & (reinterpret_cast<intptr_t>(position_) & 4); | 74 position_ += ((~size) & 4) & (reinterpret_cast<intptr_t>(position_) & 4); |
72 } else { | 75 } else { |
73 DCHECK(kAlignment >= kPointerSize); | 76 DCHECK(kAlignment >= kPointerSize); |
74 } | 77 } |
(...skipping 105 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
180 // size bytes + header and alignment padding) | 183 // size bytes + header and alignment padding) |
181 DCHECK(reinterpret_cast<uintptr_t>(position_) >= | 184 DCHECK(reinterpret_cast<uintptr_t>(position_) >= |
182 reinterpret_cast<uintptr_t>(result)); | 185 reinterpret_cast<uintptr_t>(result)); |
183 limit_ = segment->end(); | 186 limit_ = segment->end(); |
184 DCHECK(position_ <= limit_); | 187 DCHECK(position_ <= limit_); |
185 return result; | 188 return result; |
186 } | 189 } |
187 | 190 |
188 } // namespace internal | 191 } // namespace internal |
189 } // namespace v8 | 192 } // namespace v8 |
OLD | NEW |