From 898099a02ff80fb4143ab93daea3956f4f82e8e3 Mon Sep 17 00:00:00 2001 From: Shamser Ahmed Date: Fri, 1 Nov 2024 15:28:15 +0000 Subject: [PATCH] HPCC-32930 Capture and report start timings for activities derived from CInMemJoinBase Capture start timing for input activities started asynchronously by CInMemJoinBase. Signed-off-by: Shamser Ahmed --- thorlcr/activities/lookupjoin/thlookupjoinslave.cpp | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/thorlcr/activities/lookupjoin/thlookupjoinslave.cpp b/thorlcr/activities/lookupjoin/thlookupjoinslave.cpp index 69e0651c2bb..2e9f426a97a 100644 --- a/thorlcr/activities/lookupjoin/thlookupjoinslave.cpp +++ b/thorlcr/activities/lookupjoin/thlookupjoinslave.cpp @@ -1445,11 +1445,17 @@ class CInMemJoinBase : public CSlaveActivity, public CAllOrLookupHelper, } HTHELPER *queryTable() { return table; } IBitSet *queryRhsChannelStopSet() { dbgassertex(0 == queryJobChannelNumber()); return rhsChannelStop; } - void startLeftInput() + void startLeftInput(bool async=false) { try { - startInput(0); + if (async) + { + LookAheadTimer t(slaveTimerStats, timeActivities); + startInput(0); + } + else + startInput(0); if (ensureStartFTLookAhead(0)) setLookAhead(0, createRowStreamLookAhead(this, inputStream, queryRowInterfaces(input), LOOKUPJOINL_SMART_BUFFER_SIZE, ::canStall(input), grouped, RCUNBOUND, this), false); left.set(inputStream); // can be replaced by loader stream @@ -1530,6 +1536,7 @@ class CInMemJoinBase : public CSlaveActivity, public CAllOrLookupHelper, } virtual void start() override { + ActivityTimer s(slaveTimerStats, timeActivities); joined = 0; joinCounter = 0; candidateCounter = 0; @@ -1562,7 +1569,7 @@ class CInMemJoinBase : public CSlaveActivity, public CAllOrLookupHelper, } else { - CAsyncCallStart asyncLeftStart(std::bind(&CInMemJoinBase::startLeftInput, this)); + CAsyncCallStart asyncLeftStart(std::bind(&CInMemJoinBase::startLeftInput, this, true)); try { startInput(1);