no message
This commit is contained in:
147
cocos/base/job-system/job-system-dummy/DummyJobGraph.cpp
Normal file
147
cocos/base/job-system/job-system-dummy/DummyJobGraph.cpp
Normal file
@@ -0,0 +1,147 @@
|
||||
/****************************************************************************
|
||||
Copyright (c) 2020-2023 Xiamen Yaji Software Co., Ltd.
|
||||
|
||||
http://www.cocos.com
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights to
|
||||
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
|
||||
of the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
||||
****************************************************************************/
|
||||
|
||||
#include "DummyJobGraph.h"
|
||||
#include "base/Macros.h"
|
||||
|
||||
#define DUMMY_GRAPH_NODE_CHUNK_SIZE 64
|
||||
|
||||
namespace cc {
|
||||
|
||||
namespace {
|
||||
DummyGraphNode *freeList{nullptr};
|
||||
ccstd::vector<DummyGraphNode *> allocatedChunks;
|
||||
} // namespace
|
||||
|
||||
DummyGraphNode::~DummyGraphNode() {
|
||||
delete _callback;
|
||||
}
|
||||
|
||||
void DummyGraphNode::reset() {
|
||||
_successors.clear();
|
||||
_predecessors.clear();
|
||||
delete _callback;
|
||||
_callback = nullptr;
|
||||
}
|
||||
|
||||
void DummyGraphNode::succeed(DummyGraphNode *other) {
|
||||
CC_ASSERT_NE(this, other);
|
||||
// Run after other
|
||||
this->_predecessors.emplace(other);
|
||||
other->_successors.emplace(this);
|
||||
}
|
||||
|
||||
void DummyGraphNode::precede(DummyGraphNode *other) {
|
||||
// Run before other
|
||||
other->succeed(this);
|
||||
}
|
||||
|
||||
void DummyGraphNode::allocChunk() {
|
||||
CC_ASSERT_NULL(freeList);
|
||||
freeList = ccnew DummyGraphNode[DUMMY_GRAPH_NODE_CHUNK_SIZE]();
|
||||
allocatedChunks.emplace_back(freeList);
|
||||
for (auto i = 0; i < DUMMY_GRAPH_NODE_CHUNK_SIZE - 1; i++) {
|
||||
freeList[i]._next = &freeList[i + 1];
|
||||
}
|
||||
freeList[DUMMY_GRAPH_NODE_CHUNK_SIZE - 1]._next = nullptr;
|
||||
}
|
||||
|
||||
DummyGraphNode *DummyGraphNode::alloc() {
|
||||
if (freeList == nullptr) {
|
||||
DummyGraphNode::allocChunk();
|
||||
}
|
||||
auto *p = freeList;
|
||||
freeList = freeList->_next;
|
||||
p->reset();
|
||||
return p;
|
||||
}
|
||||
|
||||
void DummyGraphNode::free(DummyGraphNode *node) {
|
||||
node->_next = freeList;
|
||||
freeList = node;
|
||||
}
|
||||
|
||||
void DummyGraphNode::freeAll() {
|
||||
for (auto *chunk : allocatedChunks) {
|
||||
delete[] chunk;
|
||||
}
|
||||
allocatedChunks.clear();
|
||||
}
|
||||
|
||||
DummyGraph::~DummyGraph() {
|
||||
clear();
|
||||
}
|
||||
|
||||
void DummyGraph::clear() {
|
||||
for (auto *node : _nodes) {
|
||||
DummyGraphNode::free(node);
|
||||
}
|
||||
_nodes.clear();
|
||||
}
|
||||
|
||||
void DummyGraph::link(size_t precede, size_t after) {
|
||||
_nodes[precede]->precede(_nodes[after]);
|
||||
}
|
||||
|
||||
void DummyGraph::run() {
|
||||
for (auto *node : _nodes) {
|
||||
if (!excuted(node)) {
|
||||
walk(node);
|
||||
}
|
||||
}
|
||||
_generation++;
|
||||
}
|
||||
|
||||
void DummyGraph::walk(DummyGraphNode *node) { //NOLINT(misc-no-recursion)
|
||||
for (DummyGraphNode *n : node->_predecessors) {
|
||||
if (!excuted(n)) {
|
||||
walk(n);
|
||||
}
|
||||
}
|
||||
if (!excuted(node)) {
|
||||
node->_callback->execute();
|
||||
node->_generation++;
|
||||
}
|
||||
|
||||
for (DummyGraphNode *n : node->_successors) {
|
||||
if (!excuted(n)) {
|
||||
walk(n);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
bool DummyGraph::excuted(DummyGraphNode *n) const {
|
||||
return n->_generation != _generation;
|
||||
}
|
||||
|
||||
void DummyJobGraph::makeEdge(uint32_t j1, uint32_t j2) {
|
||||
_dummyGraph.link(j1, j2);
|
||||
}
|
||||
|
||||
void DummyJobGraph::run() noexcept {
|
||||
_dummyGraph.run();
|
||||
_dummyGraph.clear();
|
||||
}
|
||||
|
||||
} // namespace cc
|
||||
162
cocos/base/job-system/job-system-dummy/DummyJobGraph.h
Normal file
162
cocos/base/job-system/job-system-dummy/DummyJobGraph.h
Normal file
@@ -0,0 +1,162 @@
|
||||
/****************************************************************************
|
||||
Copyright (c) 2020-2023 Xiamen Yaji Software Co., Ltd.
|
||||
|
||||
http://www.cocos.com
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights to
|
||||
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
|
||||
of the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
||||
****************************************************************************/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "base/Macros.h"
|
||||
#include "base/memory/Memory.h"
|
||||
#include "base/std/container/unordered_set.h"
|
||||
#include "base/std/container/vector.h"
|
||||
|
||||
namespace cc {
|
||||
|
||||
class DummyJobSystem;
|
||||
|
||||
class DummyGraphNode;
|
||||
class DummyGraph final {
|
||||
public:
|
||||
DummyGraph() = default;
|
||||
DummyGraph(const DummyGraph &) = delete;
|
||||
DummyGraph(DummyGraph &&) = delete;
|
||||
DummyGraph &operator=(const DummyGraph &) = delete;
|
||||
DummyGraph &operator=(DummyGraph &&) = delete;
|
||||
~DummyGraph();
|
||||
|
||||
template <class Fn>
|
||||
size_t addNode(Fn &&fn);
|
||||
|
||||
void run();
|
||||
void link(size_t precede, size_t after);
|
||||
void walk(DummyGraphNode *node);
|
||||
void clear();
|
||||
|
||||
private:
|
||||
bool excuted(DummyGraphNode *n) const;
|
||||
|
||||
int _generation{0};
|
||||
ccstd::vector<DummyGraphNode *> _nodes;
|
||||
};
|
||||
|
||||
class DummyGraphNodeTaskItf {
|
||||
public:
|
||||
virtual ~DummyGraphNodeTaskItf() = default;
|
||||
virtual void execute() = 0;
|
||||
};
|
||||
|
||||
template <class Fn>
|
||||
class DummyGraphNodeTaskImpl final : public DummyGraphNodeTaskItf {
|
||||
public:
|
||||
explicit DummyGraphNodeTaskImpl(Fn &&t) noexcept;
|
||||
DummyGraphNodeTaskImpl(const DummyGraphNodeTaskImpl &) = delete;
|
||||
DummyGraphNodeTaskImpl(DummyGraphNodeTaskImpl &&) = delete;
|
||||
DummyGraphNodeTaskImpl &operator=(const DummyGraphNodeTaskImpl &) = delete;
|
||||
DummyGraphNodeTaskImpl &operator=(DummyGraphNodeTaskImpl &&) = delete;
|
||||
~DummyGraphNodeTaskImpl() override = default;
|
||||
inline void execute() override { _task(); }
|
||||
|
||||
private:
|
||||
Fn _task;
|
||||
};
|
||||
|
||||
class DummyGraphNode final {
|
||||
public:
|
||||
DummyGraphNode() = default;
|
||||
DummyGraphNode(const DummyGraphNode &) = delete;
|
||||
DummyGraphNode(DummyGraphNode &&) = delete;
|
||||
DummyGraphNode &operator=(const DummyGraphNode &) = delete;
|
||||
DummyGraphNode &operator=(DummyGraphNode &&) = delete;
|
||||
~DummyGraphNode();
|
||||
|
||||
private:
|
||||
static void allocChunk();
|
||||
static DummyGraphNode *alloc();
|
||||
static void free(DummyGraphNode *n);
|
||||
static void freeAll();
|
||||
|
||||
void succeed(DummyGraphNode *other);
|
||||
void precede(DummyGraphNode *other);
|
||||
void reset();
|
||||
|
||||
DummyGraphNodeTaskItf *_callback{nullptr};
|
||||
ccstd::unordered_set<DummyGraphNode *> _successors{};
|
||||
ccstd::unordered_set<DummyGraphNode *> _predecessors{};
|
||||
DummyGraphNode *_next{nullptr};
|
||||
int _generation{0};
|
||||
friend class DummyGraph;
|
||||
};
|
||||
|
||||
template <class Fn>
|
||||
DummyGraphNodeTaskImpl<Fn>::DummyGraphNodeTaskImpl(Fn &&t) noexcept : _task(t) {}
|
||||
|
||||
template <class Fn>
|
||||
size_t DummyGraph::addNode(Fn &&fn) {
|
||||
DummyGraphNode *n = DummyGraphNode::alloc();
|
||||
n->_callback = ccnew DummyGraphNodeTaskImpl<Fn>(std::forward<Fn>(fn));
|
||||
n->_generation = _generation;
|
||||
_nodes.emplace_back(n);
|
||||
return _nodes.size() - 1;
|
||||
}
|
||||
|
||||
// exported declarations
|
||||
|
||||
class DummyJobGraph final {
|
||||
public:
|
||||
explicit DummyJobGraph(DummyJobSystem * /*system*/) noexcept {}
|
||||
DummyJobGraph(const DummyJobGraph &) = delete;
|
||||
DummyJobGraph(DummyJobGraph &&) = delete;
|
||||
DummyJobGraph &operator=(const DummyJobGraph &) = delete;
|
||||
DummyJobGraph &operator=(DummyJobGraph &&) = delete;
|
||||
~DummyJobGraph() noexcept = default;
|
||||
|
||||
template <typename Function>
|
||||
uint32_t createJob(Function &&func) noexcept;
|
||||
|
||||
template <typename Function>
|
||||
uint32_t createForEachIndexJob(uint32_t begin, uint32_t end, uint32_t step, Function &&func) noexcept;
|
||||
|
||||
void makeEdge(uint32_t j1, uint32_t j2);
|
||||
|
||||
void run() noexcept;
|
||||
|
||||
inline void waitForAll() { run(); }
|
||||
|
||||
private:
|
||||
DummyGraph _dummyGraph{};
|
||||
};
|
||||
|
||||
template <typename Function>
|
||||
uint32_t DummyJobGraph::createJob(Function &&func) noexcept {
|
||||
return static_cast<uint32_t>(_dummyGraph.addNode(std::forward<Function>(func)));
|
||||
}
|
||||
|
||||
template <typename Function>
|
||||
uint32_t DummyJobGraph::createForEachIndexJob(uint32_t begin, uint32_t end, uint32_t step, Function &&func) noexcept {
|
||||
return static_cast<uint32_t>(_dummyGraph.addNode([callable = std::forward<Function>(func), first = begin, last = end, step = step]() {
|
||||
for (auto i = first; i < last; i += step) {
|
||||
callable(i);
|
||||
}
|
||||
}));
|
||||
}
|
||||
|
||||
} // namespace cc
|
||||
32
cocos/base/job-system/job-system-dummy/DummyJobSystem.cpp
Normal file
32
cocos/base/job-system/job-system-dummy/DummyJobSystem.cpp
Normal file
@@ -0,0 +1,32 @@
|
||||
/****************************************************************************
|
||||
Copyright (c) 2020-2023 Xiamen Yaji Software Co., Ltd.
|
||||
|
||||
http://www.cocos.com
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights to
|
||||
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
|
||||
of the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
||||
****************************************************************************/
|
||||
|
||||
#include "DummyJobSystem.h"
|
||||
#include "DummyJobGraph.h"
|
||||
|
||||
namespace cc {
|
||||
|
||||
DummyJobSystem *DummyJobSystem::instance = nullptr;
|
||||
|
||||
} // namespace cc
|
||||
62
cocos/base/job-system/job-system-dummy/DummyJobSystem.h
Normal file
62
cocos/base/job-system/job-system-dummy/DummyJobSystem.h
Normal file
@@ -0,0 +1,62 @@
|
||||
/****************************************************************************
|
||||
Copyright (c) 2020-2023 Xiamen Yaji Software Co., Ltd.
|
||||
|
||||
http://www.cocos.com
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights to
|
||||
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
|
||||
of the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
||||
****************************************************************************/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "base/Macros.h"
|
||||
#include "base/memory/Memory.h"
|
||||
|
||||
namespace cc {
|
||||
|
||||
using DummyJobToken = size_t;
|
||||
|
||||
class DummyJobGraph;
|
||||
|
||||
class DummyJobSystem final {
|
||||
private:
|
||||
static DummyJobSystem *instance;
|
||||
|
||||
public:
|
||||
static DummyJobSystem *getInstance() {
|
||||
if (!instance) {
|
||||
instance = ccnew DummyJobSystem;
|
||||
}
|
||||
return instance;
|
||||
}
|
||||
|
||||
static void destroyInstance() {
|
||||
delete instance;
|
||||
instance = nullptr;
|
||||
}
|
||||
|
||||
DummyJobSystem() noexcept = default;
|
||||
explicit DummyJobSystem(uint32_t /*threadCount*/) noexcept {}
|
||||
|
||||
inline uint32_t threadCount() const { return THREAD_COUNT; } //NOLINT
|
||||
|
||||
private:
|
||||
static constexpr uint32_t THREAD_COUNT = 1U; //always one
|
||||
};
|
||||
|
||||
} // namespace cc
|
||||
Reference in New Issue
Block a user