| OLD | NEW |
| 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
| 4 | 4 |
| 5 #include "vm/assembler.h" | 5 #include "vm/assembler.h" |
| 6 | 6 |
| 7 #include "platform/utils.h" | 7 #include "platform/utils.h" |
| 8 #include "vm/cpu.h" | 8 #include "vm/cpu.h" |
| 9 #include "vm/heap.h" | 9 #include "vm/heap.h" |
| 10 #include "vm/memory_region.h" | 10 #include "vm/memory_region.h" |
| 11 #include "vm/os.h" | 11 #include "vm/os.h" |
| 12 #include "vm/zone.h" | 12 #include "vm/zone.h" |
| 13 | 13 |
| 14 namespace dart { | 14 namespace dart { |
| 15 | 15 |
| 16 static uword NewContents(int capacity) { | 16 static uword NewContents(intptr_t capacity) { |
| 17 Zone* zone = Isolate::Current()->current_zone(); | 17 Zone* zone = Isolate::Current()->current_zone(); |
| 18 uword result = zone->Allocate(capacity); | 18 uword result = zone->AllocUnsafe(capacity); |
| 19 #if defined(DEBUG) | 19 #if defined(DEBUG) |
| 20 // Initialize the buffer with kBreakPointInstruction to force a break | 20 // Initialize the buffer with kBreakPointInstruction to force a break |
| 21 // point if we ever execute an uninitialized part of the code buffer. | 21 // point if we ever execute an uninitialized part of the code buffer. |
| 22 Assembler::InitializeMemoryWithBreakpoints(result, capacity); | 22 Assembler::InitializeMemoryWithBreakpoints(result, capacity); |
| 23 #endif | 23 #endif |
| 24 return result; | 24 return result; |
| 25 } | 25 } |
| 26 | 26 |
| 27 | 27 |
| 28 #if defined(DEBUG) | 28 #if defined(DEBUG) |
| (...skipping 12 matching lines...) Expand all Loading... |
| 41 ASSERT(!buffer->HasEnsuredCapacity()); // Cannot nest. | 41 ASSERT(!buffer->HasEnsuredCapacity()); // Cannot nest. |
| 42 buffer->has_ensured_capacity_ = true; | 42 buffer->has_ensured_capacity_ = true; |
| 43 } | 43 } |
| 44 | 44 |
| 45 | 45 |
| 46 AssemblerBuffer::EnsureCapacity::~EnsureCapacity() { | 46 AssemblerBuffer::EnsureCapacity::~EnsureCapacity() { |
| 47 // Unmark the buffer, so we cannot emit after this. | 47 // Unmark the buffer, so we cannot emit after this. |
| 48 buffer_->has_ensured_capacity_ = false; | 48 buffer_->has_ensured_capacity_ = false; |
| 49 // Make sure the generated instruction doesn't take up more | 49 // Make sure the generated instruction doesn't take up more |
| 50 // space than the minimum gap. | 50 // space than the minimum gap. |
| 51 int delta = gap_ - ComputeGap(); | 51 intptr_t delta = gap_ - ComputeGap(); |
| 52 ASSERT(delta <= kMinimumGap); | 52 ASSERT(delta <= kMinimumGap); |
| 53 } | 53 } |
| 54 #endif | 54 #endif |
| 55 | 55 |
| 56 | 56 |
| 57 AssemblerBuffer::AssemblerBuffer() | 57 AssemblerBuffer::AssemblerBuffer() |
| 58 : pointer_offsets_(new ZoneGrowableArray<int>(16)) { | 58 : pointer_offsets_(new ZoneGrowableArray<int>(16)) { |
| 59 static const int kInitialBufferCapacity = 4 * KB; | 59 static const intptr_t kInitialBufferCapacity = 4 * KB; |
| 60 contents_ = NewContents(kInitialBufferCapacity); | 60 contents_ = NewContents(kInitialBufferCapacity); |
| 61 cursor_ = contents_; | 61 cursor_ = contents_; |
| 62 limit_ = ComputeLimit(contents_, kInitialBufferCapacity); | 62 limit_ = ComputeLimit(contents_, kInitialBufferCapacity); |
| 63 fixup_ = NULL; | 63 fixup_ = NULL; |
| 64 #if defined(DEBUG) | 64 #if defined(DEBUG) |
| 65 has_ensured_capacity_ = false; | 65 has_ensured_capacity_ = false; |
| 66 fixups_processed_ = false; | 66 fixups_processed_ = false; |
| 67 #endif | 67 #endif |
| 68 | 68 |
| 69 // Verify internal state. | 69 // Verify internal state. |
| (...skipping 22 matching lines...) Expand all Loading... |
| 92 | 92 |
| 93 // Process fixups in the instructions. | 93 // Process fixups in the instructions. |
| 94 ProcessFixups(instructions); | 94 ProcessFixups(instructions); |
| 95 #if defined(DEBUG) | 95 #if defined(DEBUG) |
| 96 fixups_processed_ = true; | 96 fixups_processed_ = true; |
| 97 #endif | 97 #endif |
| 98 } | 98 } |
| 99 | 99 |
| 100 | 100 |
| 101 void AssemblerBuffer::ExtendCapacity() { | 101 void AssemblerBuffer::ExtendCapacity() { |
| 102 int old_size = Size(); | 102 intptr_t old_size = Size(); |
| 103 int old_capacity = Capacity(); | 103 intptr_t old_capacity = Capacity(); |
| 104 int new_capacity = Utils::Minimum(old_capacity * 2, old_capacity + 1 * MB); | 104 intptr_t new_capacity = |
| 105 Utils::Minimum(old_capacity * 2, old_capacity + 1 * MB); |
| 106 if (new_capacity < old_capacity) { |
| 107 FATAL("Unexpected overflow in AssemblerBuffer::ExtendCapacity"); |
| 108 } |
| 105 | 109 |
| 106 // Allocate the new data area and copy contents of the old one to it. | 110 // Allocate the new data area and copy contents of the old one to it. |
| 107 uword new_contents = NewContents(new_capacity); | 111 uword new_contents = NewContents(new_capacity); |
| 108 memmove(reinterpret_cast<void*>(new_contents), | 112 memmove(reinterpret_cast<void*>(new_contents), |
| 109 reinterpret_cast<void*>(contents_), | 113 reinterpret_cast<void*>(contents_), |
| 110 old_size); | 114 old_size); |
| 111 | 115 |
| 112 // Compute the relocation delta and switch to the new contents area. | 116 // Compute the relocation delta and switch to the new contents area. |
| 113 intptr_t delta = new_contents - contents_; | 117 intptr_t delta = new_contents - contents_; |
| 114 contents_ = new_contents; | 118 contents_ = new_contents; |
| (...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 175 | 179 |
| 176 void Assembler::Unreachable(const char* message) { | 180 void Assembler::Unreachable(const char* message) { |
| 177 const char* format = "Unreachable: %s"; | 181 const char* format = "Unreachable: %s"; |
| 178 const intptr_t len = OS::SNPrint(NULL, 0, format, message); | 182 const intptr_t len = OS::SNPrint(NULL, 0, format, message); |
| 179 char* buffer = reinterpret_cast<char*>(malloc(len + 1)); | 183 char* buffer = reinterpret_cast<char*>(malloc(len + 1)); |
| 180 OS::SNPrint(buffer, len + 1, format, message); | 184 OS::SNPrint(buffer, len + 1, format, message); |
| 181 Stop(buffer); | 185 Stop(buffer); |
| 182 } | 186 } |
| 183 | 187 |
| 184 } // namespace dart | 188 } // namespace dart |
| OLD | NEW |