mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-08-17 09:21:45 +00:00
But keep a namespace alias to avoid breaking project that depend on the previous namespace name while they get updated. Done with through the following steps: - git grep -l dawn_native:: | xargs sed -i "" "s/dawn_native::/dawn::native::/g" - git grep -l "namespace dawn_native" | xargs sed -i "" "s/namespace dawn_native/namespace dawn::native/g" - git cl format - Manual fixups in generator/templates (and the addition of namespace_case in dawn_json_generator.py). - The addition of the namespace alias in DawnNative.h Bug: dawn:824 Change-Id: I676cc4e3ced2e0e4bab32a0d66d7eaf9537e3f09 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/75982 Reviewed-by: Loko Kung <lokokung@google.com> Commit-Queue: Corentin Wallez <cwallez@chromium.org> Auto-Submit: Corentin Wallez <cwallez@chromium.org>
66 lines
2.2 KiB
C++
66 lines
2.2 KiB
C++
// Copyright 2021 The Dawn Authors
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
#ifndef DAWNNATIVE_ASYC_TASK_H_
|
|
#define DAWNNATIVE_ASYC_TASK_H_
|
|
|
|
#include <functional>
|
|
#include <memory>
|
|
#include <mutex>
|
|
#include <unordered_map>
|
|
|
|
#include "common/RefCounted.h"
|
|
|
|
namespace dawn::platform {
|
|
class WaitableEvent;
|
|
class WorkerTaskPool;
|
|
} // namespace dawn::platform
|
|
|
|
namespace dawn::native {
|
|
|
|
// TODO(crbug.com/dawn/826): we'll add additional things to AsyncTask in the future, like
|
|
// Cancel() and RunNow(). Cancelling helps avoid running the task's body when we are just
|
|
// shutting down the device. RunNow() could be used for more advanced scenarios, for example
|
|
// always doing ShaderModule initial compilation asynchronously, but being able to steal the
|
|
// task if we need it for synchronous pipeline compilation.
|
|
using AsyncTask = std::function<void()>;
|
|
|
|
class AsyncTaskManager {
|
|
public:
|
|
explicit AsyncTaskManager(dawn::platform::WorkerTaskPool* workerTaskPool);
|
|
|
|
void PostTask(AsyncTask asyncTask);
|
|
void WaitAllPendingTasks();
|
|
bool HasPendingTasks();
|
|
|
|
private:
|
|
class WaitableTask : public RefCounted {
|
|
public:
|
|
AsyncTask asyncTask;
|
|
AsyncTaskManager* taskManager;
|
|
std::unique_ptr<dawn::platform::WaitableEvent> waitableEvent;
|
|
};
|
|
|
|
static void DoWaitableTask(void* task);
|
|
void HandleTaskCompletion(WaitableTask* task);
|
|
|
|
std::mutex mPendingTasksMutex;
|
|
std::unordered_map<WaitableTask*, Ref<WaitableTask>> mPendingTasks;
|
|
dawn::platform::WorkerTaskPool* mWorkerTaskPool;
|
|
};
|
|
|
|
} // namespace dawn::native
|
|
|
|
#endif
|