Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2)

Side by Side Diff: src/zone/zone.cc

Issue 2377943003: Fixed zapping of contents (Closed)
Patch Set: Fixed zapping of contents Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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/v8.h" 9 #include "src/v8.h"
10 10
(...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after
105 Segment* next = current->next(); 105 Segment* next = current->next();
106 if (!keep && current->size() <= kMaximumKeptSegmentSize) { 106 if (!keep && current->size() <= kMaximumKeptSegmentSize) {
107 // Unlink the segment we wish to keep from the list. 107 // Unlink the segment we wish to keep from the list.
108 keep = current; 108 keep = current;
109 keep->set_next(nullptr); 109 keep->set_next(nullptr);
110 } else { 110 } else {
111 size_t size = current->size(); 111 size_t size = current->size();
112 #ifdef DEBUG 112 #ifdef DEBUG
113 // Un-poison first so the zapping doesn't trigger ASan complaints. 113 // Un-poison first so the zapping doesn't trigger ASan complaints.
114 ASAN_UNPOISON_MEMORY_REGION(current, size); 114 ASAN_UNPOISON_MEMORY_REGION(current, size);
115 // Zap the entire current segment (including the header).
116 memset(current, kZapDeadByte, size);
117 #endif 115 #endif
116 current->ZapContents();
118 segment_bytes_allocated_ -= size; 117 segment_bytes_allocated_ -= size;
119 allocator_->FreeSegment(current); 118 allocator_->FreeSegment(current);
120 } 119 }
121 current = next; 120 current = next;
122 } 121 }
123 122
124 // If we have found a segment we want to keep, we must recompute the 123 // If we have found a segment we want to keep, we must recompute the
125 // variables 'position' and 'limit' to prepare for future allocate 124 // variables 'position' and 'limit' to prepare for future allocate
126 // attempts. Otherwise, we must clear the position and limit to 125 // attempts. Otherwise, we must clear the position and limit to
127 // force a new segment to be allocated on demand. 126 // force a new segment to be allocated on demand.
128 if (keep) { 127 if (keep) {
129 Address start = keep->start(); 128 Address start = keep->start();
130 position_ = RoundUp(start, kAlignment); 129 position_ = RoundUp(start, kAlignment);
131 limit_ = keep->end(); 130 limit_ = keep->end();
132 // Un-poison so we can re-use the segment later. 131 // Un-poison so we can re-use the segment later.
133 ASAN_UNPOISON_MEMORY_REGION(start, keep->capacity()); 132 ASAN_UNPOISON_MEMORY_REGION(start, keep->capacity());
134 #ifdef DEBUG 133 keep->ZapContents();
135 // Zap the contents of the kept segment (but not the header).
136 memset(start, kZapDeadByte, keep->capacity());
137 #endif
138 } else { 134 } else {
139 position_ = limit_ = 0; 135 position_ = limit_ = 0;
140 } 136 }
141 137
142 allocation_size_ = 0; 138 allocation_size_ = 0;
143 // Update the head segment to be the kept segment (if any). 139 // Update the head segment to be the kept segment (if any).
144 segment_head_ = keep; 140 segment_head_ = keep;
145 } 141 }
146 142
147 void Zone::DeleteKeptSegment() { 143 void Zone::DeleteKeptSegment() {
148 #ifdef DEBUG 144 #ifdef DEBUG
149 // Constant byte value used for zapping dead memory in debug mode. 145 // Constant byte value used for zapping dead memory in debug mode.
150 static const unsigned char kZapDeadByte = 0xcd; 146 static const unsigned char kZapDeadByte = 0xcd;
151 #endif 147 #endif
152 148
153 DCHECK(segment_head_ == nullptr || segment_head_->next() == nullptr); 149 DCHECK(segment_head_ == nullptr || segment_head_->next() == nullptr);
154 if (segment_head_ != nullptr) { 150 if (segment_head_ != nullptr) {
155 size_t size = segment_head_->size(); 151 size_t size = segment_head_->size();
156 #ifdef DEBUG 152 #ifdef DEBUG
157 // Un-poison first so the zapping doesn't trigger ASan complaints. 153 // Un-poison first so the zapping doesn't trigger ASan complaints.
158 ASAN_UNPOISON_MEMORY_REGION(segment_head_, size); 154 ASAN_UNPOISON_MEMORY_REGION(segment_head_, size);
159 // Zap the entire kept segment (including the header). 155 // Zap the entire kept segment (including the header).
160 memset(segment_head_, kZapDeadByte, size); 156 memset(segment_head_, kZapDeadByte, size);
Michael Lippautz 2016/09/28 09:22:39 I guess this should also be the ZapContents?
161 #endif 157 #endif
162 segment_bytes_allocated_ -= size; 158 segment_bytes_allocated_ -= size;
163 allocator_->FreeSegment(segment_head_); 159 allocator_->FreeSegment(segment_head_);
164 segment_head_ = nullptr; 160 segment_head_ = nullptr;
165 } 161 }
166 162
167 DCHECK(segment_bytes_allocated_ == 0); 163 DCHECK(segment_bytes_allocated_ == 0);
168 } 164 }
169 165
170 // Creates a new segment, sets it size, and pushes it to the front 166 // Creates a new segment, sets it size, and pushes it to the front
(...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after
230 // size bytes + header and alignment padding) 226 // size bytes + header and alignment padding)
231 DCHECK(reinterpret_cast<uintptr_t>(position_) >= 227 DCHECK(reinterpret_cast<uintptr_t>(position_) >=
232 reinterpret_cast<uintptr_t>(result)); 228 reinterpret_cast<uintptr_t>(result));
233 limit_ = segment->end(); 229 limit_ = segment->end();
234 DCHECK(position_ <= limit_); 230 DCHECK(position_ <= limit_);
235 return result; 231 return result;
236 } 232 }
237 233
238 } // namespace internal 234 } // namespace internal
239 } // namespace v8 235 } // namespace v8
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698