summaryrefslogtreecommitdiff
path: root/src/mongo/db/query/sbe_stage_builder_coll_scan.h
diff options
context:
space:
mode:
authorDavid Storch <david.storch@mongodb.com>2021-01-07 17:23:11 -0500
committerEvergreen Agent <no-reply@evergreen.mongodb.com>2021-01-15 20:52:42 +0000
commit8ccc099b1821a18a120a9ce483bf64dac1899ad1 (patch)
treeebe12b1d0209d72077221b5e12398392610273a4 /src/mongo/db/query/sbe_stage_builder_coll_scan.h
parent601e94d2edd7a07ca5dd3a66bf3bebaaf7597b4a (diff)
downloadmongo-8ccc099b1821a18a120a9ce483bf64dac1899ad1.tar.gz
SERVER-53435 Make queries run with DBHelpers plus SBE circumvent 'checkCanServeReadsFor()'
Such queries may be run when a node is neither primary nor secondary, e.g. as part of executing an initial sync. This affects only the SBE engine, since SBE's internal lock policy requires it to have its own calls to 'checkCanServeReadsFor()'.
Diffstat (limited to 'src/mongo/db/query/sbe_stage_builder_coll_scan.h')
-rw-r--r--src/mongo/db/query/sbe_stage_builder_coll_scan.h4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/mongo/db/query/sbe_stage_builder_coll_scan.h b/src/mongo/db/query/sbe_stage_builder_coll_scan.h
index 1a1683d986f..4d3a73f18fe 100644
--- a/src/mongo/db/query/sbe_stage_builder_coll_scan.h
+++ b/src/mongo/db/query/sbe_stage_builder_coll_scan.h
@@ -30,6 +30,7 @@
#pragma once
#include "mongo/db/exec/sbe/expressions/expression.h"
+#include "mongo/db/exec/sbe/stages/lock_acquisition_callback.h"
#include "mongo/db/exec/sbe/stages/stages.h"
#include "mongo/db/exec/sbe/values/value.h"
#include "mongo/db/query/query_solution.h"
@@ -58,6 +59,7 @@ std::pair<std::unique_ptr<sbe::PlanStage>, PlanStageSlots> generateCollScan(
sbe::value::FrameIdGenerator* frameIdGenerator,
PlanYieldPolicy* yieldPolicy,
sbe::RuntimeEnvironment* env,
- bool isTailableResumeBranch);
+ bool isTailableResumeBranch,
+ sbe::LockAcquisitionCallback lockAcquisitionCallback);
} // namespace mongo::stage_builder