Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[memory] Fix all deadlocks, implement monitors #316

Merged
merged 42 commits into from
Nov 28, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
42 commits
Select commit Hold shift + click to select a range
0350383
[memory] Remove section locks
NikitaZotov Aug 18, 2023
6e89213
[memory] Remove check levels from iterators
NikitaZotov Aug 20, 2023
de40b3c
[memory][segment] Remake segments caching and creating
NikitaZotov Sep 10, 2023
bb5b7de
[memory] Remake processes sync flow
NikitaZotov Sep 15, 2023
196e79a
[memory] Implement monitors for reading and writing
NikitaZotov Sep 17, 2023
6a28551
[memory] Setup monitors in storages
NikitaZotov Sep 17, 2023
5e49828
[memory][tests] Fix tests
NikitaZotov Sep 17, 2023
f5f4ce6
[memory][fs-storage] Implements monitors
NikitaZotov Sep 17, 2023
a52de99
[memory][fs-memory] Fix base64 encode
NikitaZotov Sep 17, 2023
6e2bcd4
[memory][events] Inject monitors instead muteses
NikitaZotov Sep 18, 2023
1f39cbb
[memory] Reuse freed segment elements
NikitaZotov Sep 22, 2023
c82bddc
[memory] Implements monitors for addrs group
NikitaZotov Sep 23, 2023
9abf97e
[memory][monitor] Fix processes starvations
NikitaZotov Sep 28, 2023
a2383d3
[memory] Redefine glib structures
NikitaZotov Sep 28, 2023
da25ccb
[memory] Add monitors for dump and save memory
NikitaZotov Sep 29, 2023
c71dbbd
[memory][monitor][docs] Write API docs
NikitaZotov Sep 29, 2023
3949ae4
[memory] Optimized released elements usage
NikitaZotov Oct 15, 2023
93ca183
[memory][fs-memory] Sync save, load and dump statistics
NikitaZotov Oct 15, 2023
6a4b7e1
[memory] Process to segment handling
NikitaZotov Oct 15, 2023
e57f39f
[memory] Save and load released segments and elements
NikitaZotov Oct 15, 2023
b6da6f9
[memory][fs-memory] Fix sync in sc-dictionary
NikitaZotov Oct 15, 2023
2d63dbb
[memory] Optimize segment parallel handling
NikitaZotov Oct 16, 2023
ec02c36
[memory] Process management
NikitaZotov Oct 18, 2023
ee18815
[memory][tests] Update benchmark tests
NikitaZotov Oct 21, 2023
38d3e46
[memory][refactor] Restruct logs
NikitaZotov Oct 21, 2023
3cc46dd
[memory][tests] Update benchmark tests for sc-links
NikitaZotov Oct 22, 2023
779e4b8
[memory][fs-memory] Update fs-memory processes sync
NikitaZotov Oct 22, 2023
4ad6787
[memory][fs-memory] Optimize links appending
NikitaZotov Oct 22, 2023
0651ab9
[memory][tests] Update benchmark tests for links
NikitaZotov Oct 22, 2023
9e29482
[memory][tests] Fix parallel remove elements
NikitaZotov Oct 22, 2023
ccc8c40
[memory] Fix double edge iterations
NikitaZotov Oct 24, 2023
0a823df
[memory][event][context] Fix events and contexts deletion
NikitaZotov Oct 26, 2023
0305b07
[memory][events][contexts] Reorder memory, events and contexts shutdo…
NikitaZotov Nov 4, 2023
8c1a3a0
[memory] Add checking if reuse empty elements
NikitaZotov Nov 4, 2023
dd7de75
[memory][events][refactor] Divide events logic into managers
NikitaZotov Nov 9, 2023
0b12eb4
[memory][context] Refactor memory contexts, implement context manager
NikitaZotov Nov 10, 2023
fb6a519
[memory] Restruct processes distribution logic
NikitaZotov Nov 24, 2023
24d846e
[memory][fs-memory] Optimize imports, secure interfaces
NikitaZotov Nov 26, 2023
51d37dd
[docs] Apply changes
NikitaZotov Nov 26, 2023
b49a307
[memory][fs-memory][tests] Add tests for invalid params
NikitaZotov Nov 26, 2023
628b19a
[sc-memory][tests] Upgrade iterator3 tests
NikitaZotov Nov 27, 2023
a38c389
[docs] Apply changes
NikitaZotov Nov 28, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
[memory][tests] Update benchmark tests
  • Loading branch information
