Delay the process_wrapper() use
The other parts also don't allocate, but parking_lot doesn't play nicely when spawning an editor thread. In that case its hashmap may get resized on the audio thread which is not what we want, but it won't cause any real problems.
This commit is contained in:
parent
5c9ac31408
commit
29a9c41389
1 changed files with 142 additions and 148 deletions
|
@ -1124,9 +1124,6 @@ impl<P: Plugin> IAudioProcessor for Wrapper<P> {
|
||||||
unsafe fn process(&self, data: *mut vst3_sys::vst::ProcessData) -> tresult {
|
unsafe fn process(&self, data: *mut vst3_sys::vst::ProcessData) -> tresult {
|
||||||
check_null_ptr!(data);
|
check_null_ptr!(data);
|
||||||
|
|
||||||
// Panic on allocations if the `assert_process_allocs` feature has been enabled, and make
|
|
||||||
// sure that FTZ is set up correctly
|
|
||||||
process_wrapper(|| {
|
|
||||||
// We need to handle incoming automation first
|
// We need to handle incoming automation first
|
||||||
let data = &*data;
|
let data = &*data;
|
||||||
let sample_rate = self
|
let sample_rate = self
|
||||||
|
@ -1233,9 +1230,7 @@ impl<P: Plugin> IAudioProcessor for Wrapper<P> {
|
||||||
{
|
{
|
||||||
let output_slices = output_buffer.as_raw_vec();
|
let output_slices = output_buffer.as_raw_vec();
|
||||||
nih_debug_assert_eq!(num_output_channels, output_slices.len());
|
nih_debug_assert_eq!(num_output_channels, output_slices.len());
|
||||||
for (output_channel_idx, output_channel_slice) in
|
for (output_channel_idx, output_channel_slice) in output_slices.iter_mut().enumerate() {
|
||||||
output_slices.iter_mut().enumerate()
|
|
||||||
{
|
|
||||||
// SAFETY: These pointers may not be valid outside of this function even though
|
// SAFETY: These pointers may not be valid outside of this function even though
|
||||||
// their lifetime is equal to this structs. This is still safe because they are
|
// their lifetime is equal to this structs. This is still safe because they are
|
||||||
// only dereferenced here later as part of this process function.
|
// only dereferenced here later as part of this process function.
|
||||||
|
@ -1247,8 +1242,8 @@ impl<P: Plugin> IAudioProcessor for Wrapper<P> {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Most hosts process data in place, in which case we don't need to do any copying
|
// Most hosts process data in place, in which case we don't need to do any copying
|
||||||
// ourselves. If the pointers do not alias, then we'll do the copy here and then the
|
// ourselves. If the pointers do not alias, then we'll do the copy here and then the plugin
|
||||||
// plugin can just do normal in place processing.
|
// can just do normal in place processing.
|
||||||
if !data.inputs.is_null() {
|
if !data.inputs.is_null() {
|
||||||
let num_input_channels = (*data.inputs).num_channels as usize;
|
let num_input_channels = (*data.inputs).num_channels as usize;
|
||||||
nih_debug_assert!(
|
nih_debug_assert!(
|
||||||
|
@ -1270,21 +1265,20 @@ impl<P: Plugin> IAudioProcessor for Wrapper<P> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
match self
|
let mut plugin = self.inner.plugin.write();
|
||||||
.inner
|
let mut context = self.inner.make_process_context();
|
||||||
.plugin
|
// Panic on allocations if the `assert_process_allocs` feature has been enabled, and make
|
||||||
.write()
|
// sure that FTZ is set up correctly
|
||||||
// SAFETY: Same here
|
process_wrapper(
|
||||||
.process(&mut output_buffer, &mut self.inner.make_process_context())
|
move || match plugin.process(&mut output_buffer, &mut context) {
|
||||||
{
|
|
||||||
ProcessStatus::Error(err) => {
|
ProcessStatus::Error(err) => {
|
||||||
nih_debug_assert_failure!("Process error: {}", err);
|
nih_debug_assert_failure!("Process error: {}", err);
|
||||||
|
|
||||||
kResultFalse
|
kResultFalse
|
||||||
}
|
}
|
||||||
_ => kResultOk,
|
_ => kResultOk,
|
||||||
}
|
},
|
||||||
})
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
unsafe fn get_tail_samples(&self) -> u32 {
|
unsafe fn get_tail_samples(&self) -> u32 {
|
||||||
|
|
Loading…
Add table
Reference in a new issue