2020-01-21 10:03:42 -05:00
|
|
|
// Copyright 2019-2020 the Deno authors. All rights reserved. MIT license.
|
|
|
|
|
|
|
|
use std::ffi::c_void;
|
|
|
|
use std::ptr::null_mut;
|
|
|
|
|
2020-01-17 08:41:12 -05:00
|
|
|
use crate::array_buffer::backing_store_deleter_callback;
|
2019-12-28 16:29:42 -05:00
|
|
|
use crate::support::SharedRef;
|
2020-01-21 10:03:42 -05:00
|
|
|
use crate::support::UniqueRef;
|
2019-12-28 16:29:42 -05:00
|
|
|
use crate::BackingStore;
|
2020-01-17 08:41:12 -05:00
|
|
|
use crate::BackingStoreDeleterCallback;
|
2020-01-21 10:03:42 -05:00
|
|
|
use crate::InIsolate;
|
2019-12-28 16:29:42 -05:00
|
|
|
use crate::Isolate;
|
|
|
|
use crate::Local;
|
2019-12-30 09:28:39 -05:00
|
|
|
use crate::SharedArrayBuffer;
|
2019-12-28 16:29:42 -05:00
|
|
|
use crate::ToLocal;
|
|
|
|
|
|
|
|
extern "C" {
|
2020-01-21 10:03:42 -05:00
|
|
|
fn v8__SharedArrayBuffer__New__with_byte_length(
|
2019-12-28 16:29:42 -05:00
|
|
|
isolate: *mut Isolate,
|
|
|
|
byte_length: usize,
|
2020-04-13 08:43:56 -04:00
|
|
|
) -> *const SharedArrayBuffer;
|
2020-01-21 10:03:42 -05:00
|
|
|
fn v8__SharedArrayBuffer__New__with_backing_store(
|
2020-01-03 08:40:39 -05:00
|
|
|
isolate: *mut Isolate,
|
2020-04-13 08:43:56 -04:00
|
|
|
backing_store: *const SharedRef<BackingStore>,
|
|
|
|
) -> *const SharedArrayBuffer;
|
|
|
|
fn v8__SharedArrayBuffer__ByteLength(this: *const SharedArrayBuffer)
|
|
|
|
-> usize;
|
2019-12-28 16:29:42 -05:00
|
|
|
fn v8__SharedArrayBuffer__GetBackingStore(
|
2020-04-13 08:43:56 -04:00
|
|
|
this: *const SharedArrayBuffer,
|
2019-12-28 16:29:42 -05:00
|
|
|
) -> SharedRef<BackingStore>;
|
2020-01-21 10:03:42 -05:00
|
|
|
fn v8__SharedArrayBuffer__NewBackingStore__with_byte_length(
|
|
|
|
isolate: *mut Isolate,
|
|
|
|
byte_length: usize,
|
|
|
|
) -> *mut BackingStore;
|
|
|
|
fn v8__SharedArrayBuffer__NewBackingStore__with_data(
|
|
|
|
data: *mut c_void,
|
2020-01-17 08:41:12 -05:00
|
|
|
byte_length: usize,
|
|
|
|
deleter: BackingStoreDeleterCallback,
|
2020-01-21 10:03:42 -05:00
|
|
|
deleter_data: *mut c_void,
|
|
|
|
) -> *mut BackingStore;
|
2019-12-28 16:29:42 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
impl SharedArrayBuffer {
|
|
|
|
/// 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.
|
|
|
|
pub fn new<'sc>(
|
|
|
|
scope: &mut impl ToLocal<'sc>,
|
|
|
|
byte_length: usize,
|
|
|
|
) -> Option<Local<'sc, SharedArrayBuffer>> {
|
|
|
|
unsafe {
|
2020-05-31 12:45:00 -04:00
|
|
|
let ptr = v8__SharedArrayBuffer__New__with_byte_length(
|
2020-01-21 10:03:42 -05:00
|
|
|
scope.isolate(),
|
|
|
|
byte_length,
|
2020-05-31 12:45:00 -04:00
|
|
|
);
|
|
|
|
scope.to_local(ptr)
|
2019-12-28 16:29:42 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-01-21 10:03:42 -05:00
|
|
|
pub fn with_backing_store<'sc>(
|
|
|
|
scope: &mut impl ToLocal<'sc>,
|
2020-04-13 08:43:56 -04:00
|
|
|
backing_store: &SharedRef<BackingStore>,
|
2020-01-21 10:03:42 -05:00
|
|
|
) -> Local<'sc, SharedArrayBuffer> {
|
|
|
|
let isolate = scope.isolate();
|
|
|
|
let ptr = unsafe {
|
2020-04-13 08:43:56 -04:00
|
|
|
v8__SharedArrayBuffer__New__with_backing_store(isolate, backing_store)
|
2020-01-21 10:03:42 -05:00
|
|
|
};
|
|
|
|
unsafe { scope.to_local(ptr) }.unwrap()
|
|
|
|
}
|
|
|
|
|
2019-12-28 16:29:42 -05:00
|
|
|
/// Data length in bytes.
|
|
|
|
pub fn byte_length(&self) -> usize {
|
|
|
|
unsafe { v8__SharedArrayBuffer__ByteLength(self) }
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Get a shared pointer to the backing store of this array buffer. This
|
|
|
|
/// pointer coordinates the lifetime management of the internal storage
|
|
|
|
/// with any live ArrayBuffers on the heap, even across isolates. The embedder
|
|
|
|
/// should not attempt to manage lifetime of the storage through other means.
|
|
|
|
pub fn get_backing_store(&self) -> SharedRef<BackingStore> {
|
|
|
|
unsafe { v8__SharedArrayBuffer__GetBackingStore(self) }
|
|
|
|
}
|
2020-01-17 08:41:12 -05:00
|
|
|
|
2020-01-21 10:03:42 -05:00
|
|
|
/// Returns a new standalone BackingStore that is allocated using the array
|
|
|
|
/// buffer allocator of the isolate. The result can be later passed to
|
|
|
|
/// ArrayBuffer::New.
|
|
|
|
///
|
|
|
|
/// If the allocator returns nullptr, then the function may cause GCs in the
|
|
|
|
/// given isolate and re-try the allocation. If GCs do not help, then the
|
|
|
|
/// function will crash with an out-of-memory error.
|
|
|
|
pub fn new_backing_store(
|
|
|
|
scope: &mut impl InIsolate,
|
|
|
|
byte_length: usize,
|
|
|
|
) -> UniqueRef<BackingStore> {
|
|
|
|
unsafe {
|
|
|
|
UniqueRef::from_raw(
|
|
|
|
v8__SharedArrayBuffer__NewBackingStore__with_byte_length(
|
|
|
|
scope.isolate(),
|
|
|
|
byte_length,
|
|
|
|
),
|
|
|
|
)
|
|
|
|
}
|
2020-01-17 08:41:12 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Returns a new standalone BackingStore that takes over the ownership of
|
|
|
|
/// the given buffer.
|
|
|
|
///
|
|
|
|
/// The destructor of the BackingStore frees owned buffer memory.
|
|
|
|
///
|
|
|
|
/// The result can be later passed to SharedArrayBuffer::New. The raw pointer
|
|
|
|
/// to the buffer must not be passed again to any V8 API function.
|
2020-01-23 12:16:56 -05:00
|
|
|
pub fn new_backing_store_from_boxed_slice(
|
2020-01-17 08:41:12 -05:00
|
|
|
data: Box<[u8]>,
|
2020-01-21 10:03:42 -05:00
|
|
|
) -> UniqueRef<BackingStore> {
|
2020-01-17 08:41:12 -05:00
|
|
|
let byte_length = data.len();
|
2020-01-21 10:03:42 -05:00
|
|
|
let data_ptr = Box::into_raw(data) as *mut c_void;
|
2020-01-23 12:16:56 -05:00
|
|
|
unsafe {
|
|
|
|
UniqueRef::from_raw(v8__SharedArrayBuffer__NewBackingStore__with_data(
|
|
|
|
data_ptr,
|
|
|
|
byte_length,
|
|
|
|
backing_store_deleter_callback,
|
|
|
|
null_mut(),
|
|
|
|
))
|
|
|
|
}
|
2020-01-17 08:41:12 -05:00
|
|
|
}
|
2019-12-28 16:29:42 -05:00
|
|
|
}
|