rt(gl): use struct for draw_quad
This commit is contained in:
parent
c121087348
commit
aca5b5420c
12
Cargo.lock
generated
12
Cargo.lock
generated
|
@ -610,6 +610,17 @@ dependencies = [
|
||||||
"memchr",
|
"memchr",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "concat-arrays"
|
||||||
|
version = "0.1.2"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "1df715824eb382e34b7afb7463b0247bf41538aeba731fba05241ecdb5dc3747"
|
||||||
|
dependencies = [
|
||||||
|
"proc-macro2",
|
||||||
|
"quote",
|
||||||
|
"syn 1.0.109",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "concurrent-queue"
|
name = "concurrent-queue"
|
||||||
version = "2.4.0"
|
version = "2.4.0"
|
||||||
|
@ -1666,6 +1677,7 @@ name = "librashader-runtime-gl"
|
||||||
version = "0.2.0-beta.9"
|
version = "0.2.0-beta.9"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bytemuck",
|
"bytemuck",
|
||||||
|
"concat-arrays",
|
||||||
"gl",
|
"gl",
|
||||||
"glfw 0.47.0",
|
"glfw 0.47.0",
|
||||||
"librashader-cache",
|
"librashader-cache",
|
||||||
|
|
|
@ -196,6 +196,9 @@ mod test {
|
||||||
|
|
||||||
let compiled = msl.compile(Some(msl::Version::V2_0)).unwrap();
|
let compiled = msl.compile(Some(msl::Version::V2_0)).unwrap();
|
||||||
|
|
||||||
println!("{:?}", compiled.context.fragment.translation_info.entry_point_names);
|
println!(
|
||||||
|
"{:?}",
|
||||||
|
compiled.context.fragment.translation_info.entry_point_names
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,9 +22,10 @@ spirv_cross = { package = "librashader-spirv-cross", version = "0.24" }
|
||||||
|
|
||||||
rustc-hash = "1.1.0"
|
rustc-hash = "1.1.0"
|
||||||
gl = "0.14.0"
|
gl = "0.14.0"
|
||||||
bytemuck = "1.12.3"
|
bytemuck = { version = "1.12.3", features = ["derive"] }
|
||||||
thiserror = "1.0.37"
|
thiserror = "1.0.37"
|
||||||
rayon = "1.6.1"
|
rayon = "1.6.1"
|
||||||
|
concat-arrays = "0.1.2"
|
||||||
|
|
||||||
sptr = "0.3"
|
sptr = "0.3"
|
||||||
|
|
||||||
|
|
|
@ -1,13 +1,7 @@
|
||||||
use crate::gl::DrawQuad;
|
use crate::gl::FINAL_VBO_DATA;
|
||||||
|
use crate::gl::{DrawQuad, OpenGLVertex};
|
||||||
use gl::types::{GLsizei, GLsizeiptr, GLuint};
|
use gl::types::{GLsizei, GLsizeiptr, GLuint};
|
||||||
|
use std::mem::offset_of;
|
||||||
#[rustfmt::skip]
|
|
||||||
static QUAD_VBO_DATA: &[f32; 16] = &[
|
|
||||||
0.0, 0.0, 0.0, 0.0,
|
|
||||||
1.0, 0.0, 1.0, 0.0,
|
|
||||||
0.0, 1.0, 0.0, 1.0,
|
|
||||||
1.0, 1.0, 1.0, 1.0,
|
|
||||||
];
|
|
||||||
|
|
||||||
pub struct Gl3DrawQuad {
|
pub struct Gl3DrawQuad {
|
||||||
vbo: GLuint,
|
vbo: GLuint,
|
||||||
|
@ -24,8 +18,8 @@ impl DrawQuad for Gl3DrawQuad {
|
||||||
gl::BindBuffer(gl::ARRAY_BUFFER, vbo);
|
gl::BindBuffer(gl::ARRAY_BUFFER, vbo);
|
||||||
gl::BufferData(
|
gl::BufferData(
|
||||||
gl::ARRAY_BUFFER,
|
gl::ARRAY_BUFFER,
|
||||||
std::mem::size_of_val(QUAD_VBO_DATA) as GLsizeiptr,
|
4 * std::mem::size_of::<OpenGLVertex>() as GLsizeiptr,
|
||||||
QUAD_VBO_DATA.as_ptr().cast(),
|
FINAL_VBO_DATA.as_ptr().cast(),
|
||||||
gl::STATIC_DRAW,
|
gl::STATIC_DRAW,
|
||||||
);
|
);
|
||||||
gl::BindBuffer(gl::ARRAY_BUFFER, 0);
|
gl::BindBuffer(gl::ARRAY_BUFFER, 0);
|
||||||
|
@ -51,16 +45,16 @@ impl DrawQuad for Gl3DrawQuad {
|
||||||
2,
|
2,
|
||||||
gl::FLOAT,
|
gl::FLOAT,
|
||||||
gl::FALSE,
|
gl::FALSE,
|
||||||
(4 * std::mem::size_of::<f32>()) as GLsizei,
|
std::mem::size_of::<OpenGLVertex>() as GLsizei,
|
||||||
sptr::invalid(0),
|
sptr::invalid(offset_of!(OpenGLVertex, position)),
|
||||||
);
|
);
|
||||||
gl::VertexAttribPointer(
|
gl::VertexAttribPointer(
|
||||||
1,
|
1,
|
||||||
2,
|
2,
|
||||||
gl::FLOAT,
|
gl::FLOAT,
|
||||||
gl::FALSE,
|
gl::FALSE,
|
||||||
(4 * std::mem::size_of::<f32>()) as GLsizei,
|
std::mem::size_of::<OpenGLVertex>() as GLsizei,
|
||||||
sptr::invalid(2 * std::mem::size_of::<f32>()),
|
sptr::invalid(offset_of!(OpenGLVertex, position)),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,14 +1,7 @@
|
||||||
use crate::gl::DrawQuad;
|
use crate::gl::FINAL_VBO_DATA;
|
||||||
|
use crate::gl::{DrawQuad, OpenGLVertex};
|
||||||
use gl::types::{GLint, GLsizeiptr, GLuint};
|
use gl::types::{GLint, GLsizeiptr, GLuint};
|
||||||
|
use std::mem::offset_of;
|
||||||
#[rustfmt::skip]
|
|
||||||
static QUAD_VBO_DATA: &[f32; 16] = &[
|
|
||||||
0.0, 0.0, 0.0, 0.0,
|
|
||||||
1.0, 0.0, 1.0, 0.0,
|
|
||||||
0.0, 1.0, 0.0, 1.0,
|
|
||||||
1.0, 1.0, 1.0, 1.0,
|
|
||||||
];
|
|
||||||
|
|
||||||
pub struct Gl46DrawQuad {
|
pub struct Gl46DrawQuad {
|
||||||
vbo: GLuint,
|
vbo: GLuint,
|
||||||
vao: GLuint,
|
vao: GLuint,
|
||||||
|
@ -23,8 +16,8 @@ impl DrawQuad for Gl46DrawQuad {
|
||||||
gl::CreateBuffers(1, &mut vbo);
|
gl::CreateBuffers(1, &mut vbo);
|
||||||
gl::NamedBufferData(
|
gl::NamedBufferData(
|
||||||
vbo,
|
vbo,
|
||||||
std::mem::size_of_val(QUAD_VBO_DATA) as GLsizeiptr,
|
4 * std::mem::size_of::<OpenGLVertex>() as GLsizeiptr,
|
||||||
QUAD_VBO_DATA.as_ptr().cast(),
|
FINAL_VBO_DATA.as_ptr().cast(),
|
||||||
gl::STATIC_DRAW,
|
gl::STATIC_DRAW,
|
||||||
);
|
);
|
||||||
gl::CreateVertexArrays(1, &mut vao);
|
gl::CreateVertexArrays(1, &mut vao);
|
||||||
|
@ -32,16 +25,29 @@ impl DrawQuad for Gl46DrawQuad {
|
||||||
gl::EnableVertexArrayAttrib(vao, 0);
|
gl::EnableVertexArrayAttrib(vao, 0);
|
||||||
gl::EnableVertexArrayAttrib(vao, 1);
|
gl::EnableVertexArrayAttrib(vao, 1);
|
||||||
|
|
||||||
gl::VertexArrayVertexBuffer(vao, 0, vbo, 0, 4 * std::mem::size_of::<f32>() as GLint);
|
gl::VertexArrayVertexBuffer(
|
||||||
|
vao,
|
||||||
|
0,
|
||||||
|
vbo,
|
||||||
|
0,
|
||||||
|
std::mem::size_of::<OpenGLVertex>() as GLint,
|
||||||
|
);
|
||||||
|
|
||||||
gl::VertexArrayAttribFormat(vao, 0, 2, gl::FLOAT, gl::FALSE, 0);
|
gl::VertexArrayAttribFormat(
|
||||||
|
vao,
|
||||||
|
0,
|
||||||
|
2,
|
||||||
|
gl::FLOAT,
|
||||||
|
gl::FALSE,
|
||||||
|
offset_of!(OpenGLVertex, position) as GLuint,
|
||||||
|
);
|
||||||
gl::VertexArrayAttribFormat(
|
gl::VertexArrayAttribFormat(
|
||||||
vao,
|
vao,
|
||||||
1,
|
1,
|
||||||
2,
|
2,
|
||||||
gl::FLOAT,
|
gl::FLOAT,
|
||||||
gl::FALSE,
|
gl::FALSE,
|
||||||
2 * std::mem::size_of::<f32>() as GLuint,
|
offset_of!(OpenGLVertex, texcoord) as GLuint,
|
||||||
);
|
);
|
||||||
|
|
||||||
gl::VertexArrayAttribBinding(vao, 0, 0);
|
gl::VertexArrayAttribBinding(vao, 0, 0);
|
||||||
|
|
|
@ -7,6 +7,7 @@ use crate::error::Result;
|
||||||
use crate::framebuffer::GLImage;
|
use crate::framebuffer::GLImage;
|
||||||
use crate::samplers::SamplerSet;
|
use crate::samplers::SamplerSet;
|
||||||
use crate::texture::InputTexture;
|
use crate::texture::InputTexture;
|
||||||
|
use bytemuck::{Pod, Zeroable};
|
||||||
pub use framebuffer::GLFramebuffer;
|
pub use framebuffer::GLFramebuffer;
|
||||||
use gl::types::{GLenum, GLuint};
|
use gl::types::{GLenum, GLuint};
|
||||||
use librashader_common::{ImageFormat, Size};
|
use librashader_common::{ImageFormat, Size};
|
||||||
|
@ -17,6 +18,33 @@ use librashader_reflect::reflect::semantics::{BufferReflection, TextureBinding};
|
||||||
use librashader_runtime::uniforms::UniformStorageAccess;
|
use librashader_runtime::uniforms::UniformStorageAccess;
|
||||||
use rustc_hash::FxHashMap;
|
use rustc_hash::FxHashMap;
|
||||||
|
|
||||||
|
#[repr(C)]
|
||||||
|
#[derive(Debug, Copy, Clone, Default, Zeroable, Pod)]
|
||||||
|
|
||||||
|
pub(crate) struct OpenGLVertex {
|
||||||
|
pub position: [f32; 2],
|
||||||
|
pub texcoord: [f32; 2],
|
||||||
|
}
|
||||||
|
|
||||||
|
pub(crate) static FINAL_VBO_DATA: &[OpenGLVertex; 4] = &[
|
||||||
|
OpenGLVertex {
|
||||||
|
position: [0.0, 0.0],
|
||||||
|
texcoord: [0.0, 0.0],
|
||||||
|
},
|
||||||
|
OpenGLVertex {
|
||||||
|
position: [1.0, 0.0],
|
||||||
|
texcoord: [1.0, 0.0],
|
||||||
|
},
|
||||||
|
OpenGLVertex {
|
||||||
|
position: [0.0, 1.0],
|
||||||
|
texcoord: [0.0, 1.0],
|
||||||
|
},
|
||||||
|
OpenGLVertex {
|
||||||
|
position: [1.0, 1.0],
|
||||||
|
texcoord: [1.0, 1.0],
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
pub(crate) trait LoadLut {
|
pub(crate) trait LoadLut {
|
||||||
fn load_luts(textures: &[TextureConfig]) -> Result<FxHashMap<usize, InputTexture>>;
|
fn load_luts(textures: &[TextureConfig]) -> Result<FxHashMap<usize, InputTexture>>;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,12 +1,12 @@
|
||||||
use crate::error;
|
use crate::error;
|
||||||
use crate::memory::VulkanBuffer;
|
use crate::memory::VulkanBuffer;
|
||||||
|
use array_concat::concat_arrays;
|
||||||
use ash::vk;
|
use ash::vk;
|
||||||
|
use bytemuck::{Pod, Zeroable};
|
||||||
use gpu_allocator::vulkan::Allocator;
|
use gpu_allocator::vulkan::Allocator;
|
||||||
use librashader_runtime::quad::QuadType;
|
use librashader_runtime::quad::QuadType;
|
||||||
use parking_lot::RwLock;
|
use parking_lot::RwLock;
|
||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
use bytemuck::{Pod, Zeroable};
|
|
||||||
use array_concat::concat_arrays;
|
|
||||||
|
|
||||||
// Vulkan does vertex expansion
|
// Vulkan does vertex expansion
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
|
@ -75,8 +75,7 @@ impl DrawQuad {
|
||||||
|
|
||||||
{
|
{
|
||||||
let slice = buffer.as_mut_slice()?;
|
let slice = buffer.as_mut_slice()?;
|
||||||
slice
|
slice.copy_from_slice(bytemuck::cast_slice(VBO_DATA));
|
||||||
.copy_from_slice(bytemuck::cast_slice(VBO_DATA));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(DrawQuad {
|
Ok(DrawQuad {
|
||||||
|
|
Loading…
Reference in a new issue