2018-06-09 13:40:21 -07:00
|
|
|
// Matrix Construct
|
|
|
|
//
|
|
|
|
// Copyright (C) Matrix Construct Developers, Authors & Contributors
|
2019-07-20 15:29:33 -07:00
|
|
|
// Copyright (C) 2016-2019 Jason Volk <jason@zemos.net>
|
2018-06-09 13:40:21 -07:00
|
|
|
//
|
|
|
|
// Permission to use, copy, modify, and/or distribute this software for any
|
|
|
|
// purpose with or without fee is hereby granted, provided that the above
|
|
|
|
// copyright notice and this permission notice is present in all copies. The
|
|
|
|
// full license for this software is available in the LICENSE file.
|
|
|
|
|
|
|
|
#pragma once
|
2019-07-20 15:29:33 -07:00
|
|
|
#define HAVE_IRCD_DB_ENV_STATE_H
|
2018-06-09 13:40:21 -07:00
|
|
|
|
|
|
|
struct ircd::db::database::env::state
|
|
|
|
{
|
2018-08-16 04:48:21 -07:00
|
|
|
struct task;
|
2018-12-16 16:26:33 -08:00
|
|
|
struct pool;
|
2018-08-16 04:48:21 -07:00
|
|
|
|
|
|
|
static constexpr const size_t POOLS
|
|
|
|
{
|
|
|
|
rocksdb::Env::Priority::TOTAL
|
|
|
|
};
|
|
|
|
|
2018-12-16 16:26:33 -08:00
|
|
|
database &d;
|
|
|
|
std::array<std::unique_ptr<pool>, POOLS> pool;
|
2018-08-16 04:48:21 -07:00
|
|
|
|
2018-12-16 16:26:33 -08:00
|
|
|
state(database *const &);
|
2019-07-20 15:08:25 -07:00
|
|
|
state(state &&) = delete;
|
|
|
|
state(const state &) = delete;
|
2018-08-28 14:04:43 -07:00
|
|
|
~state() noexcept;
|
2018-08-16 04:48:21 -07:00
|
|
|
};
|
|
|
|
|
2018-12-16 16:26:33 -08:00
|
|
|
struct ircd::db::database::env::state::pool
|
|
|
|
{
|
|
|
|
using Priority = rocksdb::Env::Priority;
|
2018-12-27 14:56:40 -08:00
|
|
|
using IOPriority = rocksdb::Env::IOPriority;
|
2018-12-16 16:26:33 -08:00
|
|
|
|
|
|
|
static conf::item<size_t> stack_size;
|
|
|
|
|
|
|
|
database &d;
|
|
|
|
Priority pri;
|
2018-12-27 14:56:40 -08:00
|
|
|
IOPriority iopri;
|
2019-07-20 14:56:10 -07:00
|
|
|
char namebuf[16];
|
|
|
|
string_view name;
|
2018-12-28 12:57:32 -08:00
|
|
|
ctx::dock dock;
|
2018-12-31 16:12:10 -08:00
|
|
|
uint64_t taskctr {0};
|
2018-12-16 16:26:33 -08:00
|
|
|
std::deque<task> tasks;
|
2018-12-28 12:57:32 -08:00
|
|
|
ctx::pool::opts popts;
|
2018-12-16 16:26:33 -08:00
|
|
|
ctx::pool p;
|
|
|
|
|
|
|
|
size_t cancel(void *const &tag);
|
|
|
|
void operator()(task &&);
|
|
|
|
|
|
|
|
void wait();
|
|
|
|
void join();
|
|
|
|
|
|
|
|
pool(database &, const Priority &);
|
2019-07-20 15:08:25 -07:00
|
|
|
pool(pool &&) = delete;
|
|
|
|
pool(const pool &) = delete;
|
2018-12-16 16:26:33 -08:00
|
|
|
~pool() noexcept;
|
|
|
|
};
|
|
|
|
|
2018-08-16 04:48:21 -07:00
|
|
|
struct ircd::db::database::env::state::task
|
|
|
|
{
|
|
|
|
void (*func)(void *arg);
|
|
|
|
void (*cancel)(void *arg);
|
|
|
|
void *arg;
|
2018-12-31 16:12:10 -08:00
|
|
|
uint64_t _id {0};
|
2018-06-09 13:40:21 -07:00
|
|
|
};
|