entry_nacl.cpp 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192
  1. /*
  2. * Copyright 2011-2013 Branimir Karadzic. All rights reserved.
  3. * License: http://www.opensource.org/licenses/BSD-2-Clause
  4. */
  5. #include "entry_p.h"
  6. #if ENTRY_CONFIG_USE_NATIVE && BX_PLATFORM_NACL
  7. #include <bgfxplatform.h>
  8. #include <stdio.h>
  9. #include <string.h>
  10. #include <pthread.h>
  11. #include <string>
  12. #include <ppapi/c/pp_errors.h>
  13. #include <ppapi/c/pp_module.h>
  14. #include <ppapi/c/ppb.h>
  15. #include <ppapi/c/ppb_core.h>
  16. #include <ppapi/c/ppb_graphics_3d.h>
  17. #include <ppapi/c/ppb_instance.h>
  18. #include <ppapi/c/ppb_message_loop.h>
  19. #include <ppapi/c/ppb_url_loader.h>
  20. #include <ppapi/c/ppb_url_request_info.h>
  21. #include <ppapi/c/ppb_url_response_info.h>
  22. #include <ppapi/c/ppb_var.h>
  23. #include <ppapi/c/ppp.h>
  24. #include <ppapi/c/ppp_instance.h>
  25. #include <ppapi/gles2/gl2ext_ppapi.h>
  26. #include <bgfxplatform.h>
  27. #include <bx/thread.h>
  28. #include "entry.h"
  29. namespace entry
  30. {
  31. const PPB_Core* g_coreInterface;
  32. const PPB_Instance* g_instInterface;
  33. const PPB_Graphics3D* g_graphicsInterface;
  34. const PPB_MessageLoop* g_messageLoopInterface;
  35. const PPB_URLLoader* g_urlLoaderInterface;
  36. const PPB_URLRequestInfo* g_urlRequestInterface;
  37. const PPB_URLResponseInfo* g_urlResponseInterface;
  38. const PPB_Var* g_varInterface;
  39. PP_Instance g_instance;
  40. const Event* poll()
  41. {
  42. return NULL;
  43. }
  44. void release(const Event* _event)
  45. {
  46. BX_UNUSED(_event);
  47. }
  48. void setWindowSize(uint32_t _width, uint32_t _height)
  49. {
  50. BX_UNUSED(_width, _height);
  51. }
  52. void toggleWindowFrame()
  53. {
  54. }
  55. void setMouseLock(bool _lock)
  56. {
  57. BX_UNUSED(_lock);
  58. }
  59. template<typename Type>
  60. bool initializeInterface(PPB_GetInterface _interface, const char* _name, const Type*& _result)
  61. {
  62. _result = reinterpret_cast<const Type*>(_interface(_name) );
  63. return NULL != _result;
  64. }
  65. struct MainThreadEntry
  66. {
  67. int m_argc;
  68. char** m_argv;
  69. static int32_t threadFunc(void* _userData);
  70. };
  71. struct NaclContext
  72. {
  73. NaclContext()
  74. {
  75. const char* argv[1] = { "nacl.nexe" };
  76. m_mte.m_argc = 1;
  77. m_mte.m_argv = const_cast<char**>(argv);
  78. bgfx::naclSetIntefraces(g_instance, g_instInterface, g_graphicsInterface, NULL);
  79. m_thread.init(MainThreadEntry::threadFunc, &m_mte);
  80. }
  81. ~NaclContext()
  82. {
  83. m_thread.shutdown();
  84. }
  85. MainThreadEntry m_mte;
  86. bx::Thread m_thread;
  87. };
  88. static NaclContext* s_ctx;
  89. int32_t MainThreadEntry::threadFunc(void* _userData)
  90. {
  91. MainThreadEntry* self = (MainThreadEntry*)_userData;
  92. PP_Resource resource = g_messageLoopInterface->Create(g_instance);
  93. g_messageLoopInterface->AttachToCurrentThread(resource);
  94. int32_t result = main(self->m_argc, self->m_argv);
  95. return result;
  96. }
  97. static PP_Bool naclInstanceDidCreate(PP_Instance _instance, uint32_t /*_argc*/, const char* /*_argn*/[], const char* /*_argv*/[])
  98. {
  99. g_instance = _instance; // one instance only!
  100. s_ctx = new NaclContext;
  101. return PP_TRUE;
  102. }
  103. static void naclInstanceDidDestroy(PP_Instance _instance)
  104. {
  105. BX_UNUSED(_instance);
  106. delete s_ctx;
  107. }
  108. static void naclInstanceDidChangeView(PP_Instance /*_instance*/, PP_Resource /*_view*/)
  109. {
  110. }
  111. static void naclInstanceDidChangeFocus(PP_Instance /*_instance*/, PP_Bool /*_focus*/)
  112. {
  113. }
  114. static PP_Bool naclInstanceHandleDocumentLoad(PP_Instance /*_instance*/, PP_Resource /*_urlLoader*/)
  115. {
  116. return PP_FALSE;
  117. }
  118. } // namespace entry
  119. using namespace entry;
  120. PP_EXPORT const void* PPP_GetInterface(const char* _name)
  121. {
  122. if (0 == strcmp(_name, PPP_INSTANCE_INTERFACE) )
  123. {
  124. static PPP_Instance instanceInterface =
  125. {
  126. &naclInstanceDidCreate,
  127. &naclInstanceDidDestroy,
  128. &naclInstanceDidChangeView,
  129. &naclInstanceDidChangeFocus,
  130. &naclInstanceHandleDocumentLoad,
  131. };
  132. return &instanceInterface;
  133. }
  134. return NULL;
  135. }
  136. PP_EXPORT int32_t PPP_InitializeModule(PP_Module _module, PPB_GetInterface _interface)
  137. {
  138. BX_UNUSED(_module);
  139. bool result = true;
  140. result &= initializeInterface(_interface, PPB_CORE_INTERFACE, g_coreInterface);
  141. result &= initializeInterface(_interface, PPB_GRAPHICS_3D_INTERFACE, g_graphicsInterface);
  142. result &= initializeInterface(_interface, PPB_INSTANCE_INTERFACE, g_instInterface);
  143. result &= initializeInterface(_interface, PPB_MESSAGELOOP_INTERFACE, g_messageLoopInterface);
  144. result &= initializeInterface(_interface, PPB_URLLOADER_INTERFACE, g_urlLoaderInterface);
  145. result &= initializeInterface(_interface, PPB_URLREQUESTINFO_INTERFACE, g_urlRequestInterface);
  146. result &= initializeInterface(_interface, PPB_URLRESPONSEINFO_INTERFACE, g_urlResponseInterface);
  147. result &= initializeInterface(_interface, PPB_VAR_INTERFACE, g_varInterface);
  148. result &= glInitializePPAPI(_interface);
  149. return result ? PP_OK : PP_ERROR_NOINTERFACE;
  150. }
  151. PP_EXPORT void PPP_ShutdownModule()
  152. {
  153. }
  154. #endif // ENTRY_CONFIG_USE_NATIVE && BX_PLATFROM_NACL