aboutsummaryrefslogtreecommitdiffstats
path: root/library/cpp/actors/interconnect/poller_tcp_unit.h
diff options
context:
space:
mode:
authorDevtools Arcadia <arcadia-devtools@yandex-team.ru>2022-02-07 18:08:42 +0300
committerDevtools Arcadia <arcadia-devtools@mous.vla.yp-c.yandex.net>2022-02-07 18:08:42 +0300
commit1110808a9d39d4b808aef724c861a2e1a38d2a69 (patch)
treee26c9fed0de5d9873cce7e00bc214573dc2195b7 /library/cpp/actors/interconnect/poller_tcp_unit.h
downloadydb-1110808a9d39d4b808aef724c861a2e1a38d2a69.tar.gz
intermediate changes
ref:cde9a383711a11544ce7e107a78147fb96cc4029
Diffstat (limited to 'library/cpp/actors/interconnect/poller_tcp_unit.h')
-rw-r--r--library/cpp/actors/interconnect/poller_tcp_unit.h67
1 files changed, 67 insertions, 0 deletions
diff --git a/library/cpp/actors/interconnect/poller_tcp_unit.h b/library/cpp/actors/interconnect/poller_tcp_unit.h
new file mode 100644
index 0000000000..692168b968
--- /dev/null
+++ b/library/cpp/actors/interconnect/poller_tcp_unit.h
@@ -0,0 +1,67 @@
+#pragma once
+
+#include <util/system/thread.h>
+#include <library/cpp/actors/util/funnel_queue.h>
+
+#include "interconnect_stream.h"
+
+#include <memory>
+#include <functional>
+#include <unordered_map>
+
+namespace NInterconnect {
+ using NActors::TFDDelegate;
+ using NActors::TSharedDescriptor;
+
+ class TPollerUnit {
+ public:
+ typedef std::unique_ptr<TPollerUnit> TPtr;
+
+ static TPtr Make(bool useSelect);
+
+ void Start();
+ void Stop();
+
+ virtual void StartReadOperation(
+ const TIntrusivePtr<TSharedDescriptor>& stream,
+ TFDDelegate&& operation);
+
+ virtual void StartWriteOperation(
+ const TIntrusivePtr<TSharedDescriptor>& stream,
+ TFDDelegate&& operation);
+
+ virtual ~TPollerUnit();
+
+ private:
+ virtual void ProcessRead() = 0;
+ virtual void ProcessWrite() = 0;
+
+ template <bool IsWrite>
+ static void* IdleThread(void* param);
+
+ template <bool IsWrite>
+ void RunLoop();
+
+ volatile bool StopFlag;
+ TThread ReadLoop, WriteLoop;
+
+ protected:
+ TPollerUnit();
+
+ struct TSide {
+ using TOperations =
+ std::unordered_map<SOCKET,
+ std::pair<TIntrusivePtr<TSharedDescriptor>, TFDDelegate>>;
+
+ TOperations Operations;
+ using TItem = TOperations::mapped_type;
+ TFunnelQueue<TItem> InputQueue;
+
+ void ProcessInput();
+ } Read, Write;
+
+ template <bool IsWrite>
+ TSide& GetSide();
+ };
+
+}