| OLD | NEW |
| 1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 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/runtime/runtime-utils.h" | 5 #include "src/runtime/runtime-utils.h" |
| 6 | 6 |
| 7 #include "src/arguments.h" | 7 #include "src/arguments.h" |
| 8 #include "src/factory.h" | 8 #include "src/factory.h" |
| 9 #include "src/messages.h" | 9 #include "src/messages.h" |
| 10 #include "src/objects-inl.h" | 10 #include "src/objects-inl.h" |
| (...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 99 CHECK(byte_length % element_size == 0); | 99 CHECK(byte_length % element_size == 0); |
| 100 size_t length = byte_length / element_size; | 100 size_t length = byte_length / element_size; |
| 101 | 101 |
| 102 if (length > static_cast<unsigned>(Smi::kMaxValue)) { | 102 if (length > static_cast<unsigned>(Smi::kMaxValue)) { |
| 103 THROW_NEW_ERROR_RETURN_FAILURE( | 103 THROW_NEW_ERROR_RETURN_FAILURE( |
| 104 isolate, NewRangeError(MessageTemplate::kInvalidTypedArrayLength)); | 104 isolate, NewRangeError(MessageTemplate::kInvalidTypedArrayLength)); |
| 105 } | 105 } |
| 106 | 106 |
| 107 // All checks are done, now we can modify objects. | 107 // All checks are done, now we can modify objects. |
| 108 | 108 |
| 109 DCHECK_EQ(v8::ArrayBufferView::kInternalFieldCount, | 109 DCHECK_EQ(v8::ArrayBufferView::kEmbedderFieldCount, |
| 110 holder->GetInternalFieldCount()); | 110 holder->GetEmbedderFieldCount()); |
| 111 for (int i = 0; i < v8::ArrayBufferView::kInternalFieldCount; i++) { | 111 for (int i = 0; i < v8::ArrayBufferView::kEmbedderFieldCount; i++) { |
| 112 holder->SetInternalField(i, Smi::kZero); | 112 holder->SetEmbedderField(i, Smi::kZero); |
| 113 } | 113 } |
| 114 Handle<Object> length_obj = isolate->factory()->NewNumberFromSize(length); | 114 Handle<Object> length_obj = isolate->factory()->NewNumberFromSize(length); |
| 115 holder->set_length(*length_obj); | 115 holder->set_length(*length_obj); |
| 116 holder->set_byte_offset(*byte_offset_object); | 116 holder->set_byte_offset(*byte_offset_object); |
| 117 holder->set_byte_length(*byte_length_object); | 117 holder->set_byte_length(*byte_length_object); |
| 118 | 118 |
| 119 if (!maybe_buffer->IsNull(isolate)) { | 119 if (!maybe_buffer->IsNull(isolate)) { |
| 120 Handle<JSArrayBuffer> buffer = Handle<JSArrayBuffer>::cast(maybe_buffer); | 120 Handle<JSArrayBuffer> buffer = Handle<JSArrayBuffer>::cast(maybe_buffer); |
| 121 holder->set_buffer(*buffer); | 121 holder->set_buffer(*buffer); |
| 122 | 122 |
| (...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 172 CHECK(TryNumberToSize(*length_obj, &length)); | 172 CHECK(TryNumberToSize(*length_obj, &length)); |
| 173 } | 173 } |
| 174 | 174 |
| 175 if ((length > static_cast<unsigned>(Smi::kMaxValue)) || | 175 if ((length > static_cast<unsigned>(Smi::kMaxValue)) || |
| 176 (length > (kMaxInt / element_size))) { | 176 (length > (kMaxInt / element_size))) { |
| 177 THROW_NEW_ERROR_RETURN_FAILURE( | 177 THROW_NEW_ERROR_RETURN_FAILURE( |
| 178 isolate, NewRangeError(MessageTemplate::kInvalidTypedArrayLength)); | 178 isolate, NewRangeError(MessageTemplate::kInvalidTypedArrayLength)); |
| 179 } | 179 } |
| 180 size_t byte_length = length * element_size; | 180 size_t byte_length = length * element_size; |
| 181 | 181 |
| 182 DCHECK_EQ(v8::ArrayBufferView::kInternalFieldCount, | 182 DCHECK_EQ(v8::ArrayBufferView::kEmbedderFieldCount, |
| 183 holder->GetInternalFieldCount()); | 183 holder->GetEmbedderFieldCount()); |
| 184 for (int i = 0; i < v8::ArrayBufferView::kInternalFieldCount; i++) { | 184 for (int i = 0; i < v8::ArrayBufferView::kEmbedderFieldCount; i++) { |
| 185 holder->SetInternalField(i, Smi::kZero); | 185 holder->SetEmbedderField(i, Smi::kZero); |
| 186 } | 186 } |
| 187 | 187 |
| 188 // NOTE: not initializing backing store. | 188 // NOTE: not initializing backing store. |
| 189 // We assume that the caller of this function will initialize holder | 189 // We assume that the caller of this function will initialize holder |
| 190 // with the loop | 190 // with the loop |
| 191 // for(i = 0; i < length; i++) { holder[i] = source[i]; } | 191 // for(i = 0; i < length; i++) { holder[i] = source[i]; } |
| 192 // We assume that the caller of this function is always a typed array | 192 // We assume that the caller of this function is always a typed array |
| 193 // constructor. | 193 // constructor. |
| 194 // If source is a typed array, this loop will always run to completion, | 194 // If source is a typed array, this loop will always run to completion, |
| 195 // so we are sure that the backing store will be initialized. | 195 // so we are sure that the backing store will be initialized. |
| (...skipping 246 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 442 return isolate->heap()->false_value(); | 442 return isolate->heap()->false_value(); |
| 443 } | 443 } |
| 444 | 444 |
| 445 Handle<JSTypedArray> obj(JSTypedArray::cast(args[0])); | 445 Handle<JSTypedArray> obj(JSTypedArray::cast(args[0])); |
| 446 return isolate->heap()->ToBoolean(obj->GetBuffer()->is_shared() && | 446 return isolate->heap()->ToBoolean(obj->GetBuffer()->is_shared() && |
| 447 obj->type() == kExternalInt32Array); | 447 obj->type() == kExternalInt32Array); |
| 448 } | 448 } |
| 449 | 449 |
| 450 } // namespace internal | 450 } // namespace internal |
| 451 } // namespace v8 | 451 } // namespace v8 |
| OLD | NEW |