NikitaZotov committed Nov 28, 2023
commit ee188154d7fe6d9a2b6ed27e73cca65479d75f3e
4 changes: 2 additions & 2 deletions sc-memory/sc-core/sc-store/sc_storage.c
Original file line number Diff line number Diff line change
Expand Up @@ -523,9 +523,9 @@ sc_result sc_storage_element_free(sc_memory_context const * ctx, sc_addr addr)

--e_el->input_arcs_count;

sc_event_emit(ctx, el->arc.end, e_el->flags.access_levels, SC_EVENT_REMOVE_INPUT_ARC, addr, el->arc.begin);

sc_monitor_release_write_n(3, monitor, beg_monitor, end_monitor);

sc_event_emit(ctx, el->arc.end, e_el->flags.access_levels, SC_EVENT_REMOVE_INPUT_ARC, addr, el->arc.begin);
}

sc_event_emit(ctx, addr, el->flags.access_levels, SC_EVENT_REMOVE_ELEMENT, SC_ADDR_EMPTY, SC_ADDR_EMPTY);
Expand Down
281 changes: 274 additions & 7 deletions sc-memory/tests/performance/main.cpp
Original file line number Diff line number Diff line change
@@ -1,14 +1,18 @@
/*
* This source file is part of an OSTIS project. For the latest info, see http://ostis.net
* This source file is part of an OSTIS project. For the latest info, see http:ostis.net
* Distributed under the MIT License
* (See accompanying file COPYING.MIT or copy at http://opensource.org/licenses/MIT)
* (See accompanying file COPYING.MIT or copy at http:opensource.org/licenses/MIT)
*/

#include "benchmark/benchmark.h"

#include "units/memory_create_edge.hpp"
#include "units/memory_create_node.hpp"
#include "units/memory_create_link.hpp"
#include "units/memory_iterator_search.hpp"
#include "units/memory_remove_diff_elements.hpp"
#include "units/memory_remove_set_elements.hpp"

#include "units/memory_remove_elements.hpp"

#include "units/sc_code_base_vs_extend.hpp"
Expand All @@ -22,7 +26,7 @@
template <class BMType>
void BM_MemoryThreaded(benchmark::State & state)
{
static std::atomic_int ctxNum = { 0 };
static std::atomic_int ctxNum = {0};
BMType test;
if (state.thread_index() == 0)
test.Initialize();
Expand Down Expand Up @@ -58,7 +62,8 @@ void BM_MemoryThreaded(benchmark::State & state)
{
test.DestroyContext();
ctxNum.fetch_add(-1);
}}
}
}

int constexpr kNodeIters = 1000000;

Expand Down Expand Up @@ -97,6 +102,182 @@ BENCHMARK_TEMPLATE(BM_MemoryThreaded, TestCreateNode)
->Iterations(kNodeIters / 32)
->Unit(benchmark::TimeUnit::kMicrosecond);

template <class BMType>
void BM_MemoryThreaded2(benchmark::State & state)
{
static std::atomic_int ctxNum = {0};
BMType test;
if (state.thread_index() == 0)
test.Initialize(state.range(0));

auto start = std::chrono::high_resolution_clock::now();
uint32_t iterations = 0;
for (auto t : state)
{
state.PauseTiming();
if (!test.HasContext())
{
test.InitContext();
ctxNum.fetch_add(1);
}
state.ResumeTiming();

test.Run();
++iterations;
}
auto end = std::chrono::high_resolution_clock::now();
std::chrono::duration<double, std::milli> elapsed = end - start;
std::stringstream stream;
stream << state.max_iterations << " " << elapsed.count() << std::endl;
std::cout << stream.str();

state.counters["rate"] = benchmark::Counter(iterations, benchmark::Counter::kIsRate);
if (state.thread_index() == 0)
{
while (ctxNum.load() != 0);
test.Shutdown();
}
else
{
test.DestroyContext();
ctxNum.fetch_add(-1);
}
}

