2016-12-09 19:30:05 +01:00
#Ash
2016-12-09 19:33:25 +00:00
2016-12-09 23:13:58 +01:00
A very lightweight wrapper around Vulkan
2016-12-09 20:38:22 +01:00
[![LICENSE ](https://img.shields.io/badge/license-MIT-blue.svg )](LICENSE-MIT)
[![LICENSE ](https://img.shields.io/badge/license-apache-blue.svg )](LICENSE-APACHE)
2016-12-09 20:49:49 +01:00
[![Documentation ](https://docs.rs/ash/badge.svg )](https://docs.rs/ash)
2016-12-09 20:38:22 +01:00
[![Build Status ](https://travis-ci.org/MaikKlein/ash.svg?branch=master )](https://travis-ci.org/MaikKlein/ash)
2016-12-09 19:33:25 +00:00
[![Join the chat at https://gitter.im/MaikKlein/ash ](https://badges.gitter.im/MaikKlein/ash.svg )](https://gitter.im/MaikKlein/ash?utm_source=badge& utm_medium=badge& utm_campaign=pr-badge& utm_content=badge)
2016-12-09 20:45:09 +01:00
[![Crates.io Version ](https://img.shields.io/crates/v/ash.svg )](https://crates.io/crates/ash)
2016-12-23 02:01:36 +01:00
[![ ](https://tokei.rs/b1/github/maikklein/ash )](https://github.com/MaikKlein/ash)
2016-08-14 01:13:39 +02:00
2016-12-09 20:19:54 +01:00
## Stable yet?
No.
2016-12-09 19:25:48 +01:00
2016-12-09 19:30:05 +01:00
## Why Ash?
2016-12-23 22:02:03 +01:00
- [x] Lightweight Vulkan wrapper
- [x] Low overhead
- [x] Added type safety
- [x] More convenient to use than raw Vulkan
- [x] Includes a loader
- [x] Extensions have their own loader
2016-12-09 19:25:48 +01:00
2016-12-23 22:02:03 +01:00
## What does it do?
2016-12-09 19:25:48 +01:00
Functions return a `type VkResult<T> = Result<T, vk::Result>` instead of an error code. No mutable references for the output are required.
```Rust
2016-12-23 21:41:16 +01:00
pub fn create_swapchain_khr(& self,
create_info: & vk::SwapchainCreateInfoKHR)
-> VkResult< vk::SwapchainKHR > ;
let swapchain = device.create_swapchain_khr(&swapchain_create_info).unwrap();
2016-12-09 19:25:48 +01:00
```
Always returns a `Vec<T>` for functions that output multiple values.
```Rust
2016-12-23 21:41:16 +01:00
pub fn get_swapchain_images_khr(& self,
swapchain: vk::SwapchainKHR)
-> VkResult< Vec < vk::Image > >;
let present_images = device.get_swapchain_images_khr(swapchain).unwrap();
2016-12-09 19:25:48 +01:00
```
2016-12-09 19:30:05 +01:00
Ash always uses slices in functions.
2016-12-09 19:25:48 +01:00
```Rust
2016-12-23 21:41:16 +01:00
// C
void vkCmdPipelineBarrier(
VkCommandBuffer commandBuffer,
VkPipelineStageFlags srcStageMask,
VkPipelineStageFlags dstStageMask,
VkDependencyFlags dependencyFlags,
uint32_t memoryBarrierCount,
const VkMemoryBarrier* pMemoryBarriers,
uint32_t bufferMemoryBarrierCount,
const VkBufferMemoryBarrier* pBufferMemoryBarriers,
uint32_t imageMemoryBarrierCount,
const VkImageMemoryBarrier* pImageMemoryBarriers);
2016-12-09 19:25:48 +01:00
2016-12-23 21:41:16 +01:00
// Rust
pub fn cmd_pipeline_barrier(& self,
command_buffer: vk::CommandBuffer,
src_stage_mask: vk::PipelineStageFlags,
dst_stage_mask: vk::PipelineStageFlags,
dependency_flags: vk::DependencyFlags,
memory_barriers: & [vk::MemoryBarrier],
buffer_memory_barriers: & [vk::BufferMemoryBarrier],
image_memory_barriers: &[vk::ImageMemoryBarrier]);
2016-12-09 19:25:48 +01:00
2016-12-23 21:41:16 +01:00
device.cmd_pipeline_barrier(setup_command_buffer,
vk::PIPELINE_STAGE_TOP_OF_PIPE_BIT,
vk::PIPELINE_STAGE_TOP_OF_PIPE_BIT,
vk::DependencyFlags::empty(),
& [],
& [],
&[layout_transition_barrier]);
2016-12-09 19:39:16 +01:00
2016-12-23 21:41:16 +01:00
// or
2016-12-09 19:39:16 +01:00
2016-12-23 21:41:16 +01:00
let slice = device.map_memory::< Vertex > (vertex_input_buffer_memory,
0,
vertex_input_buffer_info.size,
vk::MemoryMapFlags::empty())
.unwrap();
slice.copy_from_slice(&vertices);
2016-12-09 19:25:48 +01:00
```
Ash still uses raw Vulkan structs. The only difference is type safety. Everything that can be an enum is an enum like `vk::StructureType` , flags are implemented similar to the `Bitflags` crate. Ash also follows the Rust style guide. The reason that Ash uses raw Vulkan structs is to be extensible, just like the Vulkan spec.
```Rust
2016-12-23 21:41:16 +01:00
let pool_create_info = vk::CommandPoolCreateInfo {
s_type: vk::StructureType::CommandPoolCreateInfo,
p_next: ptr::null(),
flags: vk::COMMAND_POOL_CREATE_RESET_COMMAND_BUFFER_BIT,
queue_family_index: queue_family_index,
};
let pool = device.create_command_pool(&pool_create_info).unwrap();
2016-12-09 19:25:48 +01:00
```
Ash also takes care of loading the function pointers. Function pointers are split into 3 categories. Entry, Instance and Device. The reason for not loading it into a global is that in Vulkan you can have multiple devices and each device must load its own function pointers.
```Rust
2016-12-23 21:41:16 +01:00
// Looks for the vulkan lib in your path, alternatively you can supply the path explicitly.
let entry = Entry::load_vulkan().unwrap();
let instance: Instance = entry.create_instance(& create_info).expect("Instance creation error");
let device: Device = instance.create_device(pdevice, & device_create_info)
.unwrap();
```
2016-12-23 21:42:13 +01:00
Additionally, every Vulkan extension has to be loaded explicity. You can find all extensions under [ash::extensions ](https://github.com/MaikKlein/ash/tree/master/src/extensions ). You still have to tell Vulkan which instance or device extensions you want to load.
2016-12-23 21:41:16 +01:00
```Rust
use ash::extensions::Swapchain;
let swapchain_loader = Swapchain::new(& instance, & device).expect("Unable to load swapchain");
let swapchain = swapchain_loader.create_swapchain_khr(&swapchain_create_info).unwrap();
2016-12-09 19:25:48 +01:00
```
You don't have to pass an Instance or Device handle anymore, this is done implicitly for you.
```Rust
2016-12-23 21:41:16 +01:00
// C
VkResult vkCreateCommandPool(
VkDevice device,
const VkCommandPoolCreateInfo* pCreateInfo,
const VkAllocationCallbacks* pAllocator,
VkCommandPool* pCommandPool);
2016-12-09 19:25:48 +01:00
2016-12-23 21:41:16 +01:00
// Rust
pub fn create_command_pool(& self,
create_info: & vk::CommandPoolCreateInfo)
-> VkResult< vk::CommandPool > ;
2016-12-09 19:25:48 +01:00
2016-12-23 21:41:16 +01:00
let pool = device.create_command_pool(&pool_create_info).unwrap();
2016-12-09 19:25:48 +01:00
```
2016-12-09 19:39:16 +01:00
## Example
You can find the examples [here ](https://github.com/MaikKlein/ash/tree/master/examples ).
2016-12-25 14:49:20 +01:00
All examples currently require: the LunarG Validation layers and a Vulkan library that is visible in your `PATH` .
### [Triangle](https://github.com/MaikKlein/ash/blob/master/examples/src/bin/triangle.rs)
Display a triangle with vertex colors.
2016-12-09 21:01:44 +01:00
```
2016-12-25 14:49:20 +01:00
cd examples
cargo run --bin triangle
2016-12-09 21:01:44 +01:00
```
2016-12-09 19:39:16 +01:00
2016-12-09 19:47:29 +01:00
![screenshot ](http://i.imgur.com/PQZcL6w.jpg )
2016-12-09 19:39:16 +01:00
2016-12-25 14:49:20 +01:00
### [Texture](https://github.com/MaikKlein/ash/blob/master/examples/src/bin/texture.rs)
2016-12-12 04:43:46 +01:00
Displays a texture on a quad. *Needs a cleanup* .
```
2016-12-25 14:49:20 +01:00
cd examples
cargo run --bin texture
2016-12-12 04:43:46 +01:00
```
2016-12-12 04:30:01 +01:00
![texture ](http://i.imgur.com/trow00H.png )
2016-12-12 04:19:21 +01:00
2016-12-09 19:47:29 +01:00
## Roadmap
2016-12-09 19:25:48 +01:00
2016-12-23 11:41:43 +01:00
### Extensions
- [x] Swapchain
- [x] Surface
- [x] XlibSurface
- [x] DebugReport
2016-12-23 11:43:44 +01:00
- [ ] Win32Surface
- [ ] MirSurface
- [ ] XcbSurface
- [ ] AndroidSurface
- [ ] WaylandSurface
- [ ] Display
2016-12-23 11:41:43 +01:00
2016-12-09 19:47:29 +01:00
### In progress
2016-12-09 19:25:48 +01:00
- Wrapping the complete spec
2016-12-09 19:47:29 +01:00
### Not started
2016-12-24 06:00:24 +01:00
- [Custom allocators ](https://github.com/MaikKlein/ash/issues/2.static_fn )
2016-12-09 21:04:31 +01:00
## A thanks to
* [Api with no secrets ](https://software.intel.com/en-us/articles/api-without-secrets-introduction-to-vulkan-part-1 )
* [Vulkan tutorial ](http://av.dfki.de/~jhenriques/development.html )
* [Vulkan examples ](https://github.com/SaschaWillems/Vulkan )
2016-12-09 21:05:19 +01:00
* [Vulkan tutorial ](https://vulkan-tutorial.com/ )
2016-12-09 21:04:31 +01:00
* [Vulkano ](https://github.com/tomaka/vulkano/ )
* [vk-rs ](https://github.com/Osspial/vk-rs )