// Copyright (c) 2011-2016 The Cryptonote developers // Distributed under the MIT/X11 software license, see the accompanying // file COPYING or http://www.opensource.org/licenses/mit-license.php. #pragma once #include #include #include #include namespace System { struct NativeContextGroup; struct NativeContext { void* fiber; bool interrupted; NativeContext* next; NativeContextGroup* group; NativeContext* groupPrev; NativeContext* groupNext; std::function procedure; std::function interruptProcedure; }; struct NativeContextGroup { NativeContext* firstContext; NativeContext* lastContext; NativeContext* firstWaiter; NativeContext* lastWaiter; }; class Dispatcher { public: Dispatcher(); Dispatcher(const Dispatcher&) = delete; ~Dispatcher(); Dispatcher& operator=(const Dispatcher&) = delete; void clear(); void dispatch(); NativeContext* getCurrentContext() const; void interrupt(); void interrupt(NativeContext* context); bool interrupted(); void pushContext(NativeContext* context); void remoteSpawn(std::function&& procedure); void yield(); // Platform-specific void addTimer(uint64_t time, NativeContext* context); void* getCompletionPort() const; NativeContext& getReusableContext(); void pushReusableContext(NativeContext&); void interruptTimer(uint64_t time, NativeContext* context); private: void spawn(std::function&& procedure); void* completionPort; uint8_t criticalSection[2 * sizeof(long) + 4 * sizeof(void*)]; bool remoteNotificationSent; std::queue> remoteSpawningProcedures; uint8_t remoteSpawnOverlapped[4 * sizeof(void*)]; uint32_t threadId; std::multimap timers; NativeContext mainContext; NativeContextGroup contextGroup; NativeContext* currentContext; NativeContext* firstResumingContext; NativeContext* lastResumingContext; NativeContext* firstReusableContext; size_t runningContextCount; void contextProcedure(); static void __stdcall contextProcedureStatic(void* context); }; }