blob: a7de6d6087f9453c997d57c44f9382c66b4df7d5 [file] [log] [blame]
// Copyright 2016 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "modules/webaudio/AudioWorkletMessagingProxy.h"
#include "modules/webaudio/AudioWorkletGlobalScope.h"
#include "modules/webaudio/AudioWorkletNode.h"
#include "modules/webaudio/AudioWorkletObjectProxy.h"
#include "modules/webaudio/AudioWorkletProcessor.h"
#include "modules/webaudio/AudioWorkletThread.h"
#include "modules/webaudio/CrossThreadAudioWorkletProcessorInfo.h"
#include "public/platform/TaskType.h"
namespace blink {
AudioWorkletMessagingProxy::AudioWorkletMessagingProxy(
ExecutionContext* execution_context,
WorkerClients* worker_clients)
: ThreadedWorkletMessagingProxy(execution_context, worker_clients) {}
AudioWorkletMessagingProxy::~AudioWorkletMessagingProxy() {}
void AudioWorkletMessagingProxy::CreateProcessor(
AudioWorkletHandler* handler) {
DCHECK(IsMainThread());
GetWorkerThread()
->GetTaskRunner(TaskType::kMiscPlatformAPI)
->PostTask(
BLINK_FROM_HERE,
CrossThreadBind(
&AudioWorkletMessagingProxy::CreateProcessorOnRenderingThread,
WrapCrossThreadPersistent(this),
CrossThreadUnretained(GetWorkerThread()),
CrossThreadUnretained(handler), handler->Name(),
handler->Context()->sampleRate()));
}
void AudioWorkletMessagingProxy::CreateProcessorOnRenderingThread(
WorkerThread* worker_thread,
AudioWorkletHandler* handler,
const String& name,
float sample_rate) {
DCHECK(worker_thread->IsCurrentThread());
AudioWorkletGlobalScope* global_scope =
ToAudioWorkletGlobalScope(worker_thread->GlobalScope());
AudioWorkletProcessor* processor =
global_scope->CreateInstance(name, sample_rate);
handler->SetProcessorOnRenderThread(processor);
}
void AudioWorkletMessagingProxy::SynchronizeWorkletProcessorInfoList(
std::unique_ptr<Vector<CrossThreadAudioWorkletProcessorInfo>> info_list) {
DCHECK(IsMainThread());
for (auto& processor_info : *info_list) {
processor_info_map_.insert(processor_info.Name(),
processor_info.ParamInfoList());
}
}
bool AudioWorkletMessagingProxy::IsProcessorRegistered(
const String& name) const {
return processor_info_map_.Contains(name);
}
const Vector<CrossThreadAudioParamInfo>
AudioWorkletMessagingProxy::GetParamInfoListForProcessor(
const String& name) const {
DCHECK(IsProcessorRegistered(name));
return processor_info_map_.at(name);
}
WebThread* AudioWorkletMessagingProxy::GetWorkletBackingThread() {
auto worklet_thread = static_cast<AudioWorkletThread*>(GetWorkerThread());
return worklet_thread->GetSharedBackingThread();
}
std::unique_ptr<ThreadedWorkletObjectProxy>
AudioWorkletMessagingProxy::CreateObjectProxy(
ThreadedWorkletMessagingProxy* messaging_proxy,
ParentFrameTaskRunners* parent_frame_task_runners) {
return WTF::MakeUnique<AudioWorkletObjectProxy>(
static_cast<AudioWorkletMessagingProxy*>(messaging_proxy),
parent_frame_task_runners);
}
std::unique_ptr<WorkerThread> AudioWorkletMessagingProxy::CreateWorkerThread() {
return AudioWorkletThread::Create(CreateThreadableLoadingContext(),
WorkletObjectProxy());
}
} // namespace blink