diff --git a/ash/src/entry.rs b/ash/src/entry.rs index eb3ab82..a181818 100644 --- a/ash/src/entry.rs +++ b/ash/src/entry.rs @@ -77,6 +77,10 @@ pub trait EntryV1_0 { type Instance; fn fp_v1_0(&self) -> &vk::EntryFnV1_0; fn static_fn(&self) -> &vk::StaticFn; + /// # Safety + /// In order for the created `Instance` to be valid for the duration of its + /// usage, the `Entry` this was called on must be dropped later than the + /// resulting `Instance`. #[doc = ""] unsafe fn create_instance( &self, @@ -138,6 +142,10 @@ pub trait EntryV1_0 { impl EntryV1_0 for EntryCustom { type Instance = Instance; + /// # Safety + /// In order for the created `Instance` to be valid for the duration of its + /// usage, the `Entry` this was called on must be dropped later than the + /// resulting `Instance`. #[doc = ""] unsafe fn create_instance( &self, diff --git a/ash/src/instance.rs b/ash/src/instance.rs index 4599a00..36d9d77 100644 --- a/ash/src/instance.rs +++ b/ash/src/instance.rs @@ -38,6 +38,10 @@ impl Instance { impl InstanceV1_0 for Instance { type Device = Device; + /// # Safety + /// In order for the created `Device` to be valid for the duration of its + /// usage, the `Instance` this was called on must be dropped later than the + /// resulting `Device`. #[doc = ""] unsafe fn create_device( &self, @@ -288,6 +292,10 @@ pub trait InstanceV1_0 { type Device; fn handle(&self) -> vk::Instance; fn fp_v1_0(&self) -> &vk::InstanceFnV1_0; + /// # Safety + /// In order for the created `Device` to be valid for the duration of its + /// usage, the `Instance` this was called on must be dropped later than the + /// resulting `Device`. #[doc = ""] unsafe fn create_device( &self,