123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128 |
- /**
- * @file llpluginprocesschild.h
- * @brief LLPluginProcessChild handles the child side of the external-process plugin API.
- *
- * $LicenseInfo:firstyear=2008&license=viewergpl$
- *
- * Copyright (c) 2008-2009, Linden Research, Inc.
- *
- * Second Life Viewer Source Code
- * The source code in this file ("Source Code") is provided by Linden Lab
- * to you under the terms of the GNU General Public License, version 2.0
- * ("GPL"), unless you have obtained a separate licensing agreement
- * ("Other License"), formally executed by you and Linden Lab. Terms of
- * the GPL can be found in doc/GPL-license.txt in this distribution, or
- * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2
- *
- * There are special exceptions to the terms and conditions of the GPL as
- * it is applied to this Source Code. View the full text of the exception
- * in the file doc/FLOSS-exception.txt in this software distribution, or
- * online at
- * http://secondlifegrid.net/programs/open_source/licensing/flossexception
- *
- * By copying, modifying or distributing this software, you acknowledge
- * that you have read and understood your obligations described above,
- * and agree to abide by those obligations.
- *
- * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
- * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
- * COMPLETENESS OR PERFORMANCE.
- * $/LicenseInfo$
- */
- #ifndef LL_LLPLUGINPROCESSCHILD_H
- #define LL_LLPLUGINPROCESSCHILD_H
- #include <map>
- #include <queue>
- #include "llhost.h"
- #include "llplugininstance.h"
- #include "llpluginmessage.h"
- #include "llpluginmessagepipe.h"
- #include "llpluginsharedmemory.h"
- #include "lltimer.h"
- class LLPluginProcessChild : public LLPluginMessagePipeOwner,
- public LLPluginInstanceMessageListener
- {
- protected:
- LOG_CLASS(LLPluginProcessChild);
- public:
- enum EState
- {
- STATE_UNINITIALIZED,
- STATE_INITIALIZED, // init() has been called
- STATE_CONNECTED, // connected back to launcher
- STATE_PLUGIN_LOADING, // plugin library needs to be loaded
- STATE_PLUGIN_LOADED, // plugin library has been loaded
- STATE_PLUGIN_INITIALIZING, // plugin is processing init message
- STATE_RUNNING, // steady state (processing messages)
- STATE_SHUTDOWNREQ, // Parent has requested a shutdown.
- STATE_UNLOADING, // plugin has sent shutdown_response and needs to be unloaded
- STATE_UNLOADED, // plugin has been unloaded
- STATE_ERROR, // generic bailout state
- STATE_DONE // state machine will sit in this state after either error or normal termination.
- };
- LLPluginProcessChild();
- ~LLPluginProcessChild();
- void init(U32 launcher_port);
- void idle();
- void sleep(F64 seconds);
- void pump();
- // Returns true if the plugin is in the steady state (processing messages)
- LL_INLINE bool isRunning() { return mState == STATE_RUNNING; }
- // Returns true if the plugin is unloaded or we're in an unrecoverable
- // error state.
- LL_INLINE bool isDone() { return mState == STATE_DONE; }
- void killSockets();
- LL_INLINE F64 getSleepTime() const { return mSleepTime; }
- void sendMessageToPlugin(const LLPluginMessage& message);
- void sendMessageToParent(const LLPluginMessage& message);
- // Inherited from LLPluginMessagePipeOwner
- void receiveMessageRaw(const std::string& message) override;
- // Inherited from LLPluginInstanceMessageListener
- void receivePluginMessage(const std::string& message) override;
- private:
- void setState(EState state);
- void deliverQueuedMessages();
- private:
- LLPluginInstance* mInstance;
- EState mState;
- LLHost mLauncherHost;
- LLSocket::ptr_t mSocket;
- std::string mPluginFile;
- std::string mPluginDir;
- typedef std::map<std::string, LLPluginSharedMemory*> shared_mem_regions_t;
- shared_mem_regions_t mSharedMemoryRegions;
- std::queue<std::string> mMessageQueue;
- LLTimer mHeartbeat;
- LLTimer mWaitGoodbye;
- F64 mSleepTime;
- F64 mCPUElapsed;
- bool mBlockingRequest;
- bool mBlockingResponseReceived;
- };
- #endif // LL_LLPLUGINPROCESSCHILD_H
|