CMakeLists.txt 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533
  1. include_directories(../include)
  2. if(NOT OPENSSL_NO_ASM)
  3. if(UNIX)
  4. if(${ARCH} STREQUAL "aarch64")
  5. # The "armx" Perl scripts look for "64" in the style argument
  6. # in order to decide whether to generate 32- or 64-bit asm.
  7. if(APPLE)
  8. set(PERLASM_STYLE ios64)
  9. else()
  10. set(PERLASM_STYLE linux64)
  11. endif()
  12. elseif(${ARCH} STREQUAL "arm")
  13. if(APPLE)
  14. set(PERLASM_STYLE ios32)
  15. else()
  16. set(PERLASM_STYLE linux32)
  17. endif()
  18. elseif(${ARCH} STREQUAL "ppc64le")
  19. set(PERLASM_STYLE linux64le)
  20. else()
  21. if(${ARCH} STREQUAL "x86")
  22. set(PERLASM_FLAGS "-fPIC -DOPENSSL_IA32_SSE2")
  23. endif()
  24. if(APPLE)
  25. set(PERLASM_STYLE macosx)
  26. else()
  27. set(PERLASM_STYLE elf)
  28. endif()
  29. endif()
  30. set(ASM_EXT S)
  31. enable_language(ASM)
  32. set(CMAKE_ASM_FLAGS "${CMAKE_ASM_FLAGS} -Wa,--noexecstack")
  33. # Clang's integerated assembler does not support debug symbols.
  34. if(NOT CMAKE_ASM_COMPILER_ID MATCHES "Clang")
  35. set(CMAKE_ASM_FLAGS "${CMAKE_ASM_FLAGS} -Wa,-g")
  36. endif()
  37. # CMake does not add -isysroot and -arch flags to assembly.
  38. if(APPLE)
  39. if(CMAKE_OSX_SYSROOT)
  40. set(CMAKE_ASM_FLAGS "${CMAKE_ASM_FLAGS} -isysroot \"${CMAKE_OSX_SYSROOT}\"")
  41. endif()
  42. foreach(arch ${CMAKE_OSX_ARCHITECTURES})
  43. set(CMAKE_ASM_FLAGS "${CMAKE_ASM_FLAGS} -arch ${arch}")
  44. endforeach()
  45. endif()
  46. else()
  47. if(${ARCH} STREQUAL "x86_64")
  48. set(PERLASM_STYLE nasm)
  49. else()
  50. set(PERLASM_STYLE win32n)
  51. set(PERLASM_FLAGS "-DOPENSSL_IA32_SSE2")
  52. endif()
  53. set(CMAKE_ASM_NASM_FLAGS "${CMAKE_ASM_NASM_FLAGS} -gcv8")
  54. # On Windows, we use the NASM output, specifically built with Yasm.
  55. set(ASM_EXT asm)
  56. enable_language(ASM_NASM)
  57. endif()
  58. endif()
  59. function(perlasm dest src)
  60. get_filename_component(dir ${dest} DIRECTORY)
  61. if ("${dir}" STREQUAL "")
  62. set(dir ".")
  63. endif()
  64. add_custom_command(
  65. OUTPUT ${dest}
  66. COMMAND ${CMAKE_COMMAND} -E make_directory ${dir}
  67. COMMAND ${PERL_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/${src} ${PERLASM_STYLE} ${PERLASM_FLAGS} ${ARGN} ${dest}
  68. DEPENDS
  69. ${src}
  70. ${PROJECT_SOURCE_DIR}/crypto/perlasm/arm-xlate.pl
  71. ${PROJECT_SOURCE_DIR}/crypto/perlasm/ppc-xlate.pl
  72. ${PROJECT_SOURCE_DIR}/crypto/perlasm/x86_64-xlate.pl
  73. ${PROJECT_SOURCE_DIR}/crypto/perlasm/x86asm.pl
  74. ${PROJECT_SOURCE_DIR}/crypto/perlasm/x86gas.pl
  75. ${PROJECT_SOURCE_DIR}/crypto/perlasm/x86masm.pl
  76. ${PROJECT_SOURCE_DIR}/crypto/perlasm/x86nasm.pl
  77. WORKING_DIRECTORY .
  78. )
  79. endfunction()
  80. add_subdirectory(fipsmodule)
  81. add_subdirectory(test)
  82. if(FIPS_DELOCATE OR FIPS_SHARED)
  83. SET_SOURCE_FILES_PROPERTIES(fipsmodule/bcm.o PROPERTIES EXTERNAL_OBJECT true)
  84. SET_SOURCE_FILES_PROPERTIES(fipsmodule/bcm.o PROPERTIES GENERATED true)
  85. set(
  86. CRYPTO_FIPS_OBJECTS
  87. fipsmodule/bcm.o
  88. )
  89. endif()
  90. if(${ARCH} STREQUAL "arm")
  91. set(
  92. CRYPTO_ARCH_SOURCES
  93. chacha/chacha-armv4.${ASM_EXT}
  94. curve25519/asm/x25519-asm-arm.S
  95. poly1305/poly1305_arm_asm.S
  96. test/trampoline-armv4.${ASM_EXT}
  97. )
  98. endif()
  99. if(${ARCH} STREQUAL "aarch64")
  100. set(
  101. CRYPTO_ARCH_SOURCES
  102. chacha/chacha-armv8.${ASM_EXT}
  103. test/trampoline-armv8.${ASM_EXT}
  104. third_party/sike/asm/fp-armv8.${ASM_EXT}
  105. )
  106. endif()
  107. if(${ARCH} STREQUAL "x86")
  108. set(
  109. CRYPTO_ARCH_SOURCES
  110. chacha/chacha-x86.${ASM_EXT}
  111. test/trampoline-x86.${ASM_EXT}
  112. )
  113. endif()
  114. if(${ARCH} STREQUAL "x86_64")
  115. set(
  116. CRYPTO_ARCH_SOURCES
  117. chacha/chacha-x86_64.${ASM_EXT}
  118. cipher_extra/aes128gcmsiv-x86_64.${ASM_EXT}
  119. cipher_extra/chacha20_poly1305_x86_64.${ASM_EXT}
  120. hrss/asm/poly_rq_mul.S
  121. test/trampoline-x86_64.${ASM_EXT}
  122. third_party/sike/asm/fp-x86_64.${ASM_EXT}
  123. )
  124. endif()
  125. perlasm(chacha/chacha-armv4.${ASM_EXT} chacha/asm/chacha-armv4.pl)
  126. perlasm(chacha/chacha-armv8.${ASM_EXT} chacha/asm/chacha-armv8.pl)
  127. perlasm(chacha/chacha-x86.${ASM_EXT} chacha/asm/chacha-x86.pl)
  128. perlasm(chacha/chacha-x86_64.${ASM_EXT} chacha/asm/chacha-x86_64.pl)
  129. perlasm(cipher_extra/aes128gcmsiv-x86_64.${ASM_EXT} cipher_extra/asm/aes128gcmsiv-x86_64.pl)
  130. perlasm(cipher_extra/chacha20_poly1305_x86_64.${ASM_EXT} cipher_extra/asm/chacha20_poly1305_x86_64.pl)
  131. perlasm(third_party/sike/asm/fp-x86_64.${ASM_EXT} ../third_party/sike/asm/fp-x86_64.pl)
  132. perlasm(third_party/sike/asm/fp-armv8.${ASM_EXT} ../third_party/sike/asm/fp-armv8.pl)
  133. perlasm(test/trampoline-armv4.${ASM_EXT} test/asm/trampoline-armv4.pl)
  134. perlasm(test/trampoline-armv8.${ASM_EXT} test/asm/trampoline-armv8.pl)
  135. perlasm(test/trampoline-x86.${ASM_EXT} test/asm/trampoline-x86.pl)
  136. perlasm(test/trampoline-x86_64.${ASM_EXT} test/asm/trampoline-x86_64.pl)
  137. add_custom_command(
  138. OUTPUT err_data.c
  139. COMMAND ${GO_EXECUTABLE} run err_data_generate.go > ${CMAKE_CURRENT_BINARY_DIR}/err_data.c
  140. DEPENDS
  141. err/err_data_generate.go
  142. err/asn1.errordata
  143. err/bio.errordata
  144. err/bn.errordata
  145. err/cipher.errordata
  146. err/conf.errordata
  147. err/dh.errordata
  148. err/digest.errordata
  149. err/dsa.errordata
  150. err/ecdh.errordata
  151. err/ecdsa.errordata
  152. err/ec.errordata
  153. err/engine.errordata
  154. err/evp.errordata
  155. err/hkdf.errordata
  156. err/obj.errordata
  157. err/pem.errordata
  158. err/pkcs7.errordata
  159. err/pkcs8.errordata
  160. err/rsa.errordata
  161. err/ssl.errordata
  162. err/x509.errordata
  163. err/x509v3.errordata
  164. WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/err
  165. )
  166. add_library(
  167. crypto
  168. asn1/a_bitstr.c
  169. asn1/a_bool.c
  170. asn1/a_d2i_fp.c
  171. asn1/a_dup.c
  172. asn1/a_enum.c
  173. asn1/a_gentm.c
  174. asn1/a_i2d_fp.c
  175. asn1/a_int.c
  176. asn1/a_mbstr.c
  177. asn1/a_object.c
  178. asn1/a_octet.c
  179. asn1/a_print.c
  180. asn1/a_strnid.c
  181. asn1/a_time.c
  182. asn1/a_type.c
  183. asn1/a_utctm.c
  184. asn1/a_utf8.c
  185. asn1/asn1_lib.c
  186. asn1/asn1_par.c
  187. asn1/asn_pack.c
  188. asn1/f_enum.c
  189. asn1/f_int.c
  190. asn1/f_string.c
  191. asn1/tasn_dec.c
  192. asn1/tasn_enc.c
  193. asn1/tasn_fre.c
  194. asn1/tasn_new.c
  195. asn1/tasn_typ.c
  196. asn1/tasn_utl.c
  197. asn1/time_support.c
  198. base64/base64.c
  199. bio/bio.c
  200. bio/bio_mem.c
  201. bio/connect.c
  202. bio/fd.c
  203. bio/file.c
  204. bio/hexdump.c
  205. bio/pair.c
  206. bio/printf.c
  207. bio/socket.c
  208. bio/socket_helper.c
  209. bn_extra/bn_asn1.c
  210. bn_extra/convert.c
  211. buf/buf.c
  212. bytestring/asn1_compat.c
  213. bytestring/ber.c
  214. bytestring/cbb.c
  215. bytestring/cbs.c
  216. bytestring/unicode.c
  217. chacha/chacha.c
  218. cipher_extra/cipher_extra.c
  219. cipher_extra/derive_key.c
  220. cipher_extra/e_aesccm.c
  221. cipher_extra/e_aesctrhmac.c
  222. cipher_extra/e_aesgcmsiv.c
  223. cipher_extra/e_chacha20poly1305.c
  224. cipher_extra/e_null.c
  225. cipher_extra/e_rc2.c
  226. cipher_extra/e_rc4.c
  227. cipher_extra/e_tls.c
  228. cipher_extra/tls_cbc.c
  229. cmac/cmac.c
  230. conf/conf.c
  231. cpu-aarch64-fuchsia.c
  232. cpu-aarch64-linux.c
  233. cpu-arm-linux.c
  234. cpu-arm.c
  235. cpu-intel.c
  236. cpu-ppc64le.c
  237. crypto.c
  238. curve25519/spake25519.c
  239. dh/dh.c
  240. dh/params.c
  241. dh/check.c
  242. dh/dh_asn1.c
  243. digest_extra/digest_extra.c
  244. dsa/dsa.c
  245. dsa/dsa_asn1.c
  246. ecdh_extra/ecdh_extra.c
  247. ecdsa_extra/ecdsa_asn1.c
  248. ec_extra/ec_asn1.c
  249. err/err.c
  250. err_data.c
  251. engine/engine.c
  252. evp/digestsign.c
  253. evp/evp.c
  254. evp/evp_asn1.c
  255. evp/evp_ctx.c
  256. evp/p_dsa_asn1.c
  257. evp/p_ec.c
  258. evp/p_ec_asn1.c
  259. evp/p_ed25519.c
  260. evp/p_ed25519_asn1.c
  261. evp/p_rsa.c
  262. evp/p_rsa_asn1.c
  263. evp/p_x25519.c
  264. evp/p_x25519_asn1.c
  265. evp/pbkdf.c
  266. evp/print.c
  267. evp/scrypt.c
  268. evp/sign.c
  269. ex_data.c
  270. hkdf/hkdf.c
  271. hrss/hrss.c
  272. lhash/lhash.c
  273. mem.c
  274. obj/obj.c
  275. obj/obj_xref.c
  276. pem/pem_all.c
  277. pem/pem_info.c
  278. pem/pem_lib.c
  279. pem/pem_oth.c
  280. pem/pem_pk8.c
  281. pem/pem_pkey.c
  282. pem/pem_x509.c
  283. pem/pem_xaux.c
  284. pkcs7/pkcs7.c
  285. pkcs7/pkcs7_x509.c
  286. pkcs8/pkcs8.c
  287. pkcs8/pkcs8_x509.c
  288. pkcs8/p5_pbev2.c
  289. poly1305/poly1305.c
  290. poly1305/poly1305_arm.c
  291. poly1305/poly1305_vec.c
  292. pool/pool.c
  293. rand_extra/deterministic.c
  294. rand_extra/forkunsafe.c
  295. rand_extra/fuchsia.c
  296. rand_extra/rand_extra.c
  297. rand_extra/windows.c
  298. rc4/rc4.c
  299. refcount_c11.c
  300. refcount_lock.c
  301. rsa_extra/rsa_asn1.c
  302. rsa_extra/rsa_print.c
  303. stack/stack.c
  304. siphash/siphash.c
  305. thread.c
  306. thread_none.c
  307. thread_pthread.c
  308. thread_win.c
  309. x509/a_digest.c
  310. x509/a_sign.c
  311. x509/a_strex.c
  312. x509/a_verify.c
  313. x509/algorithm.c
  314. x509/asn1_gen.c
  315. x509/by_dir.c
  316. x509/by_file.c
  317. x509/i2d_pr.c
  318. x509/rsa_pss.c
  319. x509/t_crl.c
  320. x509/t_req.c
  321. x509/t_x509.c
  322. x509/t_x509a.c
  323. x509/x509.c
  324. x509/x509_att.c
  325. x509/x509_cmp.c
  326. x509/x509_d2.c
  327. x509/x509_def.c
  328. x509/x509_ext.c
  329. x509/x509_lu.c
  330. x509/x509_obj.c
  331. x509/x509_r2x.c
  332. x509/x509_req.c
  333. x509/x509_set.c
  334. x509/x509_trs.c
  335. x509/x509_txt.c
  336. x509/x509_v3.c
  337. x509/x509_vfy.c
  338. x509/x509_vpm.c
  339. x509/x509cset.c
  340. x509/x509name.c
  341. x509/x509rset.c
  342. x509/x509spki.c
  343. x509/x_algor.c
  344. x509/x_all.c
  345. x509/x_attrib.c
  346. x509/x_crl.c
  347. x509/x_exten.c
  348. x509/x_info.c
  349. x509/x_name.c
  350. x509/x_pkey.c
  351. x509/x_pubkey.c
  352. x509/x_req.c
  353. x509/x_sig.c
  354. x509/x_spki.c
  355. x509/x_val.c
  356. x509/x_x509.c
  357. x509/x_x509a.c
  358. x509v3/pcy_cache.c
  359. x509v3/pcy_data.c
  360. x509v3/pcy_lib.c
  361. x509v3/pcy_map.c
  362. x509v3/pcy_node.c
  363. x509v3/pcy_tree.c
  364. x509v3/v3_akey.c
  365. x509v3/v3_akeya.c
  366. x509v3/v3_alt.c
  367. x509v3/v3_bcons.c
  368. x509v3/v3_bitst.c
  369. x509v3/v3_conf.c
  370. x509v3/v3_cpols.c
  371. x509v3/v3_crld.c
  372. x509v3/v3_enum.c
  373. x509v3/v3_extku.c
  374. x509v3/v3_genn.c
  375. x509v3/v3_ia5.c
  376. x509v3/v3_info.c
  377. x509v3/v3_int.c
  378. x509v3/v3_lib.c
  379. x509v3/v3_ncons.c
  380. x509v3/v3_ocsp.c
  381. x509v3/v3_pci.c
  382. x509v3/v3_pcia.c
  383. x509v3/v3_pcons.c
  384. x509v3/v3_pku.c
  385. x509v3/v3_pmaps.c
  386. x509v3/v3_prn.c
  387. x509v3/v3_purp.c
  388. x509v3/v3_skey.c
  389. x509v3/v3_sxnet.c
  390. x509v3/v3_utl.c
  391. ../third_party/fiat/curve25519.c
  392. ../third_party/sike/fpx.c
  393. ../third_party/sike/isogeny.c
  394. ../third_party/sike/curve_params.c
  395. ../third_party/sike/sike.c
  396. ../third_party/sike/asm/fp_generic.c
  397. $<TARGET_OBJECTS:fipsmodule>
  398. ${CRYPTO_ARCH_SOURCES}
  399. ${CRYPTO_FIPS_OBJECTS}
  400. )
  401. if(FIPS_SHARED)
  402. # Rewrite libcrypto.so to inject the correct module hash value. This assumes
  403. # UNIX-style library naming, but we only support FIPS mode on Linux anyway.
  404. add_custom_command(
  405. TARGET crypto POST_BUILD
  406. COMMAND ${GO_EXECUTABLE} run
  407. ${CMAKE_CURRENT_SOURCE_DIR}/../util/fipstools/inject_hash/inject_hash.go
  408. -o libcrypto.so -in-object libcrypto.so
  409. # The DEPENDS argument to a POST_BUILD rule appears to be ignored. Thus
  410. # go_executable isn't used (as it doesn't get built), but we list this
  411. # dependency anyway in case it starts working in some CMake version.
  412. DEPENDS ../util/fipstools/inject_hash/inject_hash.go
  413. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  414. )
  415. endif()
  416. add_dependencies(crypto global_target)
  417. if(FIPS_DELOCATE OR FIPS_SHARED)
  418. add_dependencies(crypto bcm_o_target)
  419. endif()
  420. SET_TARGET_PROPERTIES(crypto PROPERTIES LINKER_LANGUAGE C)
  421. if(NOT MSVC AND NOT ANDROID)
  422. target_link_libraries(crypto pthread)
  423. endif()
  424. # Every target depends on crypto, so we add libcxx as a dependency here to
  425. # simplify injecting it everywhere.
  426. if(USE_CUSTOM_LIBCXX)
  427. target_link_libraries(crypto libcxx)
  428. endif()
  429. add_executable(
  430. crypto_test
  431. abi_self_test.cc
  432. asn1/asn1_test.cc
  433. base64/base64_test.cc
  434. buf/buf_test.cc
  435. bio/bio_test.cc
  436. bytestring/bytestring_test.cc
  437. chacha/chacha_test.cc
  438. cipher_extra/aead_test.cc
  439. cipher_extra/cipher_test.cc
  440. cmac/cmac_test.cc
  441. compiler_test.cc
  442. constant_time_test.cc
  443. cpu-arm-linux_test.cc
  444. curve25519/ed25519_test.cc
  445. curve25519/spake25519_test.cc
  446. curve25519/x25519_test.cc
  447. ecdh_extra/ecdh_test.cc
  448. dh/dh_test.cc
  449. digest_extra/digest_test.cc
  450. dsa/dsa_test.cc
  451. err/err_test.cc
  452. evp/evp_extra_test.cc
  453. evp/evp_test.cc
  454. evp/pbkdf_test.cc
  455. evp/scrypt_test.cc
  456. fipsmodule/aes/aes_test.cc
  457. fipsmodule/bn/bn_test.cc
  458. fipsmodule/ec/ec_test.cc
  459. fipsmodule/ec/p256-x86_64_test.cc
  460. fipsmodule/ecdsa/ecdsa_test.cc
  461. fipsmodule/md5/md5_test.cc
  462. fipsmodule/modes/gcm_test.cc
  463. fipsmodule/rand/ctrdrbg_test.cc
  464. fipsmodule/sha/sha_test.cc
  465. hkdf/hkdf_test.cc
  466. hmac_extra/hmac_test.cc
  467. hrss/hrss_test.cc
  468. impl_dispatch_test.cc
  469. lhash/lhash_test.cc
  470. obj/obj_test.cc
  471. pem/pem_test.cc
  472. pkcs7/pkcs7_test.cc
  473. pkcs8/pkcs8_test.cc
  474. pkcs8/pkcs12_test.cc
  475. poly1305/poly1305_test.cc
  476. pool/pool_test.cc
  477. rand_extra/rand_test.cc
  478. refcount_test.cc
  479. rsa_extra/rsa_test.cc
  480. self_test.cc
  481. stack/stack_test.cc
  482. siphash/siphash_test.cc
  483. test/file_test_gtest.cc
  484. thread_test.cc
  485. x509/x509_test.cc
  486. x509/x509_time_test.cc
  487. x509v3/tab_test.cc
  488. x509v3/v3name_test.cc
  489. ../third_party/sike/sike_test.cc
  490. $<TARGET_OBJECTS:crypto_test_data>
  491. $<TARGET_OBJECTS:boringssl_gtest_main>
  492. )
  493. add_dependencies(crypto_test global_target)
  494. target_link_libraries(crypto_test test_support_lib boringssl_gtest crypto)
  495. if(WIN32)
  496. target_link_libraries(crypto_test ws2_32)
  497. endif()
  498. add_dependencies(all_tests crypto_test)