diff --git a/src/integrators/coro_path.cpp b/src/integrators/coro_path.cpp index 67f100a..d2de904 100644 --- a/src/integrators/coro_path.cpp +++ b/src/integrators/coro_path.cpp @@ -23,13 +23,7 @@ class CoroutinePathTracing final : public ProgressiveIntegrator { Wavefront, Persistent, }; - -#define PT_CORO_SIGNATURE float, float, uint - using SchedulerBase = coroutine::CoroScheduler; - using SimpleScheduler = coroutine::StateMachineCoroScheduler; - using WavefrontScheduler = coroutine::WavefrontCoroScheduler; - using PersistentScheduler = coroutine::PersistentThreadsCoroScheduler; -#undef PT_CORO_SIGNATURE + using SchedulerBase = coroutine::CoroScheduler; private: uint _max_depth; @@ -37,8 +31,8 @@ class CoroutinePathTracing final : public ProgressiveIntegrator { float _rr_threshold; uint _samples_per_pass; Scheduler _scheduler; - WavefrontScheduler::Config _wavefront_config; - PersistentScheduler::Config _persistent_config; + coroutine::WavefrontCoroSchedulerConfig _wavefront_config; + coroutine::PersistentThreadsCoroSchedulerConfig _persistent_config; public: CoroutinePathTracing(Scene *scene, const SceneNodeDesc *desc) noexcept @@ -137,7 +131,8 @@ class CoroutinePathTracingInstance final : public ProgressiveIntegrator::Instanc auto &stream = *command_buffer.stream(); switch (coro_pt->scheduler()) { case CoroutinePathTracing::Scheduler::Simple: { - return luisa::make_unique(device, render); + coroutine::StateMachineCoroScheduler s{device, render}; + return luisa::make_unique(std::move(s)); } case CoroutinePathTracing::Scheduler::Wavefront: { auto config = coro_pt->wavefront_config(); @@ -156,7 +151,8 @@ class CoroutinePathTracingInstance final : public ProgressiveIntegrator::Instanc config.thread_count, config.hint_range, !config.hint_fields.empty() ? config.hint_fields[0] : "NULL"); - return luisa::make_unique(device, render, config); + coroutine::WavefrontCoroScheduler s{device, render, config}; + return luisa::make_unique(std::move(s)); } case CoroutinePathTracing::Scheduler::Persistent: { auto config = coro_pt->persistent_config(); @@ -165,7 +161,8 @@ class CoroutinePathTracingInstance final : public ProgressiveIntegrator::Instanc config.block_size, config.fetch_size, config.global_memory_ext); - return luisa::make_unique(device, render, config); + coroutine::PersistentThreadsCoroScheduler s{device, render, config}; + return luisa::make_unique(std::move(s)); } default: break;