int constexpr kEdgeIters = 1000000;

int constexpr kEdgeNodesIters1 = 100;

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(1)
->Iterations(kEdgeIters)
->Arg(kEdgeNodesIters1)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(2)
->Iterations(kEdgeIters / 2)
->Arg(kEdgeNodesIters1)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(3)
->Iterations(kEdgeIters / 3)
->Arg(kEdgeNodesIters1)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(4)
->Iterations(kNodeIters / 4)
->Arg(kEdgeNodesIters1)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(8)
->Iterations(kEdgeIters / 8)
->Arg(kEdgeNodesIters1)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(16)
->Iterations(kEdgeIters / 16)
->Arg(kEdgeNodesIters1)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(32)
->Iterations(kEdgeIters / 32)
->Arg(kEdgeNodesIters1)
->Unit(benchmark::TimeUnit::kMicrosecond);

int constexpr kEdgeNodesIters2 = 10000;

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(1)
->Iterations(kEdgeIters)
->Arg(kEdgeNodesIters2)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(2)
->Iterations(kEdgeIters / 2)
->Arg(kEdgeNodesIters2)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(3)
->Iterations(kEdgeIters / 3)
->Arg(kEdgeNodesIters2)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(4)
->Iterations(kNodeIters / 4)
->Arg(kEdgeNodesIters2)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(8)
->Iterations(kEdgeIters / 8)
->Arg(kEdgeNodesIters2)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(16)
->Iterations(kEdgeIters / 16)
->Arg(kEdgeNodesIters2)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(32)
->Iterations(kEdgeIters / 32)
->Arg(kEdgeNodesIters2)
->Unit(benchmark::TimeUnit::kMicrosecond);

int constexpr kEdgeNodesIters3 = 1000000;

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(1)
->Iterations(kEdgeIters)
->Arg(kEdgeNodesIters3)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(2)
->Iterations(kEdgeIters / 2)
->Arg(kEdgeNodesIters3)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(3)
->Iterations(kEdgeIters / 3)
->Arg(kEdgeNodesIters3)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(4)
->Iterations(kNodeIters / 4)
->Arg(kEdgeNodesIters3)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(8)
->Iterations(kEdgeIters / 8)
->Arg(kEdgeNodesIters3)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(16)
->Iterations(kEdgeIters / 16)
->Arg(kEdgeNodesIters3)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestCreateEdge)
->Threads(32)
->Iterations(kEdgeIters / 32)
->Arg(kEdgeNodesIters3)
->Unit(benchmark::TimeUnit::kMicrosecond);

int constexpr kLinkIters = 7000;

BENCHMARK_TEMPLATE(BM_MemoryThreaded, TestCreateLink)
Expand Down Expand Up @@ -149,6 +330,92 @@ BENCHMARK_TEMPLATE(BM_MemoryThreaded, TestCreateSameLink)
->Iterations(kLinkIters / 128)
->Unit(benchmark::TimeUnit::kMicrosecond);

int constexpr kSetPower = 100;

