0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2025-01-14 16:46:50 +01:00

ircd::ctx::prof: Convert the settings into conf items.

This commit is contained in:
Jason Volk 2018-11-14 17:35:23 -08:00
parent 895768837f
commit 48a15e026b
2 changed files with 55 additions and 22 deletions

View file

@ -30,7 +30,6 @@
namespace ircd::ctx::prof namespace ircd::ctx::prof
{ {
enum class event; enum class event;
struct settings extern settings;
// lowlevel // lowlevel
ulong rdtsc(); ulong rdtsc();
@ -60,12 +59,12 @@ enum class ircd::ctx::prof::event
CUR_TERMINATE, // Current context detects termination CUR_TERMINATE, // Current context detects termination
}; };
struct ircd::ctx::prof::settings namespace ircd::ctx::prof::settings
{ {
double stack_usage_warning; // percentage extern conf::item<double> stack_usage_warning; // percentage
double stack_usage_assertion; // percentage extern conf::item<double> stack_usage_assertion; // percentage
ulong slice_warning; // Warn when the yield-to-yield cycles exceeds extern conf::item<ulong> slice_warning; // Warn when the yield-to-yield cycles exceeds
ulong slice_interrupt; // Interrupt exception when exceeded (not a signal) extern conf::item<ulong> slice_interrupt; // Interrupt exception when exceeded (not a signal)
ulong slice_assertion; // abort() when exceeded (not a signal, must yield) extern conf::item<ulong> slice_assertion; // abort() when exceeded (not a signal, must yield)
}; }

View file

@ -747,14 +747,14 @@ noexcept
ircd::ctx::this_ctx::stack_usage_assertion::stack_usage_assertion() ircd::ctx::this_ctx::stack_usage_assertion::stack_usage_assertion()
{ {
const auto stack_usage(stack_at_here()); const auto stack_usage(stack_at_here());
assert(stack_usage < cur().stack.max * prof::settings.stack_usage_assertion); assert(stack_usage < cur().stack.max * double(prof::settings::stack_usage_assertion));
} }
ircd::ctx::this_ctx::stack_usage_assertion::~stack_usage_assertion() ircd::ctx::this_ctx::stack_usage_assertion::~stack_usage_assertion()
noexcept noexcept
{ {
const auto stack_usage(stack_at_here()); const auto stack_usage(stack_at_here());
assert(stack_usage < cur().stack.max * prof::settings.stack_usage_assertion); assert(stack_usage < cur().stack.max * double(prof::settings::stack_usage_assertion));
} }
#endif // NDEBUG #endif // NDEBUG
@ -1197,15 +1197,44 @@ namespace ircd::ctx::prof
void handle_cur_enter(); void handle_cur_enter();
} }
struct ircd::ctx::prof::settings // stack_usage_warning at 1/3 engineering tolerance
ircd::ctx::prof::settings decltype(ircd::ctx::prof::settings::stack_usage_warning)
ircd::ctx::prof::settings::stack_usage_warning
{ {
0.33, // stack_usage_warning at 1/3 engineering tolerance { "name", "ircd.ctx.prof.stack_usage_warning" },
0.50, // stack_usage_assertion at 1/2 engineering tolerance { "default", 0.33 },
};
280 * 1000000UL, // slice_warning after this number of tsc ticks... // stack_usage_assertion at 1/2 engineering tolerance
0UL, // slice_interrupt unused until project more mature... decltype(ircd::ctx::prof::settings::stack_usage_assertion)
0UL, // slice_assertion unused; warning sufficient for now... ircd::ctx::prof::settings::stack_usage_assertion
{
{ "name", "ircd.ctx.prof.stack_usage_assertion" },
{ "default", 0.50 },
};
// slice_warning after this number of tsc ticks...
decltype(ircd::ctx::prof::settings::slice_warning)
ircd::ctx::prof::settings::slice_warning
{
{ "name", "ircd.ctx.prof.slice_warning" },
{ "default", 280 * 1000000L },
};
// slice_interrupt after this number of tsc ticks...
decltype(ircd::ctx::prof::settings::slice_interrupt)
ircd::ctx::prof::settings::slice_interrupt
{
{ "name", "ircd.ctx.prof.slice_interrupt" },
{ "default", 0L },
};
// slice_assertion after this number of tsc ticks...
decltype(ircd::ctx::prof::settings::slice_assertion)
ircd::ctx::prof::settings::slice_assertion
{
{ "name", "ircd.ctx.prof.slice_assertion" },
{ "default", 0L },
}; };
#ifdef RB_DEBUG #ifdef RB_DEBUG
@ -1289,7 +1318,8 @@ ircd::ctx::prof::check_slice()
c.profile.cycles += last_cycles; c.profile.cycles += last_cycles;
_slice_total += last_cycles; _slice_total += last_cycles;
if(unlikely(settings.slice_warning > 0 && last_cycles >= settings.slice_warning)) const ulong &slice_warning(settings::slice_warning);
if(unlikely(slice_warning > 0 && last_cycles >= slice_warning))
log::dwarning log::dwarning
{ {
"context timeslice exceeded '%s' #%lu total: %lu last: %lu", "context timeslice exceeded '%s' #%lu total: %lu last: %lu",
@ -1299,9 +1329,11 @@ ircd::ctx::prof::check_slice()
last_cycles last_cycles
}; };
assert(settings.slice_assertion == 0 || last_cycles < settings.slice_assertion); const ulong &slice_assertion(settings::slice_assertion);
assert(slice_assertion == 0 || last_cycles < slice_assertion);
if(unlikely(settings.slice_interrupt > 0 && last_cycles >= settings.slice_interrupt)) const ulong &slice_interrupt(settings::slice_interrupt);
if(unlikely(slice_interrupt > 0 && last_cycles >= slice_interrupt))
throw interrupted throw interrupted
{ {
"context '%s' #%lu watchdog interrupt (total: %lu last: %lu)", "context '%s' #%lu watchdog interrupt (total: %lu last: %lu)",
@ -1320,7 +1352,8 @@ ircd::ctx::prof::check_stack()
const auto &stack_at(stack_at_here()); const auto &stack_at(stack_at_here());
c.stack.at = stack_at; c.stack.at = stack_at;
if(unlikely(stack_at > stack_max * settings.stack_usage_warning)) const double &stack_usage_assertion(settings::stack_usage_assertion);
if(unlikely(stack_at > stack_max * stack_usage_assertion))
{ {
log::dwarning log::dwarning
{ {
@ -1331,7 +1364,8 @@ ircd::ctx::prof::check_stack()
c.stack.max c.stack.max
}; };
assert(stack_at < c.stack.max * settings.stack_usage_assertion); const double &stack_usage_assertion(settings::stack_usage_assertion);
assert(stack_at < c.stack.max * double(settings::stack_usage_assertion));
} }
} }