Makefile.opt_lib 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292
  1. #
  2. # Copyright (C) 2011-2017 Intel Corporation. All rights reserved.
  3. #
  4. # Redistribution and use in source and binary forms, with or without
  5. # modification, are permitted provided that the following conditions
  6. # are met:
  7. #
  8. # * Redistributions of source code must retain the above copyright
  9. # notice, this list of conditions and the following disclaimer.
  10. # * Redistributions in binary form must reproduce the above copyright
  11. # notice, this list of conditions and the following disclaimer in
  12. # the documentation and/or other materials provided with the
  13. # distribution.
  14. # * Neither the name of Intel Corporation nor the names of its
  15. # contributors may be used to endorse or promote products derived
  16. # from this software without specific prior written permission.
  17. #
  18. # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  19. # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  20. # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  21. # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  22. # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  23. # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  24. # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  25. # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  26. # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  27. # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  28. # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  29. #
  30. #
  31. # This Makefile will compile SDK to generate various components
  32. # including:
  33. # - Trusted libraries
  34. # - tstdc: libsgx_tstdc.a
  35. # - tstdcxx: libsgx_tstdcxx.a
  36. # - tcxx: libsgx_tcxx.a
  37. # - tservice: libsgx_tservice.a
  38. # - trts: libsgx_trts.a
  39. # - tcrypto: libsgx_tcrypto.a
  40. # - tkey_exchange: libsgx_tkey_exchange.a
  41. # - tprotected_fs: libsgx_tprotected_fs.a
  42. # - tcmalloc: libsgx_tcmalloc.a
  43. # - Untrtusted libraries
  44. # - ukey_exchange: libsgx_ukey_exchange.a
  45. # - uprotected_fs: libsgx_uprotected_fs.a
  46. # - sample_crypto: libsample_crypto.so (for sample code use)
  47. # - ptrace: libsgx_ptrace.so, gdb-sgx-plugin
  48. # - Standalone, untrusted libraries
  49. # - libcapable: libsgx_capable.a libsgx_capable.so
  50. # - Tools
  51. # - signtool: sgx_sign
  52. # - edger8r: sgx_edger8r
  53. # - Simulation libraries and tools
  54. # - simulation: libsgx_trts_sim.a, libsgx_tservice_sim.a, libsgx_urts_sim.so, libsgx_uae_service_sim.so, sgx_config_cpusvn
  55. #
  56. include ../buildenv.mk
  57. LIBTLIBC := $(BUILD_DIR)/libsgx_tstdc.a
  58. LIBTLIBCXX := $(BUILD_DIR)/libsgx_tstdcxx.a
  59. LIBTCXX := $(BUILD_DIR)/libsgx_tcxx.a
  60. LIBTSE := $(BUILD_DIR)/libsgx_tservice.a
  61. .PHONY: components
  62. components: tstdc tstdcxx tcxx tservice trts tcrypto tkey_exchange ukey_exchange tprotected_fs uprotected_fs ptrace sample_crypto libcapable simulation signtool edger8r tcmalloc
  63. # ---------------------------------------------------
  64. # tstdc
  65. # includes: tlibc, tlibthread, compiler-rt, tsafecrt
  66. # libimf, libirc, libsvml, etc.
  67. # ---------------------------------------------------
  68. .PHONY: tstdc
  69. tstdc: $(LIBTLIBC)
  70. ifeq ($(ARCH), x86_64)
  71. LIBM_PATH := $(LINUX_EXTERNAL_DIR)/libm/Libm_ct_Linux
  72. LIBIRC_PATH := $(LINUX_EXTERNAL_DIR)/libirc/efi2
  73. SVML_PATH := $(LINUX_EXTERNAL_DIR)/libm/SVML_Intel64_Linux
  74. else
  75. LIBM_PATH := $(LINUX_EXTERNAL_DIR)/libm/Libm_Linux
  76. LIBIRC_PATH := $(LINUX_EXTERNAL_DIR)/libirc/ia32
  77. SVML_PATH := $(LINUX_EXTERNAL_DIR)/libm/SVML_IA32_Linux
  78. endif
  79. LIBIRC_NAME := libirc.a
  80. $(LIBTLIBC): tlibthread compiler-rt tsafecrt tsetjmp $(LIBM_PATH)/libimf.a $(LIBIRC_PATH)/$(LIBIRC_NAME) $(SVML_PATH)/libsvml.a
  81. $(MAKE) -C tlibc/ -j4 2> /dev/null
  82. @$(MKDIR) $(BUILD_DIR)/.libimf $(BUILD_DIR)/.libirc $(BUILD_DIR)/.libsvml $(BUILD_DIR)/.tlibc \
  83. $(BUILD_DIR)/.tlibthread $(BUILD_DIR)/.tsafecrt $(BUILD_DIR)/.tsetjmp
  84. @$(RM) -f $(BUILD_DIR)/.libimf/* $(BUILD_DIR)/.libirc/* $(BUILD_DIR)/.libsvml/* $(BUILD_DIR)/.tlibc/* \
  85. $(BUILD_DIR)/.tlibthread/* $(BUILD_DIR)/.tsafecrt/* $(BUILD_DIR)/.tsetjmp/*
  86. @cd $(BUILD_DIR)/.libimf && $(AR) x $(LIBM_PATH)/libimf.a
  87. @cd $(BUILD_DIR)/.libirc && $(AR) x $(LIBIRC_PATH)/$(LIBIRC_NAME)
  88. @cd $(BUILD_DIR)/.libsvml && $(AR) x $(SVML_PATH)/libsvml.a
  89. @cd $(BUILD_DIR)/.tlibc && $(AR) x $(LINUX_SDK_DIR)/tlibc/libtlibc.a
  90. @cd $(BUILD_DIR)/.tlibthread && $(AR) x $(LINUX_SDK_DIR)/tlibthread/libtlibthread.a
  91. @cd $(BUILD_DIR)/.tsafecrt && $(AR) x $(LINUX_SDK_DIR)/tsafecrt/libsgx_tsafecrt.a
  92. @cd $(BUILD_DIR)/.tsetjmp && $(AR) x $(LINUX_SDK_DIR)/tsetjmp/libsgx_tsetjmp.a
  93. $(CP) compiler-rt/libcompiler-rt.a $@
  94. $(AR) rsD $@ $(BUILD_DIR)/.libimf/*.o $(BUILD_DIR)/.libirc/*.o $(BUILD_DIR)/.libsvml/*.o $(BUILD_DIR)/.tlibc/*.o \
  95. $(BUILD_DIR)/.tlibthread/*.o $(BUILD_DIR)/.tsafecrt/*.o $(BUILD_DIR)/.tsetjmp/*.o
  96. @$(RM) -rf $(BUILD_DIR)/.libimf $(BUILD_DIR)/.libirc $(BUILD_DIR)/.libsvml $(BUILD_DIR)/.tlibc \
  97. $(BUILD_DIR)/.tlibthread $(BUILD_DIR)/.tsafecrt $(BUILD_DIR)/.tsetjmp
  98. .PHONY: tlibthread
  99. tlibthread:
  100. $(MAKE) -C tlibthread/
  101. .PHONY: tsafecrt
  102. tsafecrt:
  103. $(MAKE) -C tsafecrt/
  104. .PHONY: compiler-rt
  105. compiler-rt:
  106. $(MAKE) -C compiler-rt/ 2> /dev/null
  107. .PHONY: tsetjmp
  108. tsetjmp:
  109. $(MAKE) -C tsetjmp/
  110. # ---------------------------------------------------
  111. # tstdcxx
  112. # includes: cpprt, tlibstdcxx
  113. # ---------------------------------------------------
  114. .PHONY: tstdcxx
  115. tstdcxx: $(LIBTLIBCXX)
  116. $(LIBTLIBCXX): cpprt tlibstdcxx
  117. @$(MKDIR) $(BUILD_DIR)/.cpprt $(BUILD_DIR)/.tlibstdcxx
  118. @$(RM) -f $(BUILD_DIR)/.cpprt/* $(BUILD_DIR)/.tlibstdcxx/*
  119. @cd $(BUILD_DIR)/.cpprt && $(AR) x $(LINUX_SDK_DIR)/cpprt/libcpprt.a
  120. @cd $(BUILD_DIR)/.tlibstdcxx && $(AR) x $(LINUX_SDK_DIR)/tlibstdcxx/libtlibstdcxx.a
  121. $(AR) rcsD $@ $(BUILD_DIR)/.cpprt/*.o $(BUILD_DIR)/.tlibstdcxx/*.o
  122. @$(RM) -rf $(BUILD_DIR)/.cpprt $(BUILD_DIR)/.tlibstdcxx
  123. .PHONY: cpprt
  124. cpprt:
  125. $(MAKE) -C cpprt
  126. .PHONY: tlibstdcxx
  127. tlibstdcxx: $(BUILD_DIR)
  128. $(MAKE) -C tlibstdcxx/ 2> /dev/null
  129. $(CP) tlibstdcxx/README.sgx $(BUILD_DIR)/STLport_Changes_SGX.txt
  130. # ---------------------------------------------------
  131. # tcxx
  132. # includes: cpprt, tlibcxx
  133. # ---------------------------------------------------
  134. .PHONY: tcxx
  135. tcxx: $(LIBTCXX)
  136. $(LIBTCXX): cpprt tlibcxx
  137. @$(MKDIR) $(BUILD_DIR)/._cpprt $(BUILD_DIR)/.tlibcxx
  138. @$(RM) -f $(BUILD_DIR)/._cpprt/* $(BUILD_DIR)/.tlibcxx/*
  139. @cd $(BUILD_DIR)/._cpprt && $(AR) x $(LINUX_SDK_DIR)/cpprt/libcpprt.a
  140. @cd $(BUILD_DIR)/.tlibcxx && $(AR) x $(LINUX_SDK_DIR)/tlibcxx/libcxx.a
  141. $(AR) rcsD $@ $(BUILD_DIR)/._cpprt/*.o $(BUILD_DIR)/.tlibcxx/*.o
  142. @$(RM) -rf $(BUILD_DIR)/._cpprt $(BUILD_DIR)/.tlibcxx
  143. .PHONY: tlibcxx
  144. tlibcxx: $(BUILD_DIR)
  145. $(MAKE) -C tlibcxx/ 2> /dev/null
  146. $(CP) tlibcxx/README.sgx $(BUILD_DIR)/libc++_Changes_SGX.txt
  147. # ---------------------------------------------------
  148. # tservice
  149. # includes: selib, tseal, tae_service, ec_dh_lib
  150. # ---------------------------------------------------
  151. .PHONY: tservice
  152. tservice: $(LIBTSE)
  153. $(LIBTSE): selib tseal tae_service
  154. @$(MKDIR) $(BUILD_DIR)/.tservice
  155. @$(RM) -f $(BUILD_DIR)/.tservice/*
  156. cd $(BUILD_DIR)/.tservice && $(AR) x $(LINUX_SDK_DIR)/tseal/linux/libtSeal.a
  157. cd $(BUILD_DIR)/.tservice && $(AR) x $(LINUX_SDK_DIR)/tae_service/libtae_service.a
  158. $(CP) $(LINUX_SDK_DIR)/selib/linux/libselib.a $@
  159. $(AR) rsD $@ $(BUILD_DIR)/.tservice/*.o
  160. @$(RM) -rf $(BUILD_DIR)/.tservice
  161. .PHONY: selib
  162. selib:
  163. $(MAKE) -C selib/linux/
  164. .PHONY: tseal
  165. tseal:
  166. $(MAKE) -C tseal/linux/
  167. .PHONY: tae_service
  168. tae_service: edger8r
  169. $(MAKE) -C tae_service MODE=$(MODE)
  170. # ---------------------------------------------------
  171. # Other trusted libraries
  172. # ---------------------------------------------------
  173. .PHONY: trts
  174. trts:
  175. $(MAKE) -C trts/
  176. .PHONY: tcrypto
  177. tcrypto:
  178. $(MAKE) -C tlibcrypto/
  179. .PHONY: tkey_exchange
  180. tkey_exchange: edger8r
  181. $(MAKE) -C tkey_exchange
  182. .PHONY: tcmalloc
  183. tcmalloc:
  184. $(MAKE) -C gperftools/
  185. .PHONY: tprotected_fs
  186. tprotected_fs: edger8r
  187. $(MAKE) -C protected_fs/sgx_tprotected_fs
  188. # ---------------------------------------------------
  189. # Untrusted libraries
  190. # ---------------------------------------------------
  191. .PHONY: ukey_exchange
  192. ukey_exchange:
  193. $(MAKE) -C ukey_exchange
  194. .PHONY: uprotected_fs
  195. uprotected_fs: edger8r
  196. $(MAKE) -C protected_fs/sgx_uprotected_fs
  197. .PHONY: ptrace
  198. ptrace:
  199. $(MAKE) -C debugger_interface/linux/
  200. .PHONY: sample_crypto
  201. sample_crypto:
  202. $(MAKE) -C sample_libcrypto
  203. # ---------------------------------------------------
  204. # standalone, untrusted libraries
  205. # ---------------------------------------------------
  206. .PHONY: libcapable
  207. libcapable:
  208. $(MAKE) -C libcapable/linux/
  209. # ---------------------------------------------------
  210. # simualtion libraries and tools
  211. # ---------------------------------------------------
  212. .PHONY: simulation
  213. simulation: edger8r
  214. $(MAKE) -C simulation/
  215. # ---------------------------------------------------
  216. # tools
  217. # ---------------------------------------------------
  218. .PHONY: signtool
  219. signtool:
  220. $(MAKE) -C sign_tool/SignTool/
  221. .PHONY: edger8r
  222. edger8r:
  223. $(MAKE) -C edger8r/linux/
  224. $(BUILD_DIR):
  225. $(MKDIR) $@
  226. .PHONY: clean
  227. clean:
  228. $(MAKE) -C tlibc/ clean
  229. $(MAKE) -C tlibthread/ clean
  230. $(MAKE) -C compiler-rt/ clean
  231. $(MAKE) -C cpprt clean
  232. $(MAKE) -C tlibstdcxx/ clean
  233. $(MAKE) -C tlibcxx/ clean
  234. $(MAKE) -C tseal/linux/ clean
  235. $(MAKE) -C selib/linux/ clean
  236. $(MAKE) -C tae_service/ clean
  237. $(MAKE) -C trts/ clean
  238. $(MAKE) -C tsetjmp/ clean
  239. $(MAKE) -C tsafecrt/ clean
  240. $(MAKE) -C gperftools/ clean
  241. $(MAKE) -C tlibcrypto/ clean
  242. $(MAKE) -C tkey_exchange/ clean
  243. $(MAKE) -C ukey_exchange/ clean
  244. $(MAKE) -C protected_fs/sgx_tprotected_fs/ clean
  245. $(MAKE) -C protected_fs/sgx_uprotected_fs/ clean
  246. $(MAKE) -C debugger_interface/linux/ clean
  247. $(MAKE) -C sample_libcrypto/ clean
  248. $(MAKE) -C libcapable/linux/ clean
  249. $(MAKE) -C simulation/ clean
  250. $(MAKE) -C sign_tool/SignTool clean
  251. $(MAKE) -C edger8r/linux clean
  252. @$(RM) $(LIBTLIBC) $(LIBTLIBCXX) $(LIBTSE)
  253. @$(RM) $(BUILD_DIR)/STLport_Changes_SGX.txt
  254. @$(RM) $(BUILD_DIR)/libc++_Changes_SGX.txt