| Index: include/v8.h | 
| diff --git a/include/v8.h b/include/v8.h | 
| index 5ce6dd5064fa30763ebd031fc30de117495d9814..bc0abd381207bb517867262c575ba8e58afb967e 100644 | 
| --- a/include/v8.h | 
| +++ b/include/v8.h | 
| @@ -1893,6 +1893,73 @@ class V8_EXPORT Value : public Data { | 
| */ | 
| bool IsDataView() const; | 
|  | 
| +  /** | 
| +   * Returns true if this value is a SharedArrayBuffer. | 
| +   * This is an experimental feature. | 
| +   */ | 
| +  bool IsSharedArrayBuffer() const; | 
| + | 
| +  /** | 
| +   * Returns true if this value is one of SharedTypedArrays. | 
| +   * This is an experimental feature. | 
| +   */ | 
| +  bool IsSharedTypedArray() const; | 
| + | 
| +  /** | 
| +   * Returns true if this value is a SharedUint8Array. | 
| +   * This is an experimental feature. | 
| +   */ | 
| +  bool IsSharedUint8Array() const; | 
| + | 
| +  /** | 
| +   * Returns true if this value is a SharedUint8ClampedArray. | 
| +   * This is an experimental feature. | 
| +   */ | 
| +  bool IsSharedUint8ClampedArray() const; | 
| + | 
| +  /** | 
| +   * Returns true if this value is a SharedInt8Array. | 
| +   * This is an experimental feature. | 
| +   */ | 
| +  bool IsSharedInt8Array() const; | 
| + | 
| +  /** | 
| +   * Returns true if this value is a SharedUint16Array. | 
| +   * This is an experimental feature. | 
| +   */ | 
| +  bool IsSharedUint16Array() const; | 
| + | 
| +  /** | 
| +   * Returns true if this value is a SharedInt16Array. | 
| +   * This is an experimental feature. | 
| +   */ | 
| +  bool IsSharedInt16Array() const; | 
| + | 
| +  /** | 
| +   * Returns true if this value is a SharedUint32Array. | 
| +   * This is an experimental feature. | 
| +   */ | 
| +  bool IsSharedUint32Array() const; | 
| + | 
| +  /** | 
| +   * Returns true if this value is a SharedInt32Array. | 
| +   * This is an experimental feature. | 
| +   */ | 
| +  bool IsSharedInt32Array() const; | 
| + | 
| +  /** | 
| +   * Returns true if this value is a SharedFloat32Array. | 
| +   * This is an experimental feature. | 
| +   */ | 
| +  bool IsSharedFloat32Array() const; | 
| + | 
| +  /** | 
| +   * Returns true if this value is a SharedFloat64Array. | 
| +   * This is an experimental feature. | 
| +   */ | 
| +  bool IsSharedFloat64Array() const; | 
| + | 
| + | 
| V8_WARN_UNUSED_RESULT MaybeLocal<Boolean> ToBoolean( | 
| Local<Context> context) const; | 
| V8_WARN_UNUSED_RESULT MaybeLocal<Number> ToNumber( | 
| @@ -3312,7 +3379,7 @@ class V8_EXPORT ArrayBuffer : public Object { | 
| ArrayBufferCreationMode mode = ArrayBufferCreationMode::kExternalized); | 
|  | 
| /** | 
| -   * Returns true if ArrayBuffer is extrenalized, that is, does not | 
| +   * Returns true if ArrayBuffer is externalized, that is, does not | 
| * own its memory block. | 
| */ | 
| bool IsExternal() const; | 
| @@ -3599,6 +3666,295 @@ class V8_EXPORT DataView : public ArrayBufferView { | 
|  | 
|  | 
| /** | 
| + * TODO(binji): document | 
| + * An instance of the built-in SharedArrayBuffer constructor (ES6 draft | 
| + * 15.13.5). | 
| + * This API is experimental and may change significantly. | 
| + */ | 
| +class V8_EXPORT SharedArrayBuffer : public Object { | 
| + public: | 
| +  /** | 
| +   * The contents of an |SharedArrayBuffer|. Externalization of | 
| +   * |SharedArrayBuffer| returns an instance of this class, populated, with a | 
| +   * pointer to data and byte length. | 
| +   * | 
| +   * The Data pointer of SharedArrayBuffer::Contents is always allocated with | 
| +   * |ArrayBuffer::Allocator::Allocate| by the allocator specified in | 
| +   * v8::Isolate::CreateParams::shared_array_buffer_allocator. | 
| +   * | 
| +   * This API is experimental and may change significantly. | 
| +   */ | 
| +  class V8_EXPORT Contents {  // NOLINT | 
| +   public: | 
| +    Contents() : data_(NULL), byte_length_(0) {} | 
| + | 
| +    void* Data() const { return data_; } | 
| +    size_t ByteLength() const { return byte_length_; } | 
| + | 
| +   private: | 
| +    void* data_; | 
| +    size_t byte_length_; | 
| + | 
| +    friend class SharedArrayBuffer; | 
| +  }; | 
| + | 
| + | 
| +  /** | 
| +   * Data length in bytes. | 
| +   */ | 
| +  size_t ByteLength() const; | 
| + | 
| +  /** | 
| +   * Create a new SharedArrayBuffer. Allocate |byte_length| bytes. | 
| +   * Allocated memory will be owned by a created SharedArrayBuffer and | 
| +   * will be deallocated when it is garbage-collected, | 
| +   * unless the object is externalized. | 
| +   */ | 
| +  static Local<SharedArrayBuffer> New(Isolate* isolate, size_t byte_length); | 
| + | 
| +  /** | 
| +   * Create a new SharedArrayBuffer over an existing memory block.  The created | 
| +   * array buffer is immediately in externalized state unless otherwise | 
| +   * specified. The memory block will not be reclaimed when a created | 
| +   * SharedArrayBuffer is garbage-collected. | 
| +   */ | 
| +  static Local<SharedArrayBuffer> New( | 
| +      Isolate* isolate, void* data, size_t byte_length, | 
| +      ArrayBufferCreationMode mode = ArrayBufferCreationMode::kExternalized); | 
| + | 
| +  /** | 
| +   * Returns true if SharedArrayBuffer is externalized, that is, does not | 
| +   * own its memory block. | 
| +   */ | 
| +  bool IsExternal() const; | 
| + | 
| +  /** | 
| +   * Make this SharedArrayBuffer external. The pointer to underlying memory | 
| +   * block and byte length are returned as |Contents| structure. After | 
| +   * SharedArrayBuffer had been etxrenalized, it does no longer owns the memory | 
| +   * block. The caller should take steps to free memory when it is no longer | 
| +   * needed. | 
| +   * | 
| +   * The memory block is guaranteed to be allocated with |Allocator::Allocate| | 
| +   * by the allocator specified in | 
| +   * v8::Isolate::CreateParams::shared_array_buffer_allocator. | 
| +   * | 
| +   */ | 
| +  Contents Externalize(); | 
| + | 
| +  /** | 
| +   * Get a pointer to the ArrayBuffer's underlying memory block without | 
| +   * externalizing it. If the ArrayBuffer is not externalized, this pointer | 
| +   * will become invalid as soon as the ArrayBuffer became garbage collected. | 
| +   * | 
| +   * The embedder should make sure to hold a strong reference to the | 
| +   * ArrayBuffer while accessing this pointer. | 
| +   * | 
| +   * The memory block is guaranteed to be allocated with |Allocator::Allocate| | 
| +   * by the allocator specified in | 
| +   * v8::Isolate::CreateParams::shared_array_buffer_allocator. | 
| +   */ | 
| +  Contents GetContents(); | 
| + | 
| +  V8_INLINE static SharedArrayBuffer* Cast(Value* obj); | 
| + | 
| +  static const int kInternalFieldCount = V8_ARRAY_BUFFER_INTERNAL_FIELD_COUNT; | 
| + | 
| + private: | 
| +  SharedArrayBuffer(); | 
| +  static void CheckCast(Value* obj); | 
| +}; | 
| + | 
| + | 
| +/** | 
| + * TODO(binji): document | 
| + * A base class for an instance of TypedArray series of constructors | 
| + * (ES6 draft 15.13.6). | 
| + * This API is experimental and may change significantly. | 
| + */ | 
| +class V8_EXPORT SharedTypedArray : public Object { | 
| + public: | 
| +  /** | 
| +   * Returns underlying SharedArrayBuffer. | 
| +   */ | 
| +  Local<SharedArrayBuffer> Buffer(); | 
| +  /** | 
| +   * Byte offset in |Buffer|. | 
| +   */ | 
| +  size_t ByteOffset(); | 
| +  /** | 
| +   * Size of a view in bytes. | 
| +   */ | 
| +  size_t ByteLength(); | 
| + | 
| +  /** | 
| +   * Number of elements in this typed array | 
| +   * (e.g. for SharedInt16Array, |ByteLength|/2). | 
| +   */ | 
| +  size_t Length(); | 
| + | 
| +  V8_INLINE static SharedTypedArray* Cast(Value* obj); | 
| + | 
| + private: | 
| +  SharedTypedArray(); | 
| +  static void CheckCast(Value* obj); | 
| +}; | 
| + | 
| + | 
| +/** | 
| + * TODO(binji): document | 
| + * An instance of Uint8Array constructor (ES6 draft 15.13.6). | 
| + * This API is experimental and may change significantly. | 
| + */ | 
| +class V8_EXPORT SharedUint8Array : public SharedTypedArray { | 
| + public: | 
| +  static Local<SharedUint8Array> New(Handle<SharedArrayBuffer> array_buffer, | 
| +                                     size_t byte_offset, size_t length); | 
| +  V8_INLINE static SharedUint8Array* Cast(Value* obj); | 
| + | 
| + private: | 
| +  SharedUint8Array(); | 
| +  static void CheckCast(Value* obj); | 
| +}; | 
| + | 
| + | 
| +/** | 
| + * TODO(binji): document | 
| + * An instance of Uint8ClampedArray constructor (ES6 draft 15.13.6). | 
| + * This API is experimental and may change significantly. | 
| + */ | 
| +class V8_EXPORT SharedUint8ClampedArray : public SharedTypedArray { | 
| + public: | 
| +  static Local<SharedUint8ClampedArray> New( | 
| +      Handle<SharedArrayBuffer> array_buffer, size_t byte_offset, | 
| +      size_t length); | 
| +  V8_INLINE static SharedUint8ClampedArray* Cast(Value* obj); | 
| + | 
| + private: | 
| +  SharedUint8ClampedArray(); | 
| +  static void CheckCast(Value* obj); | 
| +}; | 
| + | 
| +/** | 
| + * TODO(binji): document | 
| + * An instance of Int8Array constructor (ES6 draft 15.13.6). | 
| + * This API is experimental and may change significantly. | 
| + */ | 
| +class V8_EXPORT SharedInt8Array : public SharedTypedArray { | 
| + public: | 
| +  static Local<SharedInt8Array> New(Handle<SharedArrayBuffer> array_buffer, | 
| +                                    size_t byte_offset, size_t length); | 
| +  V8_INLINE static SharedInt8Array* Cast(Value* obj); | 
| + | 
| + private: | 
| +  SharedInt8Array(); | 
| +  static void CheckCast(Value* obj); | 
| +}; | 
| + | 
| + | 
| +/** | 
| + * TODO(binji): document | 
| + * An instance of Uint16Array constructor (ES6 draft 15.13.6). | 
| + * This API is experimental and may change significantly. | 
| + */ | 
| +class V8_EXPORT SharedUint16Array : public SharedTypedArray { | 
| + public: | 
| +  static Local<SharedUint16Array> New(Handle<SharedArrayBuffer> array_buffer, | 
| +                                      size_t byte_offset, size_t length); | 
| +  V8_INLINE static SharedUint16Array* Cast(Value* obj); | 
| + | 
| + private: | 
| +  SharedUint16Array(); | 
| +  static void CheckCast(Value* obj); | 
| +}; | 
| + | 
| + | 
| +/** | 
| + * TODO(binji): document | 
| + * An instance of Int16Array constructor (ES6 draft 15.13.6). | 
| + * This API is experimental and may change significantly. | 
| + */ | 
| +class V8_EXPORT SharedInt16Array : public SharedTypedArray { | 
| + public: | 
| +  static Local<SharedInt16Array> New(Handle<SharedArrayBuffer> array_buffer, | 
| +                                     size_t byte_offset, size_t length); | 
| +  V8_INLINE static SharedInt16Array* Cast(Value* obj); | 
| + | 
| + private: | 
| +  SharedInt16Array(); | 
| +  static void CheckCast(Value* obj); | 
| +}; | 
| + | 
| + | 
| +/** | 
| + * TODO(binji): document | 
| + * An instance of Uint32Array constructor (ES6 draft 15.13.6). | 
| + * This API is experimental and may change significantly. | 
| + */ | 
| +class V8_EXPORT SharedUint32Array : public SharedTypedArray { | 
| + public: | 
| +  static Local<SharedUint32Array> New(Handle<SharedArrayBuffer> array_buffer, | 
| +                                      size_t byte_offset, size_t length); | 
| +  V8_INLINE static SharedUint32Array* Cast(Value* obj); | 
| + | 
| + private: | 
| +  SharedUint32Array(); | 
| +  static void CheckCast(Value* obj); | 
| +}; | 
| + | 
| + | 
| +/** | 
| + * TODO(binji): document | 
| + * An instance of Int32Array constructor (ES6 draft 15.13.6). | 
| + * This API is experimental and may change significantly. | 
| + */ | 
| +class V8_EXPORT SharedInt32Array : public SharedTypedArray { | 
| + public: | 
| +  static Local<SharedInt32Array> New(Handle<SharedArrayBuffer> array_buffer, | 
| +                                     size_t byte_offset, size_t length); | 
| +  V8_INLINE static SharedInt32Array* Cast(Value* obj); | 
| + | 
| + private: | 
| +  SharedInt32Array(); | 
| +  static void CheckCast(Value* obj); | 
| +}; | 
| + | 
| + | 
| +/** | 
| + * TODO(binji): document | 
| + * An instance of Float32Array constructor (ES6 draft 15.13.6). | 
| + * This API is experimental and may change significantly. | 
| + */ | 
| +class V8_EXPORT SharedFloat32Array : public SharedTypedArray { | 
| + public: | 
| +  static Local<SharedFloat32Array> New(Handle<SharedArrayBuffer> array_buffer, | 
| +                                       size_t byte_offset, size_t length); | 
| +  V8_INLINE static SharedFloat32Array* Cast(Value* obj); | 
| + | 
| + private: | 
| +  SharedFloat32Array(); | 
| +  static void CheckCast(Value* obj); | 
| +}; | 
| + | 
| + | 
| +/** | 
| + * TODO(binji): document | 
| + * An instance of Float64Array constructor (ES6 draft 15.13.6). | 
| + * This API is experimental and may change significantly. | 
| + */ | 
| +class V8_EXPORT SharedFloat64Array : public SharedTypedArray { | 
| + public: | 
| +  static Local<SharedFloat64Array> New(Handle<SharedArrayBuffer> array_buffer, | 
| +                                       size_t byte_offset, size_t length); | 
| +  V8_INLINE static SharedFloat64Array* Cast(Value* obj); | 
| + | 
| + private: | 
| +  SharedFloat64Array(); | 
| +  static void CheckCast(Value* obj); | 
| +}; | 
| + | 
| + | 
| +/** | 
| * An instance of the built-in Date constructor (ECMA-262, 15.9). | 
| */ | 
| class V8_EXPORT Date : public Object { | 
| @@ -4956,7 +5312,8 @@ class V8_EXPORT Isolate { | 
| counter_lookup_callback(NULL), | 
| create_histogram_callback(NULL), | 
| add_histogram_sample_callback(NULL), | 
| -          array_buffer_allocator(NULL) {} | 
| +          array_buffer_allocator(NULL), | 
| +          shared_array_buffer_allocator(NULL) {} | 
|  | 
| /** | 
| * The optional entry_hook allows the host application to provide the | 
| @@ -5004,6 +5361,12 @@ class V8_EXPORT Isolate { | 
| * store of ArrayBuffers. | 
| */ | 
| ArrayBuffer::Allocator* array_buffer_allocator; | 
| + | 
| +    /** | 
| +     * The ArrayBuffer::Allocator to use for allocating and freeing the backing | 
| +     * store of SharedArrayBuffers. | 
| +     */ | 
| +    ArrayBuffer::Allocator* shared_array_buffer_allocator; | 
| }; | 
|  | 
|  | 
| @@ -6673,7 +7036,7 @@ class Internals { | 
| static const int kJSObjectHeaderSize = 3 * kApiPointerSize; | 
| static const int kFixedArrayHeaderSize = 2 * kApiPointerSize; | 
| static const int kContextHeaderSize = 2 * kApiPointerSize; | 
| -  static const int kContextEmbedderDataIndex = 77; | 
| +  static const int kContextEmbedderDataIndex = 96; | 
| static const int kFullStringRepresentationMask = 0x07; | 
| static const int kStringEncodingMask = 0x4; | 
| static const int kExternalTwoByteRepresentationTag = 0x02; | 
| @@ -7724,6 +8087,94 @@ DataView* DataView::Cast(v8::Value* value) { | 
| } | 
|  | 
|  | 
| +SharedArrayBuffer* SharedArrayBuffer::Cast(v8::Value* value) { | 
| +#ifdef V8_ENABLE_CHECKS | 
| +  CheckCast(value); | 
| +#endif | 
| +  return static_cast<SharedArrayBuffer*>(value); | 
| +} | 
| + | 
| + | 
| +SharedTypedArray* SharedTypedArray::Cast(v8::Value* value) { | 
| +#ifdef V8_ENABLE_CHECKS | 
| +  CheckCast(value); | 
| +#endif | 
| +  return static_cast<SharedTypedArray*>(value); | 
| +} | 
| + | 
| + | 
| +SharedUint8Array* SharedUint8Array::Cast(v8::Value* value) { | 
| +#ifdef V8_ENABLE_CHECKS | 
| +  CheckCast(value); | 
| +#endif | 
| +  return static_cast<SharedUint8Array*>(value); | 
| +} | 
| + | 
| + | 
| +SharedInt8Array* SharedInt8Array::Cast(v8::Value* value) { | 
| +#ifdef V8_ENABLE_CHECKS | 
| +  CheckCast(value); | 
| +#endif | 
| +  return static_cast<SharedInt8Array*>(value); | 
| +} | 
| + | 
| + | 
| +SharedUint16Array* SharedUint16Array::Cast(v8::Value* value) { | 
| +#ifdef V8_ENABLE_CHECKS | 
| +  CheckCast(value); | 
| +#endif | 
| +  return static_cast<SharedUint16Array*>(value); | 
| +} | 
| + | 
| + | 
| +SharedInt16Array* SharedInt16Array::Cast(v8::Value* value) { | 
| +#ifdef V8_ENABLE_CHECKS | 
| +  CheckCast(value); | 
| +#endif | 
| +  return static_cast<SharedInt16Array*>(value); | 
| +} | 
| + | 
| + | 
| +SharedUint32Array* SharedUint32Array::Cast(v8::Value* value) { | 
| +#ifdef V8_ENABLE_CHECKS | 
| +  CheckCast(value); | 
| +#endif | 
| +  return static_cast<SharedUint32Array*>(value); | 
| +} | 
| + | 
| + | 
| +SharedInt32Array* SharedInt32Array::Cast(v8::Value* value) { | 
| +#ifdef V8_ENABLE_CHECKS | 
| +  CheckCast(value); | 
| +#endif | 
| +  return static_cast<SharedInt32Array*>(value); | 
| +} | 
| + | 
| + | 
| +SharedFloat32Array* SharedFloat32Array::Cast(v8::Value* value) { | 
| +#ifdef V8_ENABLE_CHECKS | 
| +  CheckCast(value); | 
| +#endif | 
| +  return static_cast<SharedFloat32Array*>(value); | 
| +} | 
| + | 
| + | 
| +SharedFloat64Array* SharedFloat64Array::Cast(v8::Value* value) { | 
| +#ifdef V8_ENABLE_CHECKS | 
| +  CheckCast(value); | 
| +#endif | 
| +  return static_cast<SharedFloat64Array*>(value); | 
| +} | 
| + | 
| + | 
| +SharedUint8ClampedArray* SharedUint8ClampedArray::Cast(v8::Value* value) { | 
| +#ifdef V8_ENABLE_CHECKS | 
| +  CheckCast(value); | 
| +#endif | 
| +  return static_cast<SharedUint8ClampedArray*>(value); | 
| +} | 
| + | 
| + | 
| Function* Function::Cast(v8::Value* value) { | 
| #ifdef V8_ENABLE_CHECKS | 
| CheckCast(value); | 
|  |