pub struct ImmutableBuffer<T, A = PotentialDedicatedAllocation<StdMemoryPoolAlloc>> where
T: BufferContents + ?Sized, { /* private fields */ }
Expand description
Buffer that is written once then read for as long as it is alive.
Implementations
sourceimpl<T> ImmutableBuffer<T> where
T: BufferContents + ?Sized,
impl<T> ImmutableBuffer<T> where
T: BufferContents + ?Sized,
sourcepub fn from_buffer<B>(
source: Arc<B>,
usage: BufferUsage,
queue: Arc<Queue>
) -> Result<(Arc<ImmutableBuffer<T>>, CommandBufferExecFuture<NowFuture, PrimaryAutoCommandBuffer>), DeviceMemoryAllocationError> where
B: TypedBufferAccess<Content = T> + 'static,
pub fn from_buffer<B>(
source: Arc<B>,
usage: BufferUsage,
queue: Arc<Queue>
) -> Result<(Arc<ImmutableBuffer<T>>, CommandBufferExecFuture<NowFuture, PrimaryAutoCommandBuffer>), DeviceMemoryAllocationError> where
B: TypedBufferAccess<Content = T> + 'static,
Builds an ImmutableBuffer
that copies its data from another buffer.
This function returns two objects: the newly-created buffer, and a future representing
the initial upload operation. In order to be allowed to use the ImmutableBuffer
, you must
either submit your operation after this future, or execute this future and wait for it to
be finished before submitting your own operation.
sourceimpl<T> ImmutableBuffer<T> where
T: BufferContents,
impl<T> ImmutableBuffer<T> where
T: BufferContents,
sourcepub fn from_data(
data: T,
usage: BufferUsage,
queue: Arc<Queue>
) -> Result<(Arc<ImmutableBuffer<T>>, CommandBufferExecFuture<NowFuture, PrimaryAutoCommandBuffer>), DeviceMemoryAllocationError>
pub fn from_data(
data: T,
usage: BufferUsage,
queue: Arc<Queue>
) -> Result<(Arc<ImmutableBuffer<T>>, CommandBufferExecFuture<NowFuture, PrimaryAutoCommandBuffer>), DeviceMemoryAllocationError>
Builds an ImmutableBuffer
from some data.
This function builds a memory-mapped intermediate buffer, writes the data to it, builds a command buffer that copies from this intermediate buffer to the final buffer, and finally submits the command buffer as a future.
This function returns two objects: the newly-created buffer, and a future representing
the initial upload operation. In order to be allowed to use the ImmutableBuffer
, you must
either submit your operation after this future, or execute this future and wait for it to
be finished before submitting your own operation.
Panics
- Panics if
T
has zero size.
sourcepub unsafe fn uninitialized(
device: Arc<Device>,
usage: BufferUsage
) -> Result<(Arc<ImmutableBuffer<T>>, Arc<ImmutableBufferInitialization<T>>), DeviceMemoryAllocationError>
pub unsafe fn uninitialized(
device: Arc<Device>,
usage: BufferUsage
) -> Result<(Arc<ImmutableBuffer<T>>, Arc<ImmutableBufferInitialization<T>>), DeviceMemoryAllocationError>
Builds a new buffer with uninitialized data. Only allowed for sized data.
Returns two things: the buffer, and a special access that should be used for the initial upload to the buffer.
You will get an error if you try to use the buffer before using the initial upload access. However this function doesn’t check whether you actually used this initial upload to fill the buffer like you’re supposed to do.
You will also get an error if you try to get exclusive access to the final buffer.
Safety
- The
ImmutableBufferInitialization
should be used to fill the buffer with some initial data, otherwise the content is undefined.
Panics
- Panics if
T
has zero size.
sourceimpl<T> ImmutableBuffer<[T]> where
[T]: BufferContents,
impl<T> ImmutableBuffer<[T]> where
[T]: BufferContents,
sourcepub fn from_iter<D>(
data: D,
usage: BufferUsage,
queue: Arc<Queue>
) -> Result<(Arc<ImmutableBuffer<[T]>>, CommandBufferExecFuture<NowFuture, PrimaryAutoCommandBuffer>), DeviceMemoryAllocationError> where
D: IntoIterator<Item = T>,
D::IntoIter: ExactSizeIterator,
pub fn from_iter<D>(
data: D,
usage: BufferUsage,
queue: Arc<Queue>
) -> Result<(Arc<ImmutableBuffer<[T]>>, CommandBufferExecFuture<NowFuture, PrimaryAutoCommandBuffer>), DeviceMemoryAllocationError> where
D: IntoIterator<Item = T>,
D::IntoIter: ExactSizeIterator,
Panics
- Panics if
T
has zero size. - Panics if
data
is empty.
sourcepub unsafe fn uninitialized_array(
device: Arc<Device>,
len: DeviceSize,
usage: BufferUsage
) -> Result<(Arc<ImmutableBuffer<[T]>>, Arc<ImmutableBufferInitialization<[T]>>), DeviceMemoryAllocationError>
pub unsafe fn uninitialized_array(
device: Arc<Device>,
len: DeviceSize,
usage: BufferUsage
) -> Result<(Arc<ImmutableBuffer<[T]>>, Arc<ImmutableBufferInitialization<[T]>>), DeviceMemoryAllocationError>
Builds a new buffer with uninitialized data. Can be used for arrays.
Returns two things: the buffer, and a special access that should be used for the initial upload to the buffer.
You will get an error if you try to use the buffer before using the initial upload access. However this function doesn’t check whether you actually used this initial upload to fill the buffer like you’re supposed to do.
You will also get an error if you try to get exclusive access to the final buffer.
Safety
- The
ImmutableBufferInitialization
should be used to fill the buffer with some initial data, otherwise the content is undefined.
Panics
- Panics if
T
has zero size. - Panics if
len
is zero.
sourceimpl<T> ImmutableBuffer<T> where
T: BufferContents + ?Sized,
impl<T> ImmutableBuffer<T> where
T: BufferContents + ?Sized,
sourcepub unsafe fn raw<'a, I>(
device: Arc<Device>,
size: DeviceSize,
usage: BufferUsage,
queue_families: I
) -> Result<(Arc<ImmutableBuffer<T>>, Arc<ImmutableBufferInitialization<T>>), DeviceMemoryAllocationError> where
I: IntoIterator<Item = QueueFamily<'a>>,
pub unsafe fn raw<'a, I>(
device: Arc<Device>,
size: DeviceSize,
usage: BufferUsage,
queue_families: I
) -> Result<(Arc<ImmutableBuffer<T>>, Arc<ImmutableBufferInitialization<T>>), DeviceMemoryAllocationError> where
I: IntoIterator<Item = QueueFamily<'a>>,
Builds a new buffer without checking the size and granting free access for the initial upload.
Returns two things: the buffer, and a special access that should be used for the initial upload to the buffer. You will get an error if you try to use the buffer before using the initial upload access. However this function doesn’t check whether you used this initial upload to fill the buffer. You will also get an error if you try to get exclusive access to the final buffer.
Safety
- You must ensure that the size that you pass is correct for
T
. - The
ImmutableBufferInitialization
should be used to fill the buffer with some initial data.
Panics
- Panics if
size
is zero.
sourceimpl<T, A> ImmutableBuffer<T, A> where
T: BufferContents + ?Sized,
impl<T, A> ImmutableBuffer<T, A> where
T: BufferContents + ?Sized,
sourcepub fn queue_families(&self) -> Vec<QueueFamily<'_>>
pub fn queue_families(&self) -> Vec<QueueFamily<'_>>
Returns the queue families this buffer can be used on.
Trait Implementations
sourceimpl<T, A> BufferAccess for ImmutableBuffer<T, A> where
T: BufferContents + ?Sized,
A: Send + Sync,
impl<T, A> BufferAccess for ImmutableBuffer<T, A> where
T: BufferContents + ?Sized,
A: Send + Sync,
sourcefn inner(&self) -> BufferInner<'_>
fn inner(&self) -> BufferInner<'_>
Returns the inner information about this buffer.
sourcefn size(&self) -> DeviceSize
fn size(&self) -> DeviceSize
Returns the size of the buffer in bytes.
sourcefn conflict_key(&self) -> (u64, u64)
fn conflict_key(&self) -> (u64, u64)
Returns a key that uniquely identifies the buffer. Two buffers or images that potentially overlap in memory must return the same key. Read more
sourcefn try_gpu_lock(
&self,
exclusive_access: bool,
_: &Queue
) -> Result<(), AccessError>
fn try_gpu_lock(
&self,
exclusive_access: bool,
_: &Queue
) -> Result<(), AccessError>
Locks the resource for usage on the GPU. Returns an error if the lock can’t be acquired. Read more
sourceunsafe fn increase_gpu_lock(&self)
unsafe fn increase_gpu_lock(&self)
Locks the resource for usage on the GPU. Supposes that the resource is already locked, and simply increases the lock by one. Read more
sourceunsafe fn unlock(&self)
unsafe fn unlock(&self)
Unlocks the resource previously acquired with try_gpu_lock
or increase_gpu_lock
. Read more
sourcefn into_buffer_slice(self: &Arc<Self>) -> Arc<BufferSlice<Self::Content, Self>> where
Self: Sized + TypedBufferAccess,
fn into_buffer_slice(self: &Arc<Self>) -> Arc<BufferSlice<Self::Content, Self>> where
Self: Sized + TypedBufferAccess,
Returns a BufferSlice
covering the whole buffer.
sourcefn slice<T>(
self: &Arc<Self>,
range: Range<DeviceSize>
) -> Option<Arc<BufferSlice<[T], Self>>> where
Self: Sized + TypedBufferAccess<Content = [T]>,
fn slice<T>(
self: &Arc<Self>,
range: Range<DeviceSize>
) -> Option<Arc<BufferSlice<[T], Self>>> where
Self: Sized + TypedBufferAccess<Content = [T]>,
Returns a BufferSlice
for a subrange of elements in the buffer. Returns None
if
out of range. Read more
sourcefn index<T>(
self: &Arc<Self>,
index: DeviceSize
) -> Option<Arc<BufferSlice<T, Self>>> where
Self: Sized + TypedBufferAccess<Content = [T]>,
fn index<T>(
self: &Arc<Self>,
index: DeviceSize
) -> Option<Arc<BufferSlice<T, Self>>> where
Self: Sized + TypedBufferAccess<Content = [T]>,
Returns a BufferSlice
for a single element in the buffer. Returns None
if out of range. Read more
sourcefn raw_device_address(&self) -> Result<NonZeroU64, BufferDeviceAddressError>
fn raw_device_address(&self) -> Result<NonZeroU64, BufferDeviceAddressError>
Gets the device address for this buffer. Read more
sourceimpl<T: Debug, A: Debug> Debug for ImmutableBuffer<T, A> where
T: BufferContents + ?Sized,
impl<T: Debug, A: Debug> Debug for ImmutableBuffer<T, A> where
T: BufferContents + ?Sized,
sourceimpl<T, A> DeviceOwned for ImmutableBuffer<T, A> where
T: BufferContents + ?Sized,
impl<T, A> DeviceOwned for ImmutableBuffer<T, A> where
T: BufferContents + ?Sized,
sourceimpl<T, A> Hash for ImmutableBuffer<T, A> where
T: BufferContents + ?Sized,
A: Send + Sync,
impl<T, A> Hash for ImmutableBuffer<T, A> where
T: BufferContents + ?Sized,
A: Send + Sync,
sourceimpl<T, A> PartialEq<ImmutableBuffer<T, A>> for ImmutableBuffer<T, A> where
T: BufferContents + ?Sized,
A: Send + Sync,
impl<T, A> PartialEq<ImmutableBuffer<T, A>> for ImmutableBuffer<T, A> where
T: BufferContents + ?Sized,
A: Send + Sync,
sourceimpl<T, A> TypedBufferAccess for ImmutableBuffer<T, A> where
T: BufferContents + ?Sized,
A: Send + Sync,
impl<T, A> TypedBufferAccess for ImmutableBuffer<T, A> where
T: BufferContents + ?Sized,
A: Send + Sync,
type Content = T
type Content = T
The type of the content.
sourcefn len(&self) -> DeviceSize
fn len(&self) -> DeviceSize
Returns the length of the buffer in number of elements. Read more
impl<T, A> Eq for ImmutableBuffer<T, A> where
T: BufferContents + ?Sized,
A: Send + Sync,
Auto Trait Implementations
impl<T: ?Sized, A> RefUnwindSafe for ImmutableBuffer<T, A> where
A: RefUnwindSafe,
T: RefUnwindSafe,
impl<T: ?Sized, A> Send for ImmutableBuffer<T, A> where
A: Send,
impl<T: ?Sized, A> Sync for ImmutableBuffer<T, A> where
A: Sync,
impl<T: ?Sized, A> Unpin for ImmutableBuffer<T, A> where
A: Unpin,
impl<T: ?Sized, A> UnwindSafe for ImmutableBuffer<T, A> where
A: UnwindSafe,
T: UnwindSafe,
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more