BENCHMARK_TEMPLATE(BM_MemoryThreaded, TestIteratorSearch)
->Threads(1)
->Iterations(kSetPower * 8 / 1)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded, TestIteratorSearch)
->Threads(2)
->Iterations(kSetPower * 8 / 2)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded, TestIteratorSearch)
->Threads(3)
->Iterations(kSetPower * 8 / 3)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded, TestIteratorSearch)
->Threads(4)
->Iterations(kSetPower * 8 / 4)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded, TestIteratorSearch)
->Threads(8)
->Iterations(kSetPower * 8 / 8)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestRemoveDiffElements)
->Threads(1)
->Iterations(kSetPower)
->Arg(kSetPower)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestRemoveDiffElements)
->Threads(2)
->Iterations(kSetPower / 2)
->Arg(kSetPower)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestRemoveDiffElements)
->Threads(3)
->Iterations(kSetPower / 3)
->Arg(kSetPower)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestRemoveDiffElements)
->Threads(4)
->Iterations(kSetPower / 4)
->Arg(kSetPower)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestRemoveDiffElements)
->Threads(8)
->Iterations(kSetPower / 8)
->Arg(kSetPower)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestRemoveSetElements)
->Threads(1)
->Iterations(kSetPower)
->Arg(kSetPower)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestRemoveSetElements)
->Threads(2)
->Iterations(kSetPower / 2)
->Arg(kSetPower)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestRemoveSetElements)
->Threads(3)
->Iterations(kSetPower / 3)
->Arg(kSetPower)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestRemoveSetElements)
->Threads(4)
->Iterations(kSetPower / 4)
->Arg(kSetPower)
->Unit(benchmark::TimeUnit::kMicrosecond);

BENCHMARK_TEMPLATE(BM_MemoryThreaded2, TestRemoveSetElements)
->Threads(8)
->Iterations(kSetPower / 8)
->Arg(kSetPower)
->Unit(benchmark::TimeUnit::kMicrosecond);

// ------------------------------------
template <class BMType>
Expand Down Expand Up @@ -221,16 +488,16 @@ BENCHMARK_TEMPLATE(BM_Template, TestTemplateSearchSmoke)

BENCHMARK_TEMPLATE(BM_Template, TestTemplateSearchComplex)
->Unit(benchmark::TimeUnit::kMicrosecond)
->Arg(5)->Arg(50)->Arg(500);
->Arg(5)->Arg(50);

// SC-code base vs extended
BENCHMARK_TEMPLATE(BM_Template, TestScCodeBase)
->Unit(benchmark::TimeUnit::kMicrosecond)
->Arg(1000)->Arg(10000)->Arg(100000);
->Arg(5)->Arg(50)->Arg(500);

BENCHMARK_TEMPLATE(BM_Template, TestScCodeExtended)
->Unit(benchmark::TimeUnit::kMicrosecond)
->Arg(1000)->Arg(10000)->Arg(100000);
->Arg(5)->Arg(50)->Arg(500);


BENCHMARK_MAIN();
4 changes: 3 additions & 1 deletion sc-memory/tests/performance/units/memory_create_edge.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -27,5 +27,7 @@ class TestCreateEdge : public TestMemory
}

private:
ScAddrVector m_nodes;
static ScAddrVector m_nodes;
};

ScAddrVector TestCreateEdge::m_nodes;
39 changes: 39 additions & 0 deletions sc-memory/tests/performance/units/memory_iterator_search.hpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
/*
* This source file is part of an OSTIS project. For the latest info, see http://ostis.net
* Distributed under the MIT License
* (See accompanying file COPYING.MIT or copy at http://opensource.org/licenses/MIT)
*/

#pragma once

#include "memory_test.hpp"

class TestIteratorSearch : public TestMemory
{
public:
void Run()
{
if (!it)
{
it = m_ctx->Iterator3(m_node, ScType::EdgeAccessConstPosPerm, ScType::NodeConst);
}

it->Next();
}

void Setup(size_t edgesNum) override
{
m_node = m_ctx->CreateNode(ScType::NodeConstClass);
for (size_t i = 0; i < edgesNum; ++i)
{
ScAddr target = m_ctx->CreateNode(ScType::NodeConst);
m_ctx->CreateEdge(ScType::EdgeAccessConstPosPerm, m_node, target);
}
}

private:
ScIterator3Ptr it;
static ScAddr m_node;
};

ScAddr TestIteratorSearch::m_node;
Loading