gl: buffer building

This commit is contained in:
chyyran 2022-11-15 01:03:36 -05:00
parent d37fc0ccb5
commit 888d7be50f

View file

@ -21,6 +21,7 @@ pub struct FilterPass {
pub locations: FxHashMap<String, VariableLocation>, pub locations: FxHashMap<String, VariableLocation>,
pub framebuffer: Framebuffer, pub framebuffer: Framebuffer,
pub feedback_framebuffer: Framebuffer, pub feedback_framebuffer: Framebuffer,
} }
impl FilterPass { impl FilterPass {
@ -29,26 +30,58 @@ impl FilterPass {
buffer.copy_from_slice(mvp); buffer.copy_from_slice(mvp);
} }
fn build_vec4(buffer: &mut [u8], width: u32, height: u32) { fn build_vec4(location: Location<GLint>, buffer: &mut [u8], size: Size) {
let vec4 = [width as f32, height as f32, 1.0 / width as f32, 1.0/ height as f32]; let vec4 = [size.width as f32, size.height as f32, 1.0 / size.width as f32, 1.0/ size.height as f32];
let vec4 = bytemuck::cast_slice(&vec4); if location.fragment >= 0 || location.vertex >= 0 {
unsafe {
buffer.copy_from_slice(vec4); if location.vertex >= 0 {
} gl::Uniform4fv(location.vertex, 1, vec4.as_ptr());
}
fn build_vec4_uniform(location: Location<GLint>, width: u32, height: u32) { if location.fragment >= 0 {
let vec4 = [width as f32, height as f32, 1.0 / width as f32, 1.0/ height as f32]; gl::Uniform4fv(location.fragment, 1, vec4.as_ptr());
unsafe { }
if location.vertex >= 0 {
gl::Uniform4fv(location.vertex, 1, vec4.as_ptr());
}
if location.fragment >= 0 {
gl::Uniform4fv(location.fragment, 1, vec4.as_ptr());
} }
} else {
let vec4 = bytemuck::cast_slice(&vec4);
buffer.copy_from_slice(vec4);
} }
} }
fn build_semantics(&mut self, mvp: Option<&[f32]>, fb_size: Size, vp_size: Size, original: &Texture, source: &Texture) { #[inline(always)]
fn build_uniform<T>(location: Location<GLint>, buffer: &mut [u8], value: T, glfn: unsafe fn(GLint, T) -> ())
where T: Copy, T: bytemuck::Pod
{
if location.fragment >= 0 || location.vertex >= 0 {
unsafe {
if location.vertex >= 0 {
glfn(location.vertex, value);
}
if location.fragment >= 0 {
glfn(location.fragment, value);
}
}
} else {
let mut buffer = bytemuck::cast_slice_mut(buffer);
buffer[0] = value;
}
}
fn build_uint(location: Location<GLint>, buffer: &mut [u8], value: u32) {
Self::build_uniform(location, buffer, value, gl::Uniform1ui)
}
fn build_sint(location: Location<GLint>, buffer: &mut [u8], value: i32) {
Self::build_uniform(location, buffer, value, gl::Uniform1i)
}
fn build_float(location: Location<GLint>, buffer: &mut [u8], value: f32) {
Self::build_uniform(location, buffer, value, gl::Uniform1f)
}
// todo: build vec4 texture
// framecount should be pre-modded
fn build_semantics(&mut self, mvp: Option<&[f32]>, frame_count: u32, frame_direction: u32, fb_size: Size, vp_size: Size, original: &Texture, source: &Texture) {
if let Some(variable) = self.reflection.meta.variable_meta.get(&VariableSemantics::MVP) { if let Some(variable) = self.reflection.meta.variable_meta.get(&VariableSemantics::MVP) {
let mvp = mvp.unwrap_or(&[ let mvp = mvp.unwrap_or(&[
2f32, 0.0, 0.0, 0.0, 2f32, 0.0, 0.0, 0.0,
@ -66,16 +99,56 @@ impl FilterPass {
if let Some(variable) = self.reflection.meta.variable_meta.get(&VariableSemantics::Output) { if let Some(variable) = self.reflection.meta.variable_meta.get(&VariableSemantics::Output) {
let location = self.locations.get(&variable.id).expect("variable did not have location mapped").location(); let location = self.locations.get(&variable.id).expect("variable did not have location mapped").location();
if location.fragment >= 0 || location.vertex >= 0 { let (buffer, offset) = match variable.offset {
FilterPass::build_vec4_uniform(location, fb_size.width, fb_size.height); MemberOffset::Ubo(offset) => (&mut self.uniform_buffer, offset),
} else { MemberOffset::PushConstant(offset) => (&mut self.push_buffer, offset)
let (buffer, offset) = match variable.offset { };
MemberOffset::Ubo(offset) => (&mut self.uniform_buffer, offset), FilterPass::build_vec4(location, &mut buffer[offset..][..4], fb_size)
MemberOffset::PushConstant(offset) => (&mut self.push_buffer, offset) //
}; // if location.fragment >= 0 || location.vertex >= 0 {
// FilterPass::build_vec4_uniform(location, fb_size);
FilterPass::build_vec4(&mut buffer[offset..][..4], fb_size.width, fb_size.height) // } else {
} // let (buffer, offset) = match variable.offset {
// MemberOffset::Ubo(offset) => (&mut self.uniform_buffer, offset),
// MemberOffset::PushConstant(offset) => (&mut self.push_buffer, offset)
// };
//
// FilterPass::build_vec4(&mut buffer[offset..][..4], fb_size)
// }
} }
if let Some(variable) = self.reflection.meta.variable_meta.get(&VariableSemantics::FinalViewport) {
// todo: do all variables have location..?
let location = self.locations.get(&variable.id).expect("variable did not have location mapped").location();
let (buffer, offset) = match variable.offset {
MemberOffset::Ubo(offset) => (&mut self.uniform_buffer, offset),
MemberOffset::PushConstant(offset) => (&mut self.push_buffer, offset)
};
FilterPass::build_vec4(location, &mut buffer[offset..][..4], vp_size)
}
if let Some(variable) = self.reflection.meta.variable_meta.get(&VariableSemantics::FrameCount) {
// todo: do all variables have location..?
let location = self.locations.get(&variable.id).expect("variable did not have location mapped").location();
let (buffer, offset) = match variable.offset {
MemberOffset::Ubo(offset) => (&mut self.uniform_buffer, offset),
MemberOffset::PushConstant(offset) => (&mut self.push_buffer, offset)
};
FilterPass::build_uint(location, &mut buffer[offset..][..4], frame_count)
}
if let Some(variable) = self.reflection.meta.variable_meta.get(&VariableSemantics::FrameDirection) {
// todo: do all variables have location..?
let location = self.locations.get(&variable.id).expect("variable did not have location mapped").location();
let (buffer, offset) = match variable.offset {
MemberOffset::Ubo(offset) => (&mut self.uniform_buffer, offset),
MemberOffset::PushConstant(offset) => (&mut self.push_buffer, offset)
};
FilterPass::build_uint(location, &mut buffer[offset..][..4], frame_direction)
}
} }
} }