Skip to content

Commit

Permalink
#2187: trace: first fix regular user events without a note
Browse files Browse the repository at this point in the history
  • Loading branch information
lifflander authored and thearusable committed Jul 10, 2024
1 parent ed79a65 commit f4b9152
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 13 deletions.
28 changes: 24 additions & 4 deletions src/vt/trace/trace_lite.cc
Original file line number Diff line number Diff line change
Expand Up @@ -248,21 +248,41 @@ bool TraceLite::checkDynamicRuntimeEnabled(bool is_end_event) {
(trace_enabled_cur_phase_ or is_end_event);
}

void TraceLite::addUserEventBracketed(
UserEventIDType event, TimeType begin, TimeType end) {
void TraceLite::addUserEventBracketedBegin(
UserEventIDType event, double begin
) {
if (not checkDynamicRuntimeEnabled()) {
return;
}

vt_debug_print(
normal, trace,
"Trace::addUserEventBracketed: event={:x}, begin={}, end={}\n",
event, begin, end);
"Trace::addUserEventBracketedBegin: event={:x}, begin={}\n",
event, begin
);

auto const type = TraceConstantsType::UserEventPair;
NodeType const node = theContext()->getNode();

logEvent(LogType{begin, type, node, event, true});
}

void TraceLite::addUserEventBracketedEnd(
UserEventIDType event, double end
) {
if (not checkDynamicRuntimeEnabled()) {
return;
}

vt_debug_print(
normal, trace,
"Trace::addUserEventBracketedEnd: event={:x}, end={}\n",
event, end
);

auto const type = TraceConstantsType::UserEventPair;
NodeType const node = theContext()->getNode();

logEvent(LogType{end, type, node, event, false});
}

Expand Down
11 changes: 9 additions & 2 deletions src/vt/trace/trace_lite.h
Original file line number Diff line number Diff line change
Expand Up @@ -166,13 +166,20 @@ struct TraceLite {
void disableTracing();

/**
* \brief Log a bracketed user event with start and end time
* \brief Log a bracketed user event with begin time
*
* \param[in] event the ID for the sts file
* \param[in] begin the begin time
*/
void addUserEventBracketedBegin(UserEventIDType event, double begin);

/**
* \brief Log a bracketed user event with end time
*
* \param[in] event the ID for the sts file
* \param[in] end the end time
*/
void addUserEventBracketed(UserEventIDType event, TimeType begin, TimeType end);
void addUserEventBracketedEnd(UserEventIDType event, double end);

/**
* \brief Log a user bracketed event with a note
Expand Down
15 changes: 8 additions & 7 deletions src/vt/trace/trace_user.h
Original file line number Diff line number Diff line change
Expand Up @@ -174,6 +174,7 @@ struct TraceScopedEventHash final {
str_(in_str)
{
event_ = registerEventHashed(str_);
theTrace()->addUserEventBracketedBegin(event_, begin_);
}

TraceScopedEventHash& operator=(TraceScopedEventHash const&) = delete;
Expand All @@ -185,9 +186,8 @@ struct TraceScopedEventHash final {
*/
void end() {
if (event_ != no_user_event_id) {
auto end = TraceLite::getCurrentTime();
theTrace()->addUserEventBracketed(event_, begin_, end);

double end = TraceLite::getCurrentTime();
theTrace()->addUserEventBracketedEnd(event_, end);
event_ = no_user_event_id;
}
}
Expand Down Expand Up @@ -217,7 +217,9 @@ struct TraceScopedEvent final {
explicit TraceScopedEvent(UserEventIDType event)
: begin_(event != no_user_event_id ? TraceLite::getCurrentTime() : TimeType{0.}),
event_(event)
{ }
{
theTrace()->addUserEventBracketedBegin(event_, begin_);
}

TraceScopedEvent(TraceScopedEvent const&) = delete;
TraceScopedEvent(TraceScopedEvent &&other) noexcept
Expand All @@ -241,9 +243,8 @@ struct TraceScopedEvent final {
*/
void end() {
if (event_ != no_user_event_id) {
auto end = TraceLite::getCurrentTime();
theTrace()->addUserEventBracketed(event_, begin_, end);

double end = TraceLite::getCurrentTime();
theTrace()->addUserEventBracketedEnd(event_, end);
event_ = no_user_event_id;
}
}
Expand Down

0 comments on commit f4b9152

Please sign in to comment.