1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 2 // Use of this source code is governed by a BSD-style license that can be 3 // found in the LICENSE file. 4 5 #ifndef NATIVE_CLIENT_SRC_TRUSTED_PLUGIN_PNACL_TRANSLATE_THREAD_H_ 6 #define NATIVE_CLIENT_SRC_TRUSTED_PLUGIN_PNACL_TRANSLATE_THREAD_H_ 7 8 #include <deque> 9 #include <vector> 10 11 #include "native_client/src/include/nacl_macros.h" 12 #include "native_client/src/include/nacl_scoped_ptr.h" 13 #include "native_client/src/include/nacl_string.h" 14 #include "native_client/src/shared/platform/nacl_threads.h" 15 #include "native_client/src/shared/platform/nacl_sync_checked.h" 16 17 #include "ppapi/cpp/completion_callback.h" 18 19 #include "ppapi/native_client/src/trusted/plugin/plugin_error.h" 20 #include "ppapi/native_client/src/trusted/plugin/service_runtime.h" 21 22 struct PP_PNaClOptions; 23 24 namespace nacl { 25 class DescWrapper; 26 } 27 28 29 namespace plugin { 30 31 class NaClSubprocess; 32 class Plugin; 33 class PnaclCoordinator; 34 class PnaclResources; 35 class TempFile; 36 37 class PnaclTranslateThread { 38 public: 39 PnaclTranslateThread(); 40 ~PnaclTranslateThread(); 41 42 // Start the translation process. It will continue to run and consume data 43 // as it is passed in with PutBytes. 44 void RunTranslate(const pp::CompletionCallback& finish_callback, 45 const std::vector<TempFile*>* obj_files, 46 TempFile* nexe_file, 47 nacl::DescWrapper* invalid_desc_wrapper, 48 ErrorInfo* error_info, 49 PnaclResources* resources, 50 PP_PNaClOptions* pnacl_options, 51 const nacl::string &architecture_attributes, 52 PnaclCoordinator* coordinator, 53 Plugin* plugin); 54 55 // Kill the llc and/or ld subprocesses. This happens by closing the command 56 // channel on the plugin side, which causes the trusted code in the nexe to 57 // exit, which will cause any pending SRPCs to error. Because this is called 58 // on the main thread, the translation thread must not use the subprocess 59 // objects without the lock, other than InvokeSrpcMethod, which does not 60 // race with service runtime shutdown. 61 void AbortSubprocesses(); 62 63 // Send bitcode bytes to the translator. Called from the main thread. 64 void PutBytes(std::vector<char>* data, int count); 65 66 int64_t GetCompileTime() const { return compile_time_; } 67 68 private: 69 // Helper thread entry point for translation. Takes a pointer to 70 // PnaclTranslateThread and calls DoTranslate(). 71 static void WINAPI DoTranslateThread(void* arg); 72 // Runs the streaming translation. Called from the helper thread. 73 void DoTranslate() ; 74 // Signal that Pnacl translation failed, from the translation thread only. 75 void TranslateFailed(PP_NaClError err_code, 76 const nacl::string& error_string); 77 // Run the LD subprocess, returning true on success. 78 // On failure, it returns false and runs the callback. 79 bool RunLdSubprocess(); 80 81 82 // Callback to run when tasks are completed or an error has occurred. 83 pp::CompletionCallback report_translate_finished_; 84 85 nacl::scoped_ptr<NaClThread> translate_thread_; 86 87 // Used to guard llc_subprocess and ld_subprocess 88 struct NaClMutex subprocess_mu_; 89 nacl::scoped_ptr<NaClSubprocess> llc_subprocess_; 90 nacl::scoped_ptr<NaClSubprocess> ld_subprocess_; 91 // Used to ensure the subprocesses don't get shutdown more than once. 92 bool llc_subprocess_active_; 93 bool ld_subprocess_active_; 94 95 bool subprocesses_aborted_; 96 97 // Condition variable to synchronize communication with the SRPC thread. 98 // SRPC thread waits on this condvar if data_buffers_ is empty (meaning 99 // there is no bitcode to send to the translator), and the main thread 100 // appends to data_buffers_ and signals it when it receives bitcode. 101 struct NaClCondVar buffer_cond_; 102 // Mutex for buffer_cond_. 103 struct NaClMutex cond_mu_; 104 // Data buffers from FileDownloader are enqueued here to pass from the 105 // main thread to the SRPC thread. Protected by cond_mu_ 106 std::deque<std::vector<char> > data_buffers_; 107 // Whether all data has been downloaded and copied to translation thread. 108 // Associated with buffer_cond_ 109 bool done_; 110 111 int64_t compile_time_; 112 113 // Data about the translation files, owned by the coordinator 114 const std::vector<TempFile*>* obj_files_; 115 TempFile* nexe_file_; 116 nacl::DescWrapper* invalid_desc_wrapper_; 117 ErrorInfo* coordinator_error_info_; 118 PnaclResources* resources_; 119 PP_PNaClOptions* pnacl_options_; 120 nacl::string architecture_attributes_; 121 PnaclCoordinator* coordinator_; 122 Plugin* plugin_; 123 private: 124 NACL_DISALLOW_COPY_AND_ASSIGN(PnaclTranslateThread); 125 }; 126 127 } 128 #endif // NATIVE_CLIENT_SRC_TRUSTED_PLUGIN_PNACL_TRANSLATE_THREAD_H_ 129