mirror of
https://github.com/matrix-construct/construct
synced 2025-01-01 18:34:18 +01:00
ircd::ctx: Unify access to ctx::stack, expose structure; remove cruft.
This commit is contained in:
parent
dd1e016ec5
commit
5a27958fa0
5 changed files with 60 additions and 41 deletions
|
@ -45,8 +45,6 @@ namespace ircd::ctx
|
|||
|
||||
const uint64_t &id(const ctx &) noexcept; // Unique ID for context
|
||||
string_view name(const ctx &) noexcept; // User's optional label for context
|
||||
const size_t &stack_max(const ctx &) noexcept; // Returns stack size allocated for ctx
|
||||
const size_t &stack_at(const ctx &) noexcept; // Stack at last sleep (also see this_ctx.h)
|
||||
const int32_t ¬es(const ctx &) noexcept; // Peeks at internal semaphore count
|
||||
const uint64_t &epoch(const ctx &) noexcept; // Context switching counter
|
||||
const ulong &cycles(const ctx &) noexcept; // Accumulated tsc (not counting cur slice)
|
||||
|
@ -81,6 +79,7 @@ namespace ircd::ctx
|
|||
#include "this_ctx.h"
|
||||
#include "wait.h"
|
||||
#include "sleep.h"
|
||||
#include "stack.h"
|
||||
#include "stack_usage_assertion.h"
|
||||
#include "slice_usage_warning.h"
|
||||
#include "critical_assertion.h"
|
||||
|
|
26
include/ircd/ctx/stack.h
Normal file
26
include/ircd/ctx/stack.h
Normal file
|
@ -0,0 +1,26 @@
|
|||
// The Construct
|
||||
//
|
||||
// Copyright (C) The Construct Developers, Authors & Contributors
|
||||
// Copyright (C) 2016-2020 Jason Volk <jason@zemos.net>
|
||||
//
|
||||
// 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.
|
||||
|
||||
namespace ircd::ctx
|
||||
{
|
||||
struct stack;
|
||||
}
|
||||
|
||||
struct ircd::ctx::stack
|
||||
{
|
||||
uintptr_t base {0}; // assigned when spawned
|
||||
size_t max {0}; // User given stack size
|
||||
size_t at {0}; // Updated for profiling at sleep
|
||||
|
||||
stack(const size_t &max);
|
||||
|
||||
static const stack &get(const ctx &) noexcept;
|
||||
static stack &get(ctx &) noexcept;
|
||||
};
|
48
ircd/ctx.cc
48
ircd/ctx.cc
|
@ -654,24 +654,6 @@ noexcept
|
|||
return ctx.notes;
|
||||
}
|
||||
|
||||
/// Returns the notification count for `ctx`
|
||||
[[gnu::hot]]
|
||||
const size_t &
|
||||
ircd::ctx::stack_at(const ctx &ctx)
|
||||
noexcept
|
||||
{
|
||||
return ctx.stack.at;
|
||||
}
|
||||
|
||||
/// Returns the notification count for `ctx`
|
||||
[[gnu::hot]]
|
||||
const size_t &
|
||||
ircd::ctx::stack_max(const ctx &ctx)
|
||||
noexcept
|
||||
{
|
||||
return ctx.stack.max;
|
||||
}
|
||||
|
||||
/// Returns the developer's optional name literal for `ctx`
|
||||
[[gnu::hot]]
|
||||
ircd::string_view
|
||||
|
@ -998,6 +980,36 @@ noexcept
|
|||
}
|
||||
#endif
|
||||
|
||||
//////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// ctx/stack.h
|
||||
//
|
||||
|
||||
[[gnu::hot]]
|
||||
ircd::ctx::stack &
|
||||
ircd::ctx::stack::get(ctx &ctx)
|
||||
noexcept
|
||||
{
|
||||
return ctx.stack;
|
||||
}
|
||||
|
||||
[[gnu::hot]]
|
||||
const ircd::ctx::stack &
|
||||
ircd::ctx::stack::get(const ctx &ctx)
|
||||
noexcept
|
||||
{
|
||||
return ctx.stack;
|
||||
}
|
||||
|
||||
//
|
||||
// stack::stack
|
||||
//
|
||||
|
||||
ircd::ctx::stack::stack(const size_t &max)
|
||||
:max{max}
|
||||
{
|
||||
}
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// ctx/continuation.h
|
||||
|
|
18
ircd/ctx.h
18
ircd/ctx.h
|
@ -18,29 +18,11 @@
|
|||
#define IRCD_CTX_STACK_PROTECT
|
||||
#endif
|
||||
|
||||
namespace ircd::ctx
|
||||
{
|
||||
struct stack;
|
||||
struct profile;
|
||||
}
|
||||
|
||||
namespace ircd::ctx::prof
|
||||
{
|
||||
void mark(const event &);
|
||||
}
|
||||
|
||||
/// Internal structure aggregating any stack related state for the ctx
|
||||
struct ircd::ctx::stack
|
||||
{
|
||||
uintptr_t base {0}; // assigned when spawned
|
||||
size_t max {0}; // User given stack size
|
||||
size_t at {0}; // Updated for profiling at sleep
|
||||
|
||||
stack(const size_t &max = 0)
|
||||
:max{max}
|
||||
{}
|
||||
};
|
||||
|
||||
/// Internal context implementation
|
||||
///
|
||||
struct ircd::ctx::ctx
|
||||
|
|
|
@ -2459,14 +2459,14 @@ console_cmd__ctx__list(opt &out, const string_view &line)
|
|||
|
||||
thread_local char pbuf[32];
|
||||
out << " "
|
||||
<< std::setw(25) << std::right << pretty(pbuf, iec(stack_at(ctx)));
|
||||
<< std::setw(25) << std::right << pretty(pbuf, iec(ctx::stack::get(ctx).at));
|
||||
|
||||
out << " "
|
||||
<< std::setw(25) << std::right << pretty(pbuf, iec(stack_max(ctx)));
|
||||
<< std::setw(25) << std::right << pretty(pbuf, iec(ctx::stack::get(ctx).max));
|
||||
|
||||
const auto stack_pct
|
||||
{
|
||||
stack_at(ctx) / (long double)stack_max(ctx)
|
||||
ctx::stack::get(ctx).at / (long double)(ctx::stack::get(ctx).max)
|
||||
};
|
||||
|
||||
out << " "
|
||||
|
|
Loading…
Reference in a new issue