functions.cmake 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943
  1. function(override_cache VAR VAL)
  2. get_property(VAR_STRINGS CACHE ${VAR} PROPERTY STRINGS)
  3. LIST(FIND VAR_STRINGS ${VAL} CK)
  4. if(-1 EQUAL ${CK})
  5. message(SEND_ERROR
  6. "\"${VAL}\" is not valid override value for \"${VAR}\"."
  7. " Please select value from \"${VAR_STRINGS}\"\n")
  8. endif()
  9. set_property(CACHE ${VAR} PROPERTY VALUE ${VAL})
  10. endfunction()
  11. function(add_option NAME HELP_STRING DEFAULT VALUES)
  12. # Set the default value for the option.
  13. set(${NAME} ${DEFAULT} CACHE STRING ${HELP_STRING})
  14. # Set the list of allowed values for the option.
  15. set_property(CACHE ${NAME} PROPERTY STRINGS ${VALUES})
  16. if(DEFINED ${NAME})
  17. list(FIND VALUES ${${NAME}} IDX)
  18. #
  19. # If the given value isn't in the list of allowed values for the option,
  20. # reduce it to yes/no according to CMake's "if" logic:
  21. # https://cmake.org/cmake/help/latest/command/if.html#basic-expressions
  22. #
  23. # This has no functional impact; it just makes the settings in
  24. # CMakeCache.txt and cmake-gui easier to read.
  25. #
  26. if (${IDX} EQUAL -1)
  27. if(${${NAME}})
  28. override_cache(${NAME} "yes")
  29. else()
  30. override_cache(${NAME} "no")
  31. endif()
  32. endif()
  33. endif()
  34. endfunction()
  35. function(generate_build_flags)
  36. set(BUILD_DISTRO ${WOLFSSL_DISTRO} PARENT_SCOPE)
  37. set(BUILD_ALL ${WOLFSSL_ALL} PARENT_SCOPE)
  38. if(WOLFSSL_TLS13 OR WOLFSSL_USER_SETTINGS)
  39. set(BUILD_TLS13 "yes" PARENT_SCOPE)
  40. endif()
  41. if(WOLFSSL_DTLS13 OR WOLFSSL_USER_SETTINGS)
  42. set(BUILD_DTLS13 "yes" PARENT_SCOPE)
  43. endif()
  44. if(WOLFSSL_QUIC)
  45. set(BUILD_QUIC "yes" PARENT_SCOPE)
  46. endif()
  47. if(WOLFSSL_RNG OR WOLFSSL_USER_SETTINGS)
  48. set(BUILD_RNG "yes" PARENT_SCOPE)
  49. endif()
  50. if(WOLFSSL_SCTP OR WOLFSSL_USER_SETTINGS)
  51. set(BUILD_SCTP "yes" PARENT_SCOPE)
  52. endif()
  53. if(WOLFSSL_DTLS_CID OR WOLFSSL_USER_SETTINGS OR WOLFSSL_DTLS)
  54. set(BUILD_DTLS_COMMON "yes" PARENT_SCOPE)
  55. endif()
  56. set(BUILD_MCAST ${WOLFSSL_MCAST} PARENT_SCOPE)
  57. set(BUILD_IPV6 ${WOLFSSL_IPV6} PARENT_SCOPE)
  58. set(BUILD_LEAN_PSK ${WOLFSSL_LEAN_PSK} PARENT_SCOPE)
  59. set(BUILD_LEAN_TLS ${WOLFSSL_LEAN_TLS} PARENT_SCOPE)
  60. set(BUILD_LOWMEM ${WOLFSSL_LOWRESOURCE} PARENT_SCOPE)
  61. set(BUILD_PKCALLBACKS ${WOLFSSL_PKCALLBACKS} PARENT_SCOPE)
  62. set(BUILD_CRYPTOAUTHLIB ${WOLFSSL_CRYPTOAUTHLIB} PARENT_SCOPE)
  63. if(WOLFSSL_SNIFFER OR WOLFSSL_USER_SETTINGS)
  64. set(BUILD_SNIFFER "yes" PARENT_SCOPE)
  65. endif()
  66. set(BUILD_SNIFFTEST ${WOLFSSL_SNIFFTEST} PARENT_SCOPE)
  67. if(WOLFSSL_AESGCM OR WOLFSSL_USER_SETTINGS)
  68. set(BUILD_AESGCM "yes" PARENT_SCOPE)
  69. endif()
  70. if(WOLFSSL_AESCCM OR WOLFSSL_USER_SETTINGS)
  71. set(BUILD_AESCCM "yes" PARENT_SCOPE)
  72. endif()
  73. set(BUILD_ARM_ASM ${WOLFSSL_ARM_ASM} PARENT_SCOPE)
  74. set(BUILD_XILINX ${WOLFSSL_XILINX} PARENT_SCOPE)
  75. set(BUILD_AESNI ${WOLFSSL_AESNI} PARENT_SCOPE)
  76. set(BUILD_INTEL_ASM ${WOLFSSL_INTEL_ASM} PARENT_SCOPE)
  77. set(BUILD_AFALG ${WOLFSSL_AFALG} PARENT_SCOPE)
  78. set(BUILD_DEVCRYPTO ${WOLFSSL_DEVCRYPTO} PARENT_SCOPE)
  79. if(WOLFSSL_CAMELLIA OR WOLFSSL_USER_SETTINGS)
  80. set(BUILD_CAMELLIA "yes" PARENT_SCOPE)
  81. endif()
  82. if(WOLFSSL_MD2 OR WOLFSSL_USER_SETTINGS)
  83. set(BUILD_MD2 "yes" PARENT_SCOPE)
  84. endif()
  85. if(WOLFSSL_RIPEMD OR WOLFSSL_USER_SETTINGS)
  86. set(BUILD_RIPEMD "yes" PARENT_SCOPE)
  87. endif()
  88. if(WOLFSSL_BLAKE2 OR WOLFSSL_USER_SETTINGS)
  89. set(BUILD_BLAKE2 "yes" PARENT_SCOPE)
  90. endif()
  91. if(WOLFSSL_BLAKE2S OR WOLFSSL_USER_SETTINGS)
  92. set(BUILD_BLAKE2S "yes" PARENT_SCOPE)
  93. endif()
  94. if(WOLFSSL_SHA512 OR WOLFSSL_SHA384 OR WOLFSSL_USER_SETTINGS)
  95. set(BUILD_SHA512 "yes" PARENT_SCOPE)
  96. endif()
  97. if(WOLFSSL_DSA OR WOLFSSL_USER_SETTINGS)
  98. set(BUILD_DSA "yes" PARENT_SCOPE)
  99. endif()
  100. if(WOLFSSL_ECC OR WOLFSSL_USER_SETTINGS)
  101. set(BUILD_ECC "yes" PARENT_SCOPE)
  102. endif()
  103. if(WOLFSSL_ED25519 OR WOLFSSL_USER_SETTINGS)
  104. set(BUILD_ED25519 "yes" PARENT_SCOPE)
  105. endif()
  106. set(BUILD_ED25519_SMALL ${WOLFSSL_ED25519_SMALL} PARENT_SCOPE)
  107. if(WOLFSSL_FEMATH OR WOLFSSL_USER_SETTINGS)
  108. set(BUILD_FEMATH "yes" PARENT_SCOPE)
  109. endif()
  110. if(WOLFSSL_GEMATH OR WOLFSSL_USER_SETTINGS)
  111. set(BUILD_GEMATH "yes" PARENT_SCOPE)
  112. endif()
  113. if(WOLFSSL_CURVE25519 OR WOLFSSL_USER_SETTINGS)
  114. set(BUILD_CURVE25519 "yes" PARENT_SCOPE)
  115. endif()
  116. set(BUILD_CURVE25519_SMALL ${WOLFSSL_CURVE25519_SMALL} PARENT_SCOPE)
  117. if(WOLFSSL_ED448 OR WOLFSSL_USER_SETTINGS)
  118. set(BUILD_ED448 "yes" PARENT_SCOPE)
  119. endif()
  120. set(BUILD_ED448_SMALL ${WOLFSSL_ED448_SMALL} PARENT_SCOPE)
  121. if(WOLFSSL_FE448 OR WOLFSSL_USER_SETTINGS)
  122. set(BUILD_FE448 "yes" PARENT_SCOPE)
  123. endif()
  124. if(WOLFSSL_GE448 OR WOLFSSL_USER_SETTINGS)
  125. set(BUILD_GE448 "yes" PARENT_SCOPE)
  126. endif()
  127. if(WOLFSSL_CURVE448 OR WOLFSSL_USER_SETTINGS)
  128. set(BUILD_CURVE448 "yes" PARENT_SCOPE)
  129. endif()
  130. if(WOLFSSL_CURVE448_SMALL OR WOLFSSL_USER_SETTINGS)
  131. set(BUILD_CURVE448_SMALL "yes" PARENT_SCOPE)
  132. endif()
  133. if(WOLFSSL_MEMORY OR WOLFSSL_USER_SETTINGS)
  134. set(BUILD_MEMORY "yes" PARENT_SCOPE)
  135. endif()
  136. if(WOLFSSL_RSA OR WOLFSSL_USER_SETTINGS)
  137. set(BUILD_RSA "yes" PARENT_SCOPE)
  138. endif()
  139. if(WOLFSSL_DH OR WOLFSSL_USER_SETTINGS)
  140. set(BUILD_DH "yes" PARENT_SCOPE)
  141. endif()
  142. if(WOLFSSL_ASN OR WOLFSSL_USER_SETTINGS)
  143. set(BUILD_ASN "yes" PARENT_SCOPE)
  144. endif()
  145. if(WOLFSSL_AES OR WOLFSSL_USER_SETTINGS)
  146. set(BUILD_AES "yes" PARENT_SCOPE)
  147. endif()
  148. if(WOLFSSL_CODING OR WOLFSSL_USER_SETTINGS)
  149. set(BUILD_CODING "yes" PARENT_SCOPE)
  150. endif()
  151. if(WOLFSSL_ARC4 OR WOLFSSL_USER_SETTINGS)
  152. set(BUILD_RC4 "yes" PARENT_SCOPE)
  153. endif()
  154. if(WOLFSSL_MD5 OR WOLFSSL_USER_SETTINGS)
  155. set(BUILD_MD5 "yes" PARENT_SCOPE)
  156. endif()
  157. if(WOLFSSL_SHA OR WOLFSSL_USER_SETTINGS)
  158. set(BUILD_SHA "yes" PARENT_SCOPE)
  159. endif()
  160. set(BUILD_FIPS ${WOLFSSL_FIPS} PARENT_SCOPE)
  161. if("${FIPS_VERSION}" STREQUAL "v1")
  162. set(BUILD_FIPS_V1 "yes" PARENT_SCOPE)
  163. endif()
  164. if("${FIPS_VERSION}" STREQUAL "v2")
  165. set(BUILD_FIPS_V2 "yes" PARENT_SCOPE)
  166. endif()
  167. if("${FIPS_VERSION}" STREQUAL "rand")
  168. set(BUILD_FIPS_RAND "yes" PARENT_SCOPE)
  169. endif()
  170. if("${FIPS_VERSION}" STREQUAL "v5")
  171. set(BUILD_FIPS_V5 "yes" PARENT_SCOPE)
  172. endif()
  173. set(BUILD_FIPS_READY ${FIPS_READY} PARENT_SCOPE)
  174. if(WOLFSSL_CMAC OR WOLFSSL_USER_SETTINGS)
  175. set(BUILD_CMAC "yes" PARENT_SCOPE)
  176. endif()
  177. set(BUILD_SELFTEST ${WOLFSSL_SELFTEST} PARENT_SCOPE)
  178. if(WOLFSSL_SHA224 OR WOLFSSL_USER_SETTINGS)
  179. set(BUILD_SHA224 "yes" PARENT_SCOPE)
  180. endif()
  181. if(WOLFSSL_SHA3 OR WOLFSSL_USER_SETTINGS)
  182. set(BUILD_SHA3 "yes" PARENT_SCOPE)
  183. endif()
  184. if(WOLFSSL_POLY1305 OR WOLFSSL_USER_SETTINGS)
  185. set(BUILD_POLY1305 "yes" PARENT_SCOPE)
  186. endif()
  187. if(WOLFSSL_CHACHA OR WOLFSSL_USER_SETTINGS)
  188. set(BUILD_CHACHA "yes" PARENT_SCOPE)
  189. endif()
  190. if(WOLFSSL_XCHACHA OR WOLFSSL_USER_SETTINGS)
  191. set(BUILD_XCHACHA "yes" PARENT_SCOPE)
  192. endif()
  193. if(WOLFSSL_OQS OR WOLFSSL_USER_SETTINGS)
  194. set(BUILD_FALCON "yes" PARENT_SCOPE)
  195. set(BUILD_SPHINCS "yes" PARENT_SCOPE)
  196. set(BUILD_DILITHIUM "yes" PARENT_SCOPE)
  197. set(BUILD_EXT_KYBER "yes" PARENT_SCOPE)
  198. endif()
  199. if(WOLFSSL_ARIA OR WOLFSSL_USER_SETTINGS)
  200. message(STATUS "ARIA functions.cmake found WOLFSSL_ARIA")
  201. # we cannot actually build, as we only have pre-compiled bin
  202. set(BUILD_ARIA "yes" PARENT_SCOPE)
  203. endif()
  204. set(BUILD_INLINE ${WOLFSSL_INLINE} PARENT_SCOPE)
  205. if(WOLFSSL_OCSP OR WOLFSSL_USER_SETTINGS)
  206. set(BUILD_OCSP "yes" PARENT_SCOPE)
  207. endif()
  208. set(BUILD_OCSP_STAPLING ${WOLFSSL_OCSPSTAPLING} PARENT_SCOPE)
  209. set(BUILD_OCSP_STAPLING_V2 ${WOLFSSL_OCSPSTAPLING_V2} PARENT_SCOPE)
  210. if(WOLFSSL_CRL OR WOLFSSL_USER_SETTINGS)
  211. set(BUILD_CRL "yes" PARENT_SCOPE)
  212. endif()
  213. if(WOLFSSL_CRL_MONITOR)
  214. set(BUILD_CRL_MONITOR "yes" PARENT_SCOPE)
  215. endif()
  216. set(BUILD_QUIC ${WOLFSSL_QUIC} PARENT_SCOPE)
  217. set(BUILD_USER_RSA ${WOLFSSL_USER_RSA} PARENT_SCOPE)
  218. set(BUILD_USER_CRYPTO ${WOLFSSL_USER_CRYPTO} PARENT_SCOPE)
  219. set(BUILD_WNR ${WOLFSSL_WNR} PARENT_SCOPE)
  220. if(WOLFSSL_SRP OR WOLFSSL_USER_SETTINGS)
  221. set(BUILD_SRP "yes" PARENT_SCOPE)
  222. endif()
  223. set(USE_VALGRIND ${WOLFSSL_VALGRIND})
  224. if(WOLFSSL_MD4 OR WOLFSSL_USER_SETTINGS)
  225. set(BUILD_MD4 "yes" PARENT_SCOPE)
  226. endif()
  227. if(WOLFSSL_PWDBASED OR WOLFSSL_USER_SETTINGS)
  228. set(BUILD_PWDBASED "yes" PARENT_SCOPE)
  229. endif()
  230. if(WOLFSSL_SCRYPT OR WOLFSSL_USER_SETTINGS)
  231. set(BUILD_SCRYPT "yes" PARENT_SCOPE)
  232. endif()
  233. if(WOLFSSL_CRYPT_ONLY AND NOT WOLFSSL_OPENSSL_EXTRA)
  234. set(BUILD_CRYPTONLY "yes" PARENT_SCOPE)
  235. endif()
  236. if(WOLFSSL_FAST_MATH OR WOLFSSL_USER_SETTINGS)
  237. set(BUILD_FAST_MATH "yes" PARENT_SCOPE)
  238. endif()
  239. if(WOLFSSL_SLOW_MATH OR WOLFSSL_USER_SETTINGS)
  240. set(BUILD_SLOW_MATH "yes" PARENT_SCOPE)
  241. endif()
  242. if(WOLFSSL_EXAMPLES AND NOT WOLFSSL_LEAN_TLS)
  243. set(BUILD_EXAMPLE_SERVERS "yes" PARENT_SCOPE)
  244. endif()
  245. set(BUILD_EXAMPLE_CLIENTS ${WOLFSSL_EXAMPLES} PARENT_SCOPE)
  246. set(BUILD_TESTS ${WOLFSSL_EXAMPLES} PARENT_SCOPE)
  247. if(NOT WOLFSSL_SINGLETHREADED AND WOLFSSL_EXAMPLES AND NOT WOLFSSL_LEAN_TLS)
  248. set(BUILD_THREADED_EXAMPLES "yes" PARENT_SCOPE)
  249. endif()
  250. set(BUILD_WOLFCRYPT_TESTS ${WOLFSSL_CRYPT_TESTS} PARENT_SCOPE)
  251. set(BUILD_LIBZ ${WOLFSSL_LIBZ} PARENT_SCOPE)
  252. if(WOLFSSL_PKCS11 OR WOLFSSL_USER_SETTINGS)
  253. set(BUILD_PKCS11 "yes" PARENT_SCOPE)
  254. endif()
  255. if(WOLFSSL_PKCS12 OR WOLFSSL_USER_SETTINGS)
  256. set(BUILD_PKCS12 "yes" PARENT_SCOPE)
  257. endif()
  258. set(BUILD_CAVIUM ${WOLFSSL_CAVIUM} PARENT_SCOPE)
  259. set(BUILD_CAVIUM_V ${WOLFSSL_CAVIUM_V} PARENT_SCOPE)
  260. set(BUILD_OCTEON_SYNC ${WOLFSSL_OCTEON_SYNC} PARENT_SCOPE)
  261. set(BUILD_INTEL_QA ${WOLFSSL_INTEL_QA} PARENT_SCOPE)
  262. set(BUILD_INTEL_QA_SYNC ${WOLFSSL_INTEL_QA_SYNC} PARENT_SCOPE)
  263. if(WOLFSSL_SP OR WOLFSSL_USER_SETTINGS)
  264. set(BUILD_SP "yes" PARENT_SCOPE)
  265. endif()
  266. if((WOLFSSL_SP AND NOT WOLFSSL_SP_ASM) OR WOLFSSL_USER_SETTINGS)
  267. set(BUILD_SP_C "yes" PARENT_SCOPE)
  268. endif()
  269. if(WOLFSSL_SP_ARM64_ASM OR WOLFSSL_USER_SETTINGS)
  270. set(BUILD_SP_ARM64 "yes" PARENT_SCOPE)
  271. endif()
  272. if(WOLFSSL_SP_ARM32_ASM OR WOLFSSL_USER_SETTINGS)
  273. set(BUILD_SP_ARM32 "yes" PARENT_SCOPE)
  274. endif()
  275. if(WOLFSSL_SP_ARM_THUMB_ASM OR WOLFSSL_USER_SETTINGS)
  276. set(BUILD_SP_ARM_THUMB "yes" PARENT_SCOPE)
  277. endif()
  278. if(WOLFSSL_SP_ARM_CORTEX_ASM OR WOLFSSL_USER_SETTINGS)
  279. set(BUILD_SP_ARM_CORTEX "yes" PARENT_SCOPE)
  280. endif()
  281. if(WOLFSSL_SP_X86_64_ASM OR WOLFSSL_USER_SETTINGS)
  282. set(BUILD_SP_X86_64 "yes" PARENT_SCOPE)
  283. endif()
  284. if(WOLFSSL_SP_MATH OR WOLFSSL_SP_MATH_ALL OR WOLFSSL_USER_SETTINGS)
  285. set(BUILD_SP_INT "yes" PARENT_SCOPE)
  286. endif()
  287. set(BUILD_FAST_RSA ${WOLFSSL_FAST_RSA} PARENT_SCOPE)
  288. set(BUILD_MCAPI ${WOLFSSL_MCAPI} PARENT_SCOPE)
  289. set(BUILD_ASYNCCRYPT ${WOLFSSL_ASYNCCRYPT} PARENT_SCOPE)
  290. set(BUILD_WOLFEVENT ${WOLFSSL_ASYNCCRYPT} PARENT_SCOPE)
  291. if(WOLFSSL_CRYPTOCB OR WOLFSSL_USER_SETTINGS)
  292. set(BUILD_CRYPTOCB "yes" PARENT_SCOPE)
  293. endif()
  294. set(BUILD_PSK ${WOLFSSL_PSK} PARENT_SCOPE)
  295. set(BUILD_TRUST_PEER_CERT ${WOLFSSL_TRUSTED_PEER_CERT} PARENT_SCOPE)
  296. set(BUILD_PKI ${WOLFSSL_PKI} PARENT_SCOPE)
  297. if(WOLFSSL_DES3 OR WOLFSSL_USER_SETTINGS)
  298. set(BUILD_DES3 "yes" PARENT_SCOPE)
  299. endif()
  300. if(WOLFSSL_PKCS7 OR WOLFSSL_USER_SETTINGS)
  301. set(BUILD_PKCS7 "yes" PARENT_SCOPE)
  302. endif()
  303. set(BUILD_HASHFLAGS ${WOLFSSL_HASHFLAGS} PARENT_SCOPE)
  304. set(BUILD_LINUX_KM ${WOLFSSL_LINUX_KM} PARENT_SCOPE)
  305. set(BUILD_NO_LIBRARY ${WOLFSSL_NO_LIBRARY} PARENT_SCOPE)
  306. if(WOLFSSL_DEBUG OR WOLFSSL_STACK_SIZE)
  307. set(BUILD_DEBUG "yes" PARENT_SCOPE)
  308. endif()
  309. set(BUILD_RC2 ${WOLFSSL_RC2} PARENT_SCOPE)
  310. if(WOLFSSL_CAAM)
  311. set(BUILD_CAAM "yes" PARENT_SCOPE)
  312. endif()
  313. if(WOLFSSL_HPKE OR WOLFSSL_USER_SETTINGS)
  314. set(BUILD_HPKE "yes" PARENT_SCOPE)
  315. endif()
  316. set(BUILD_FLAGS_GENERATED "yes" PARENT_SCOPE)
  317. endfunction()
  318. function(generate_lib_src_list LIB_SOURCES)
  319. if(NOT BUILD_FLAGS_GENERATED)
  320. message(FATAL_ERROR "Cannot call generate_lib_src_list without calling generate_build_flags first.")
  321. endif()
  322. # Corresponds to src/include.am
  323. if(BUILD_FIPS)
  324. if(BUILD_FIPS_V2)
  325. # FIPSv2 first file
  326. list(APPEND LIB_SOURCES wolfcrypt/src/wolfcrypt_first.c)
  327. list(APPEND LIB_SOURCES
  328. wolfcrypt/src/hmac.c
  329. wolfcrypt/src/random.c
  330. wolfcrypt/src/sha256.c)
  331. if(BUILD_RSA)
  332. list(APPEND LIB_SOURCES wolfcrypt/src/rsa.c)
  333. endif()
  334. if(BUILD_ECC)
  335. list(APPEND LIB_SOURCES wolfcrypt/src/ecc.c)
  336. endif()
  337. if(BUILD_AES)
  338. list(APPEND LIB_SOURCES wolfcrypt/src/aes.c)
  339. if(BUILD_ARMASM AND BUILD_FIPS_READY)
  340. list(APPEND LIB_SOURCES wolfcrypt/src/port/arm/armv8-aes.c)
  341. endif()
  342. endif()
  343. if(BUILD_AESNI)
  344. list(APPEND LIB_SOURCES wolfcrypt/src/aes_asm.S)
  345. if(BUILD_INTELASM)
  346. list(APPEND LIB_SOURCES wolfcrypt/src/aes_gcm_asm.S)
  347. endif()
  348. endif()
  349. if(BUILD_DES3)
  350. list(APPEND LIB_SOURCES wolfcrypt/src/des3.c)
  351. endif()
  352. if(BUILD_SHA)
  353. list(APPEND LIB_SOURCES wolfcrypt/src/sha.c)
  354. endif()
  355. if(BUILD_ARMASM AND BUILD_FIPS_READY)
  356. list(APPEND LIB_SOURCES wolfcrypt/src/port/arm/armv8-sha256.c)
  357. endif()
  358. if(BUILD_INTELASM)
  359. list(APPEND LIB_SOURCES wolfcrypt/src/sha256_asm.S)
  360. endif()
  361. if(BUILD_SHA512)
  362. list(APPEND LIB_SOURCES wolfcrypt/src/sha512.c)
  363. if(BUILD_ARMASM AND BUILD_FIPS_READY)
  364. list(APPEND LIB_SOURCES
  365. wolfcrypt/src/port/arm/armv8-sha512.c
  366. wolfcrypt/src/port/arm/armv8-sha512-asm.S
  367. wolfcrypt/src/port/arm/armv8-32-sha512-asm.S)
  368. endif()
  369. if(BUILD_INTELASM)
  370. list(APPEND LIB_SOURCES wolfcrypt/src/sha512_asm.S)
  371. endif()
  372. endif()
  373. if(BUILD_SHA3)
  374. list(APPEND LIB_SOURCES wolfcrypt/src/sha3.c)
  375. endif()
  376. if(BUILD_DH)
  377. list(APPEND LIB_SOURCES wolfcrypt/src/dh.c)
  378. endif()
  379. if(BUILD_CMAC)
  380. list(APPEND LIB_SOURCES wolfcrypt/src/cmac.c)
  381. endif()
  382. list(APPEND LIB_SOURCES
  383. wolfcrypt/src/fips.c
  384. wolfcrypt/src/fips_test.c)
  385. # fips last file
  386. list(APPEND LIB_SOURCES wolfcrypt/src/wolfcrypt_last.c)
  387. endif()
  388. if(BUILD_FIPS_V5)
  389. list(APPEND LIB_SOURCES wolfcrypt/src/wolfcrypt_first.c)
  390. list(APPEND LIB_SOURCES
  391. wolfcrypt/src/hmac.c
  392. wolfcrypt/src/random.c
  393. wolfcrypt/src/sha256.c)
  394. list(APPEND LIB_SOURCES
  395. wolfcrypt/src/kdf.c)
  396. if(BUILD_RSA)
  397. list(APPEND LIB_SOURCES wolfcrypt/src/rsa.c)
  398. endif()
  399. endif()
  400. if(BUILD_FIPS_RAND)
  401. list(APPEND LIB_SOURCES
  402. wolfcrypt/src/wolfcrypt_first.c
  403. wolfcrypt/src/hmac.c
  404. wolfcrypt/src/random.c
  405. wolfcrypt/src/sha256.c
  406. wolfcrypt/src/sha256_asm.S
  407. wolfcrypt/src/fips.c
  408. wolfcrypt/src/fips_test.c
  409. wolfcrypt/src/wolfcrypt_last.c)
  410. endif()
  411. endif()
  412. # For wolfRand, exclude everything else.
  413. if(NOT BUILD_FIPS_RAND)
  414. # For FIPSV2, exclude the wolfCrypt files included above.
  415. # For wolfRand, exclude just a couple files.
  416. # For old FIPS, keep the wolfCrypt versions of the
  417. # CtaoCrypt files included above.
  418. if(NOT BUILD_FIPS_V2)
  419. list(APPEND LIB_SOURCES wolfcrypt/src/hmac.c)
  420. endif()
  421. # CAVP self test
  422. if(BUILD_SELFTEST)
  423. list(APPEND LIB_SOURCES wolfcrypt/src/selftest.c)
  424. endif()
  425. endif()
  426. list(APPEND LIB_SOURCES
  427. wolfcrypt/src/hash.c
  428. wolfcrypt/src/cpuid.c)
  429. if(NOT BUILD_FIPS_RAND)
  430. if(NOT BUILD_FIPS_V5)
  431. list(APPEND LIB_SOURCES wolfcrypt/src/kdf.c)
  432. endif()
  433. if(NOT BUILD_FIPS_V2 AND BUILD_RNG)
  434. list(APPEND LIB_SOURCES wolfcrypt/src/random.c)
  435. endif()
  436. if(NOT BUILD_FIPS_V2)
  437. if(BUILD_ARMASM)
  438. list(APPEND LIB_SOURCES wolfcrypt/src/port/arm/armv8-sha256.c)
  439. else()
  440. list(APPEND LIB_SOURCES wolfcrypt/src/sha256.c)
  441. if(BUILD_INTELASM)
  442. list(APPEND LIB_SOURCES wolfcrypt/src/sha256_asm.S)
  443. endif()
  444. endif()
  445. endif()
  446. if(BUILD_AFALG)
  447. list(APPEND LIB_SOURCES wolfcrypt/src/port/af_alg/afalg_hash.c)
  448. endif()
  449. if(BUILD_WOLFEVENT)
  450. list(APPEND LIB_SOURCES wolfcrypt/src/wolfevent.c)
  451. endif()
  452. if(BUILD_ASYNCCRYPT)
  453. list(APPEND LIB_SOURCES wolfcrypt/src/async.c)
  454. endif()
  455. if(NOT BUILD_USER_RSA AND BUILD_RSA)
  456. if(BUILD_FAST_RSA)
  457. list(APPEND LIB_SOURCES wolfcrypt/user-crypto/src/rsa.c)
  458. else()
  459. if(NOT BUILD_FIPS_V2)
  460. list(APPEND LIB_SOURCES wolfcrypt/src/rsa.c)
  461. endif()
  462. endif()
  463. endif()
  464. if(BUILD_SP)
  465. if(BUILD_SP_C)
  466. list(APPEND LIB_SOURCES
  467. wolfcrypt/src/sp_c32.c
  468. wolfcrypt/src/sp_c64.c)
  469. endif()
  470. if(BUILD_SP_X86_64)
  471. list(APPEND LIB_SOURCES
  472. wolfcrypt/src/sp_x86_64.c
  473. wolfcrypt/src/sp_x86_64_asm.S)
  474. endif()
  475. if(NOT BUILD_FIPS_V2 AND BUILD_SP_ARM32)
  476. list(APPEND LIB_SOURCES wolfcrypt/src/sp_arm32.c)
  477. endif()
  478. if(BUILD_SP_ARM_THUMB)
  479. list(APPEND LIB_SOURCES wolfcrypt/src/sp_armthumb.c)
  480. endif()
  481. if(BUILD_SP_ARM64)
  482. list(APPEND LIB_SOURCES wolfcrypt/src/sp_arm64.c)
  483. endif()
  484. if(BUILD_SP_ARM_CORTEX)
  485. list(APPEND LIB_SOURCES wolfcrypt/src/sp_cortexm.c)
  486. endif()
  487. endif()
  488. if(BUILD_SP_INT)
  489. list(APPEND LIB_SOURCES wolfcrypt/src/sp_int.c)
  490. endif()
  491. if(NOT BUILD_FIPS_V2)
  492. if(BUILD_AES)
  493. list(APPEND LIB_SOURCES wolfcrypt/src/aes.c)
  494. if(BUILD_ARMASM)
  495. list(APPEND LIB_SOURCES wolfcrypt/src/port/arm/armv8-aes.c)
  496. endif()
  497. if(BUILD_AFALG)
  498. list(APPEND LIB_SOURCES wolfcrypt/src/port/af_alg/afalg_aes.c)
  499. endif()
  500. endif()
  501. endif()
  502. if(NOT BUILD_FIPS_V2 AND BUILD_CMAC)
  503. list(APPEND LIB_SOURCES wolfcrypt/src/cmac.c)
  504. endif()
  505. if(NOT BUILD_FIPS_V2 AND BUILD_DES3)
  506. list(APPEND LIB_SOURCES wolfcrypt/src/des3.c)
  507. endif()
  508. if(NOT BUILD_FIPS_V2 AND BUILD_SHA)
  509. list(APPEND LIB_SOURCES wolfcrypt/src/sha.c)
  510. endif()
  511. if(NOT BUILD_FIPS_V2 AND BUILD_SHA512)
  512. if(BUILD_ARMASM)
  513. list(APPEND LIB_SOURCES
  514. wolfcrypt/src/port/arm/armv8-sha512.c
  515. wolfcrypt/src/port/arm/armv8-sha512-asm.S
  516. wolfcrypt/src/port/arm/armv8-32-sha512-asm.S)
  517. else()
  518. list(APPEND LIB_SOURCES wolfcrypt/src/sha512.c)
  519. if(BUILD_INTELASM)
  520. list(APPEND LIB_SOURCES wolfcrypt/src/sha512_asm.S)
  521. endif()
  522. endif()
  523. endif()
  524. if(NOT BUILD_FIPS_V2 AND BUILD_SHA3)
  525. list(APPEND LIB_SOURCES wolfcrypt/src/sha3.c)
  526. endif()
  527. endif()
  528. list(APPEND LIB_SOURCES
  529. wolfcrypt/src/logging.c
  530. wolfcrypt/src/wc_port.c
  531. wolfcrypt/src/error.c)
  532. if(BUILD_ARIA)
  533. list(APPEND LIB_SOURCES
  534. wolfcrypt/src/port/aria/aria-crypt.c
  535. wolfcrypt/src/port/aria/aria-cryptocb.c)
  536. endif()
  537. if(NOT BUILD_FIPS_RAND)
  538. list(APPEND LIB_SOURCES
  539. wolfcrypt/src/wc_encrypt.c
  540. wolfcrypt/src/signature.c
  541. wolfcrypt/src/wolfmath.c)
  542. endif()
  543. if(BUILD_MEMORY)
  544. list(APPEND LIB_SOURCES wolfcrypt/src/memory.c)
  545. endif()
  546. if(NOT BUILD_FIPS_RAND)
  547. if(NOT BUILD_FIPS_V2 AND BUILD_DH)
  548. list(APPEND LIB_SOURCES wolfcrypt/src/dh.c)
  549. endif()
  550. if(BUILD_ASN)
  551. list(APPEND LIB_SOURCES wolfcrypt/src/asn.c)
  552. endif()
  553. endif()
  554. if(BUILD_CODING)
  555. list(APPEND LIB_SOURCES wolfcrypt/src/coding.c)
  556. endif()
  557. if(NOT BUILD_FIPS_RAND)
  558. if(BUILD_POLY1305)
  559. if(BUILD_ARMASM)
  560. list(APPEND LIB_SOURCES wolfcrypt/src/port/arm/armv8-poly1305.c)
  561. endif()
  562. list(APPEND LIB_SOURCES wolfcrypt/src/poly1305.c)
  563. if(BUILD_INTELASM)
  564. list(APPEND LIB_SOURCES wolfcrypt/src/poly1305_asm.S)
  565. endif()
  566. endif()
  567. if(BUILD_RC4)
  568. list(APPEND LIB_SOURCES wolfcrypt/src/arc4.c)
  569. endif()
  570. if(BUILD_MD4)
  571. list(APPEND LIB_SOURCES wolfcrypt/src/md4.c)
  572. endif()
  573. if(BUILD_MD5)
  574. list(APPEND LIB_SOURCES wolfcrypt/src/md5.c)
  575. endif()
  576. if(BUILD_PWDBASED)
  577. list(APPEND LIB_SOURCES
  578. wolfcrypt/src/pwdbased.c
  579. wolfcrypt/src/pkcs12.c)
  580. endif()
  581. if(BUILD_DSA)
  582. list(APPEND LIB_SOURCES wolfcrypt/src/dsa.c)
  583. endif()
  584. if(NOT BUILD_FIPS_V2 AND BUILD_AESNI)
  585. list(APPEND LIB_SOURCES
  586. wolfcrypt/src/aes_asm.S
  587. wolfcrypt/src/aes_gcm_asm.S)
  588. endif()
  589. if(BUILD_CAMELLIA)
  590. list(APPEND LIB_SOURCES wolfcrypt/src/camellia.c)
  591. endif()
  592. if(BUILD_MD2)
  593. list(APPEND LIB_SOURCES wolfcrypt/src/md2.c)
  594. endif()
  595. if(BUILD_RIPEMD)
  596. list(APPEND LIB_SOURCES wolfcrypt/src/ripemd.c)
  597. endif()
  598. if(BUILD_BLAKE2)
  599. list(APPEND LIB_SOURCES wolfcrypt/src/blake2b.c)
  600. endif()
  601. if(BUILD_BLAKE2S)
  602. list(APPEND LIB_SOURCES wolfcrypt/src/blake2s.c)
  603. endif()
  604. if(BUILD_CHACHA)
  605. if(BUILD_ARMASM)
  606. list(APPEND LIB_SOURCES wolfcrypt/src/port/arm/armv8-chacha.c)
  607. else()
  608. list(APPEND LIB_SOURCES wolfcrypt/src/chacha.c)
  609. if(BUILD_INTELASM)
  610. list(APPEND LIB_SOURCES wolfcrypt/src/chacha_asm.S)
  611. endif()
  612. endif()
  613. if(BUILD_POLY1305)
  614. list(APPEND LIB_SOURCES wolfcrypt/src/chacha20_poly1305.c)
  615. endif()
  616. endif()
  617. if(NOT BUILD_INLINE)
  618. list(APPEND LIB_SOURCES wolfcrypt/src/misc.c)
  619. endif()
  620. if(BUILD_FAST_MATH)
  621. list(APPEND LIB_SOURCES wolfcrypt/src/tfm.c)
  622. endif()
  623. if(BUILD_SLOW_MATH)
  624. list(APPEND LIB_SOURCES wolfcrypt/src/integer.c)
  625. endif()
  626. if(NOT BUILD_FIPS_V2 AND BUILD_ECC)
  627. list(APPEND LIB_SOURCES wolfcrypt/src/ecc.c)
  628. endif()
  629. if(BUILD_CURVE25519)
  630. list(APPEND LIB_SOURCES wolfcrypt/src/curve25519.c)
  631. endif()
  632. if(BUILD_ED25519)
  633. list(APPEND LIB_SOURCES wolfcrypt/src/ed25519.c)
  634. endif()
  635. if(BUILD_FEMATH)
  636. if(BUILD_CURVE25519_SMALL)
  637. list(APPEND LIB_SOURCES wolfcrypt/src/fe_low_mem.c)
  638. else()
  639. if(BUILD_INTELASM)
  640. list(APPEND LIB_SOURCES wolfcrypt/src/fe_x25519_asm.S)
  641. else()
  642. if(BUILD_ARMASM)
  643. list(APPEND LIB_SOURCES
  644. wolfcrypt/src/port/arm/armv8-32-curve25519.S
  645. wolfcrypt/src/port/arm/armv8-curve25519.S)
  646. else()
  647. list(APPEND LIB_SOURCES wolfcrypt/src/fe_operations.c)
  648. endif()
  649. endif()
  650. endif()
  651. endif()
  652. if(BUILD_GEMATH)
  653. if(BUILD_ED25519_SMALL)
  654. list(APPEND LIB_SOURCES wolfcrypt/src/ge_low_mem.c)
  655. else()
  656. list(APPEND LIB_SOURCES wolfcrypt/src/ge_operations.c)
  657. if(NOT BUILD_FEMATH)
  658. if(BUILD_INTELASM)
  659. list(APPEND LIB_SOURCES wolfcrypt/src/fe_x25519_asm.S)
  660. else()
  661. if(BUILD_ARMASM)
  662. list(APPEND LIB_SOURCES wolfcrypt/src/port/arm/armv8-curve25519.S)
  663. else()
  664. list(APPEND LIB_SOURCES wolfcrypt/src/fe_operations.c)
  665. endif()
  666. endif()
  667. endif()
  668. endif()
  669. endif()
  670. if(BUILD_CURVE448)
  671. list(APPEND LIB_SOURCES wolfcrypt/src/curve448.c)
  672. endif()
  673. if(BUILD_ED448)
  674. list(APPEND LIB_SOURCES wolfcrypt/src/ed448.c)
  675. endif()
  676. if(BUILD_FE448)
  677. list(APPEND LIB_SOURCES wolfcrypt/src/fe_448.c)
  678. endif()
  679. if(BUILD_GE448)
  680. list(APPEND LIB_SOURCES wolfcrypt/src/ge_448.c)
  681. if(NOT BUILD_FE448)
  682. list(APPEND LIB_SOURCES wolfcrypt/src/fe_448.c)
  683. endif()
  684. endif()
  685. if(BUILD_FALCON)
  686. list(APPEND LIB_SOURCES wolfcrypt/src/falcon.c)
  687. endif()
  688. if(BUILD_SPHINCS)
  689. list(APPEND LIB_SOURCES wolfcrypt/src/sphincs.c)
  690. endif()
  691. if(BUILD_DILITHIUM)
  692. list(APPEND LIB_SOURCES wolfcrypt/src/dilithium.c)
  693. endif()
  694. if(BUILD_EXT_KYBER)
  695. list(APPEND LIB_SOURCES wolfcrypt/src/ext_kyber.c)
  696. endif()
  697. if(BUILD_LIBZ)
  698. list(APPEND LIB_SOURCES wolfcrypt/src/compress.c)
  699. endif()
  700. if(BUILD_PKCS7)
  701. list(APPEND LIB_SOURCES wolfcrypt/src/pkcs7.c)
  702. endif()
  703. if(BUILD_SRP)
  704. list(APPEND LIB_SOURCES wolfcrypt/src/srp.c)
  705. endif()
  706. if(BUILD_AFALG)
  707. list(APPEND LIB_SOURCES wolfcrypt/src/port/af_alg/wc_afalg.c)
  708. endif()
  709. if(NOT BUILD_CRYPTONLY)
  710. # ssl files
  711. list(APPEND LIB_SOURCES
  712. src/internal.c
  713. src/wolfio.c
  714. src/keys.c
  715. src/ssl.c
  716. src/ocsp.c
  717. src/tls.c)
  718. if(BUILD_TLS13)
  719. list(APPEND LIB_SOURCES src/tls13.c)
  720. endif()
  721. if(BUILD_DTLS13)
  722. list(APPEND LIB_SOURCES src/dtls13.c)
  723. endif()
  724. if(BUILD_QUIC)
  725. list(APPEND LIB_SOURCES src/quic.c)
  726. endif()
  727. if(BUILD_OCSP)
  728. list(APPEND LIB_SOURCES src/ocsp.c)
  729. endif()
  730. if(BUILD_CRL)
  731. list(APPEND LIB_SOURCES src/crl.c)
  732. endif()
  733. if(BUILD_SNIFFER)
  734. list(APPEND LIB_SOURCES src/sniffer.c)
  735. endif()
  736. if(BUILD_DTLS_COMMON)
  737. list(APPEND LIB_SOURCES src/dtls.c)
  738. endif()
  739. if(BUILD_QUIC)
  740. list(APPEND LIB_SOURCES src/quic.c)
  741. endif()
  742. endif()
  743. endif()
  744. # Corresponds to wolfcrypt/src/include.am
  745. if(BUILD_CRYPTOCB)
  746. list(APPEND LIB_SOURCES wolfcrypt/src/cryptocb.c)
  747. endif()
  748. if(BUILD_PKCS11)
  749. list(APPEND LIB_SOURCES wolfcrypt/src/wc_pkcs11.c)
  750. endif()
  751. if(BUILD_DEVCRYPTO)
  752. list(APPEND LIB_SOURCES
  753. wolfcrypt/src/port/devcrypto/devcrypto_hash.c
  754. wolfcrypt/src/port/devcrypto/devcrypto_aes.c
  755. wolfcrypt/src/port/devcrypto/wc_devcrypto.c)
  756. endif()
  757. if(BUILD_CAVIUM)
  758. list(APPEND LIB_SOURCES wolfcrypt/src/port/cavium/cavium_nitrox.c)
  759. endif()
  760. if(BUILD_OCTEON_SYNC)
  761. list(APPEND LIB_SOURCES wolfcrypt/src/port/cavium/cavium_octeon_sync.c)
  762. endif()
  763. if(BUILD_INTEL_QA)
  764. list(APPEND LIB_SOURCES
  765. wolfcrypt/src/port/intel/quickassist.c
  766. wolfcrypt/src/port/intel/quickassist_mem.c)
  767. endif()
  768. if(BUILD_INTEL_QA_SYNC)
  769. list(APPEND LIB_SOURCES wolfcrypt/src/port/intel/quickassist_sync.c)
  770. endif()
  771. if(BUILD_CRYPTOAUTHLIB)
  772. list(APPEND LIB_SOURCES wolfcrypt/src/port/atmel/atmel.c)
  773. endif()
  774. if(BUILD_CAAM)
  775. list(APPEND LIB_SOURCES
  776. wolfcrypt/src/port/caam/wolfcaam_init.c
  777. wolfcrypt/src/port/caam/wolfcaam_qnx.c
  778. wolfcrypt/src/port/caam/wolfcaam_seco.c
  779. wolfcrypt/src/port/caam/wolfcaam_fsl_nxp.c
  780. wolfcrypt/src/port/caam/wolfcaam_x25519.c
  781. wolfcrypt/src/port/caam/wolfcaam_ecdsa.c
  782. wolfcrypt/src/port/caam/wolfcaam_cmac.c
  783. wolfcrypt/src/port/caam/wolfcaam_aes.c
  784. wolfcrypt/src/port/caam/wolfcaam_hash.c
  785. wolfcrypt/src/port/caam/wolfcaam_rsa.c
  786. wolfcrypt/src/port/caam/wolfcaam_hmac.c)
  787. endif()
  788. if(BUILD_HPKE)
  789. list(APPEND LIB_SOURCES wolfcrypt/src/hpke.c)
  790. endif()
  791. set(LIB_SOURCES ${LIB_SOURCES} PARENT_SCOPE)
  792. endfunction()
  793. function(add_to_options_file DEFINITIONS OPTION_FILE)
  794. list(REMOVE_DUPLICATES DEFINITIONS)
  795. foreach(DEF IN LISTS DEFINITIONS)
  796. if(DEF MATCHES "^-D")
  797. if(DEF MATCHES "^-D(N)?DEBUG(=.+)?")
  798. message("not outputting (N)DEBUG to ${OPTION_FILE}")
  799. endif()
  800. # allow user to ignore system options
  801. if(DEF MATCHES "^-D_.*")
  802. file(APPEND ${OPTION_FILE} "#ifndef WOLFSSL_OPTIONS_IGNORE_SYS\n")
  803. endif()
  804. string(REGEX REPLACE "^-D" "" DEF_NO_PREFIX ${DEF})
  805. string(REGEX REPLACE "=.*$" "" DEF_NO_EQUAL_NO_VAL ${DEF_NO_PREFIX})
  806. string(REPLACE "=" " " DEF_NO_EQUAL ${DEF_NO_PREFIX})
  807. file(APPEND ${OPTION_FILE} "#undef ${DEF_NO_EQUAL_NO_VAL}\n")
  808. file(APPEND ${OPTION_FILE} "#define ${DEF_NO_EQUAL}\n")
  809. if(DEF MATCHES "^-D_.*")
  810. file(APPEND ${OPTION_FILE} "#endif\n")
  811. endif()
  812. file(APPEND ${OPTION_FILE} "\n")
  813. endif()
  814. endforeach()
  815. endfunction()