Makefile 10.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267
  1. # SPDX-License-Identifier: GPL-2.0
  2. #
  3. # Cryptographic API
  4. #
  5. obj-$(CONFIG_CRYPTO) += crypto.o
  6. crypto-y := api.o cipher.o compress.o
  7. obj-$(CONFIG_CRYPTO_ENGINE) += crypto_engine.o
  8. obj-$(CONFIG_CRYPTO_FIPS) += fips.o
  9. crypto_algapi-$(CONFIG_PROC_FS) += proc.o
  10. crypto_algapi-y := algapi.o scatterwalk.o $(crypto_algapi-y)
  11. obj-$(CONFIG_CRYPTO_ALGAPI2) += crypto_algapi.o
  12. obj-$(CONFIG_CRYPTO_AEAD2) += aead.o
  13. obj-$(CONFIG_CRYPTO_AEAD2) += geniv.o
  14. obj-$(CONFIG_CRYPTO_SKCIPHER2) += skcipher.o
  15. obj-$(CONFIG_CRYPTO_SEQIV) += seqiv.o
  16. obj-$(CONFIG_CRYPTO_ECHAINIV) += echainiv.o
  17. crypto_hash-y += ahash.o
  18. crypto_hash-y += shash.o
  19. obj-$(CONFIG_CRYPTO_HASH2) += crypto_hash.o
  20. obj-$(CONFIG_CRYPTO_AKCIPHER2) += akcipher.o
  21. obj-$(CONFIG_CRYPTO_KPP2) += kpp.o
  22. dh_generic-y := dh.o
  23. dh_generic-y += dh_helper.o
  24. obj-$(CONFIG_CRYPTO_DH) += dh_generic.o
  25. $(obj)/rsapubkey.asn1.o: $(obj)/rsapubkey.asn1.c $(obj)/rsapubkey.asn1.h
  26. $(obj)/rsaprivkey.asn1.o: $(obj)/rsaprivkey.asn1.c $(obj)/rsaprivkey.asn1.h
  27. $(obj)/rsa_helper.o: $(obj)/rsapubkey.asn1.h $(obj)/rsaprivkey.asn1.h
  28. rsa_generic-y := rsapubkey.asn1.o
  29. rsa_generic-y += rsaprivkey.asn1.o
  30. rsa_generic-y += rsa.o
  31. rsa_generic-y += rsa_helper.o
  32. rsa_generic-y += rsa-pkcs1pad.o
  33. obj-$(CONFIG_CRYPTO_RSA) += rsa_generic.o
  34. $(obj)/sm2signature.asn1.o: $(obj)/sm2signature.asn1.c $(obj)/sm2signature.asn1.h
  35. $(obj)/sm2.o: $(obj)/sm2signature.asn1.h
  36. sm2_generic-y += sm2signature.asn1.o
  37. sm2_generic-y += sm2.o
  38. obj-$(CONFIG_CRYPTO_SM2) += sm2_generic.o
  39. $(obj)/ecdsasignature.asn1.o: $(obj)/ecdsasignature.asn1.c $(obj)/ecdsasignature.asn1.h
  40. $(obj)/ecdsa.o: $(obj)/ecdsasignature.asn1.h
  41. ecdsa_generic-y += ecdsa.o
  42. ecdsa_generic-y += ecdsasignature.asn1.o
  43. obj-$(CONFIG_CRYPTO_ECDSA) += ecdsa_generic.o
  44. crypto_acompress-y := acompress.o
  45. crypto_acompress-y += scompress.o
  46. obj-$(CONFIG_CRYPTO_ACOMP2) += crypto_acompress.o
  47. cryptomgr-y := algboss.o testmgr.o
  48. obj-$(CONFIG_CRYPTO_MANAGER2) += cryptomgr.o
  49. obj-$(CONFIG_CRYPTO_USER) += crypto_user.o
  50. crypto_user-y := crypto_user_base.o
  51. crypto_user-$(CONFIG_CRYPTO_STATS) += crypto_user_stat.o
  52. obj-$(CONFIG_CRYPTO_CMAC) += cmac.o
  53. obj-$(CONFIG_CRYPTO_HMAC) += hmac.o
  54. obj-$(CONFIG_CRYPTO_VMAC) += vmac.o
  55. obj-$(CONFIG_CRYPTO_XCBC) += xcbc.o
  56. obj-$(CONFIG_CRYPTO_NULL2) += crypto_null.o
  57. obj-$(CONFIG_CRYPTO_MD4) += md4.o
  58. obj-$(CONFIG_CRYPTO_MD5) += md5.o
  59. obj-$(CONFIG_CRYPTO_RMD160) += rmd160.o
  60. obj-$(CONFIG_CRYPTO_SHA1) += sha1_generic.o
  61. obj-$(CONFIG_CRYPTO_SHA256) += sha256_generic.o
  62. obj-$(CONFIG_CRYPTO_SHA512) += sha512_generic.o
  63. obj-$(CONFIG_CRYPTO_SHA3) += sha3_generic.o
  64. obj-$(CONFIG_CRYPTO_SM3) += sm3.o
  65. obj-$(CONFIG_CRYPTO_SM3_GENERIC) += sm3_generic.o
  66. obj-$(CONFIG_CRYPTO_STREEBOG) += streebog_generic.o
  67. obj-$(CONFIG_CRYPTO_WP512) += wp512.o
  68. CFLAGS_wp512.o := $(call cc-option,-fno-schedule-insns) # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=79149
  69. obj-$(CONFIG_CRYPTO_BLAKE2B) += blake2b_generic.o
  70. CFLAGS_blake2b_generic.o := -Wframe-larger-than=4096 # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=105930
  71. obj-$(CONFIG_CRYPTO_GF128MUL) += gf128mul.o
  72. obj-$(CONFIG_CRYPTO_ECB) += ecb.o
  73. obj-$(CONFIG_CRYPTO_CBC) += cbc.o
  74. obj-$(CONFIG_CRYPTO_CFB) += cfb.o
  75. obj-$(CONFIG_CRYPTO_PCBC) += pcbc.o
  76. obj-$(CONFIG_CRYPTO_CTS) += cts.o
  77. obj-$(CONFIG_CRYPTO_LRW) += lrw.o
  78. obj-$(CONFIG_CRYPTO_XTS) += xts.o
  79. obj-$(CONFIG_CRYPTO_CTR) += ctr.o
  80. obj-$(CONFIG_CRYPTO_XCTR) += xctr.o
  81. obj-$(CONFIG_CRYPTO_HCTR2) += hctr2.o
  82. obj-$(CONFIG_CRYPTO_KEYWRAP) += keywrap.o
  83. obj-$(CONFIG_CRYPTO_ADIANTUM) += adiantum.o
  84. obj-$(CONFIG_CRYPTO_NHPOLY1305) += nhpoly1305.o
  85. obj-$(CONFIG_CRYPTO_GCM) += gcm.o
  86. obj-$(CONFIG_CRYPTO_CCM) += ccm.o
  87. obj-$(CONFIG_CRYPTO_CHACHA20POLY1305) += chacha20poly1305.o
  88. obj-$(CONFIG_CRYPTO_AEGIS128) += aegis128.o
  89. aegis128-y := aegis128-core.o
  90. ifeq ($(ARCH),arm)
  91. CFLAGS_aegis128-neon-inner.o += -ffreestanding -march=armv8-a -mfloat-abi=softfp
  92. CFLAGS_aegis128-neon-inner.o += -mfpu=crypto-neon-fp-armv8
  93. aegis128-$(CONFIG_CRYPTO_AEGIS128_SIMD) += aegis128-neon.o aegis128-neon-inner.o
  94. endif
  95. ifeq ($(ARCH),arm64)
  96. aegis128-cflags-y := -ffreestanding -mcpu=generic+crypto
  97. aegis128-cflags-$(CONFIG_CC_IS_GCC) += -ffixed-q16 -ffixed-q17 -ffixed-q18 \
  98. -ffixed-q19 -ffixed-q20 -ffixed-q21 \
  99. -ffixed-q22 -ffixed-q23 -ffixed-q24 \
  100. -ffixed-q25 -ffixed-q26 -ffixed-q27 \
  101. -ffixed-q28 -ffixed-q29 -ffixed-q30 \
  102. -ffixed-q31
  103. CFLAGS_aegis128-neon-inner.o += $(aegis128-cflags-y)
  104. CFLAGS_REMOVE_aegis128-neon-inner.o += -mgeneral-regs-only
  105. aegis128-$(CONFIG_CRYPTO_AEGIS128_SIMD) += aegis128-neon.o aegis128-neon-inner.o
  106. endif
  107. # Enable <arm_neon.h>
  108. CFLAGS_aegis128-neon-inner.o += -isystem $(shell $(CC) -print-file-name=include)
  109. obj-$(CONFIG_CRYPTO_PCRYPT) += pcrypt.o
  110. obj-$(CONFIG_CRYPTO_CRYPTD) += cryptd.o
  111. obj-$(CONFIG_CRYPTO_DES) += des_generic.o
  112. obj-$(CONFIG_CRYPTO_FCRYPT) += fcrypt.o
  113. obj-$(CONFIG_CRYPTO_BLOWFISH) += blowfish_generic.o
  114. obj-$(CONFIG_CRYPTO_BLOWFISH_COMMON) += blowfish_common.o
  115. obj-$(CONFIG_CRYPTO_TWOFISH) += twofish_generic.o
  116. obj-$(CONFIG_CRYPTO_TWOFISH_COMMON) += twofish_common.o
  117. obj-$(CONFIG_CRYPTO_SERPENT) += serpent_generic.o
  118. CFLAGS_serpent_generic.o := $(call cc-option,-fsched-pressure) # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=79149
  119. obj-$(CONFIG_CRYPTO_AES) += aes_generic.o
  120. CFLAGS_aes_generic.o := $(call cc-option,-fno-code-hoisting) # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=83356
  121. obj-$(CONFIG_CRYPTO_SM4) += sm4.o
  122. obj-$(CONFIG_CRYPTO_SM4_GENERIC) += sm4_generic.o
  123. obj-$(CONFIG_CRYPTO_AES_TI) += aes_ti.o
  124. obj-$(CONFIG_CRYPTO_CAMELLIA) += camellia_generic.o
  125. obj-$(CONFIG_CRYPTO_CAST_COMMON) += cast_common.o
  126. obj-$(CONFIG_CRYPTO_CAST5) += cast5_generic.o
  127. obj-$(CONFIG_CRYPTO_CAST6) += cast6_generic.o
  128. obj-$(CONFIG_CRYPTO_ARC4) += arc4.o
  129. obj-$(CONFIG_CRYPTO_TEA) += tea.o
  130. obj-$(CONFIG_CRYPTO_KHAZAD) += khazad.o
  131. obj-$(CONFIG_CRYPTO_ANUBIS) += anubis.o
  132. obj-$(CONFIG_CRYPTO_SEED) += seed.o
  133. obj-$(CONFIG_CRYPTO_ARIA) += aria_generic.o
  134. obj-$(CONFIG_CRYPTO_CHACHA20) += chacha_generic.o
  135. obj-$(CONFIG_CRYPTO_POLY1305) += poly1305_generic.o
  136. obj-$(CONFIG_CRYPTO_DEFLATE) += deflate.o
  137. obj-$(CONFIG_CRYPTO_MICHAEL_MIC) += michael_mic.o
  138. obj-$(CONFIG_CRYPTO_CRC32C) += crc32c_generic.o
  139. obj-$(CONFIG_CRYPTO_CRC32) += crc32_generic.o
  140. obj-$(CONFIG_CRYPTO_CRCT10DIF) += crct10dif_common.o crct10dif_generic.o
  141. obj-$(CONFIG_CRYPTO_CRC64_ROCKSOFT) += crc64_rocksoft_generic.o
  142. obj-$(CONFIG_CRYPTO_AUTHENC) += authenc.o authencesn.o
  143. obj-$(CONFIG_CRYPTO_LZO) += lzo.o lzo-rle.o
  144. obj-$(CONFIG_CRYPTO_LZ4) += lz4.o
  145. obj-$(CONFIG_CRYPTO_LZ4HC) += lz4hc.o
  146. obj-$(CONFIG_CRYPTO_XXHASH) += xxhash_generic.o
  147. obj-$(CONFIG_CRYPTO_842) += 842.o
  148. obj-$(CONFIG_CRYPTO_RNG2) += rng.o
  149. obj-$(CONFIG_CRYPTO_ANSI_CPRNG) += ansi_cprng.o
  150. obj-$(CONFIG_CRYPTO_DRBG) += drbg.o
  151. obj-$(CONFIG_CRYPTO_JITTERENTROPY) += jitterentropy_rng.o
  152. CFLAGS_jitterentropy.o = -O0
  153. KASAN_SANITIZE_jitterentropy.o = n
  154. UBSAN_SANITIZE_jitterentropy.o = n
  155. jitterentropy_rng-y := jitterentropy.o jitterentropy-kcapi.o
  156. obj-$(CONFIG_CRYPTO_TEST) += tcrypt.o
  157. obj-$(CONFIG_CRYPTO_GHASH) += ghash-generic.o
  158. obj-$(CONFIG_CRYPTO_POLYVAL) += polyval-generic.o
  159. obj-$(CONFIG_CRYPTO_USER_API) += af_alg.o
  160. obj-$(CONFIG_CRYPTO_USER_API_HASH) += algif_hash.o
  161. obj-$(CONFIG_CRYPTO_USER_API_SKCIPHER) += algif_skcipher.o
  162. obj-$(CONFIG_CRYPTO_USER_API_RNG) += algif_rng.o
  163. obj-$(CONFIG_CRYPTO_USER_API_AEAD) += algif_aead.o
  164. obj-$(CONFIG_CRYPTO_ZSTD) += zstd.o
  165. obj-$(CONFIG_CRYPTO_OFB) += ofb.o
  166. obj-$(CONFIG_CRYPTO_ECC) += ecc.o
  167. obj-$(CONFIG_CRYPTO_ESSIV) += essiv.o
  168. obj-$(CONFIG_CRYPTO_CURVE25519) += curve25519-generic.o
  169. ecdh_generic-y += ecdh.o
  170. ecdh_generic-y += ecdh_helper.o
  171. obj-$(CONFIG_CRYPTO_ECDH) += ecdh_generic.o
  172. $(obj)/ecrdsa_params.asn1.o: $(obj)/ecrdsa_params.asn1.c $(obj)/ecrdsa_params.asn1.h
  173. $(obj)/ecrdsa_pub_key.asn1.o: $(obj)/ecrdsa_pub_key.asn1.c $(obj)/ecrdsa_pub_key.asn1.h
  174. $(obj)/ecrdsa.o: $(obj)/ecrdsa_params.asn1.h $(obj)/ecrdsa_pub_key.asn1.h
  175. ecrdsa_generic-y += ecrdsa.o
  176. ecrdsa_generic-y += ecrdsa_params.asn1.o
  177. ecrdsa_generic-y += ecrdsa_pub_key.asn1.o
  178. obj-$(CONFIG_CRYPTO_ECRDSA) += ecrdsa_generic.o
  179. #
  180. # generic algorithms and the async_tx api
  181. #
  182. obj-$(CONFIG_XOR_BLOCKS) += xor.o
  183. obj-$(CONFIG_ASYNC_CORE) += async_tx/
  184. obj-$(CONFIG_ASYMMETRIC_KEY_TYPE) += asymmetric_keys/
  185. obj-$(CONFIG_CRYPTO_HASH_INFO) += hash_info.o
  186. crypto_simd-y := simd.o
  187. obj-$(CONFIG_CRYPTO_SIMD) += crypto_simd.o
  188. #
  189. # Key derivation function
  190. #
  191. obj-$(CONFIG_CRYPTO_KDF800108_CTR) += kdf_sp800108.o
  192. ifneq ($(CONFIG_CRYPTO_FIPS140_MOD),)
  193. FIPS140_CFLAGS := -DBUILD_FIPS140_KO -include $(srctree)/crypto/fips140-defs.h
  194. CFLAGS_jitterentropy-fips.o := -O0
  195. KASAN_SANITIZE_jitterentropy-fips.o = n
  196. UBSAN_SANITIZE_jitterentropy-fips.o = n
  197. # Compile an extra copy of various crypto algorithms into the fips140 module.
  198. #
  199. # Note: the module will still work if some files are removed from here.
  200. # However, it may affect FIPS certifiability. Don't remove files from here
  201. # without considering impact on FIPS certifiability.
  202. crypto-fips-objs := drbg.o ecb.o cbc.o ctr.o cts.o gcm.o xts.o hmac.o cmac.o \
  203. gf128mul.o aes_generic.o lib-crypto-aes.o \
  204. jitterentropy.o jitterentropy-kcapi.o \
  205. sha1_generic.o sha256_generic.o sha512_generic.o \
  206. lib-crypto-memneq.o lib-crypto-sha1.o lib-crypto-sha256.o \
  207. lib-crypto-utils.o
  208. crypto-fips-objs := $(foreach o,$(crypto-fips-objs),$(o:.o=-fips.o))
  209. # get the arch to add its objects to $(crypto-fips-objs)
  210. include $(srctree)/arch/$(ARCH)/crypto/Kbuild.fips140
  211. $(obj)/%-fips.o: KBUILD_CFLAGS += $(FIPS140_CFLAGS)
  212. $(obj)/%-fips.o: $(src)/%.c FORCE
  213. $(call if_changed_rule,cc_o_c)
  214. $(obj)/lib-%-fips.o: $(srctree)/lib/%.c FORCE
  215. $(call if_changed_rule,cc_o_c)
  216. $(obj)/lib-crypto-%-fips.o: $(srctree)/lib/crypto/%.c FORCE
  217. $(call if_changed_rule,cc_o_c)
  218. fips140-objs := \
  219. fips140-alg-registration.o \
  220. fips140-module.o \
  221. fips140-refs.o \
  222. fips140-selftests.o \
  223. $(crypto-fips-objs)
  224. fips140-$(CONFIG_CRYPTO_FIPS140_MOD_EVAL_TESTING) += \
  225. fips140-eval-testing.o
  226. obj-m += fips140.o
  227. CFLAGS_fips140-alg-registration.o += $(FIPS140_CFLAGS)
  228. CFLAGS_fips140-module.o += $(FIPS140_CFLAGS)
  229. CFLAGS_fips140-selftests.o += $(FIPS140_CFLAGS)
  230. CFLAGS_fips140-eval-testing.o += $(FIPS140_CFLAGS)
  231. hostprogs-always-y := fips140_gen_hmac
  232. HOSTLDLIBS_fips140_gen_hmac := -lcrypto -lelf
  233. endif