Makefile 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367
  1. # SPDX-License-Identifier: GPL-2.0
  2. aflags-thumb2-$(CONFIG_THUMB2_KERNEL) := -U__thumb2__ -D__thumb2__=1
  3. quiet_cmd_perlasm = PERLASM $@
  4. cmd_perlasm = $(PERL) $(<) > $(@)
  5. quiet_cmd_perlasm_with_args = PERLASM $@
  6. cmd_perlasm_with_args = $(PERL) $(<) void $(@)
  7. obj-$(CONFIG_KUNIT) += tests/
  8. obj-$(CONFIG_CRYPTO_HASH_INFO) += hash_info.o
  9. obj-$(CONFIG_CRYPTO_LIB_UTILS) += libcryptoutils.o
  10. libcryptoutils-y := memneq.o utils.o
  11. ################################################################################
  12. obj-$(CONFIG_CRYPTO_LIB_AES) += libaes.o
  13. libaes-y := aes.o
  14. ifeq ($(CONFIG_CRYPTO_LIB_AES_ARCH),y)
  15. CFLAGS_aes.o += -I$(src)/$(SRCARCH)
  16. libaes-$(CONFIG_ARM) += arm/aes-cipher-core.o
  17. ifeq ($(CONFIG_ARM64),y)
  18. libaes-y += arm64/aes-cipher-core.o
  19. libaes-$(CONFIG_KERNEL_MODE_NEON) += arm64/aes-ce-core.o
  20. endif
  21. ifeq ($(CONFIG_PPC),y)
  22. ifeq ($(CONFIG_SPE),y)
  23. libaes-y += powerpc/aes-spe-core.o \
  24. powerpc/aes-spe-keys.o \
  25. powerpc/aes-spe-modes.o \
  26. powerpc/aes-tab-4k.o
  27. else
  28. libaes-y += powerpc/aesp8-ppc.o
  29. aes-perlasm-flavour-y := linux-ppc64
  30. aes-perlasm-flavour-$(CONFIG_PPC64_ELF_ABI_V2) := linux-ppc64-elfv2
  31. aes-perlasm-flavour-$(CONFIG_CPU_LITTLE_ENDIAN) := linux-ppc64le
  32. quiet_cmd_perlasm_aes = PERLASM $@
  33. cmd_perlasm_aes = $(PERL) $< $(aes-perlasm-flavour-y) $@
  34. # Use if_changed instead of cmd, in case the flavour changed.
  35. $(obj)/powerpc/aesp8-ppc.S: $(src)/powerpc/aesp8-ppc.pl FORCE
  36. $(call if_changed,perlasm_aes)
  37. targets += powerpc/aesp8-ppc.S
  38. OBJECT_FILES_NON_STANDARD_powerpc/aesp8-ppc.o := y
  39. endif # !CONFIG_SPE
  40. endif # CONFIG_PPC
  41. libaes-$(CONFIG_RISCV) += riscv/aes-riscv64-zvkned.o
  42. libaes-$(CONFIG_SPARC) += sparc/aes_asm.o
  43. libaes-$(CONFIG_X86) += x86/aes-aesni.o
  44. endif # CONFIG_CRYPTO_LIB_AES_ARCH
  45. # clean-files must be defined unconditionally
  46. clean-files += powerpc/aesp8-ppc.S
  47. ################################################################################
  48. obj-$(CONFIG_CRYPTO_LIB_AESCFB) += libaescfb.o
  49. libaescfb-y := aescfb.o
  50. obj-$(CONFIG_CRYPTO_LIB_AESGCM) += libaesgcm.o
  51. libaesgcm-y := aesgcm.o
  52. obj-$(CONFIG_CRYPTO_LIB_ARC4) += libarc4.o
  53. libarc4-y := arc4.o
  54. obj-$(CONFIG_CRYPTO_LIB_GF128MUL) += gf128mul.o
  55. ################################################################################
  56. obj-$(CONFIG_CRYPTO_LIB_BLAKE2B) += libblake2b.o
  57. libblake2b-y := blake2b.o
  58. ifeq ($(CONFIG_CRYPTO_LIB_BLAKE2B_ARCH),y)
  59. CFLAGS_blake2b.o += -I$(src)/$(SRCARCH)
  60. libblake2b-$(CONFIG_ARM) += arm/blake2b-neon-core.o
  61. endif # CONFIG_CRYPTO_LIB_BLAKE2B_ARCH
  62. ################################################################################
  63. # blake2s is used by the /dev/random driver which is always builtin
  64. obj-y += blake2s.o
  65. ifeq ($(CONFIG_CRYPTO_LIB_BLAKE2S_ARCH),y)
  66. CFLAGS_blake2s.o += -I$(src)/$(SRCARCH)
  67. obj-$(CONFIG_ARM) += arm/blake2s-core.o
  68. obj-$(CONFIG_X86) += x86/blake2s-core.o
  69. endif
  70. ################################################################################
  71. # chacha20_block() is used by the /dev/random driver which is always builtin
  72. obj-y += chacha-block-generic.o
  73. obj-$(CONFIG_CRYPTO_LIB_CHACHA) += libchacha.o
  74. libchacha-y := chacha.o
  75. ifeq ($(CONFIG_CRYPTO_LIB_CHACHA_ARCH),y)
  76. CFLAGS_chacha.o += -I$(src)/$(SRCARCH)
  77. ifeq ($(CONFIG_ARM),y)
  78. libchacha-y += arm/chacha-scalar-core.o
  79. libchacha-$(CONFIG_KERNEL_MODE_NEON) += arm/chacha-neon-core.o
  80. endif
  81. libchacha-$(CONFIG_ARM64) += arm64/chacha-neon-core.o
  82. ifeq ($(CONFIG_MIPS),y)
  83. libchacha-y += mips/chacha-core.o
  84. AFLAGS_mips/chacha-core.o += -O2 # needed to fill branch delay slots
  85. endif
  86. libchacha-$(CONFIG_PPC) += powerpc/chacha-p10le-8x.o
  87. libchacha-$(CONFIG_RISCV) += riscv/chacha-riscv64-zvkb.o
  88. libchacha-$(CONFIG_S390) += s390/chacha-s390.o
  89. libchacha-$(CONFIG_X86) += x86/chacha-ssse3-x86_64.o \
  90. x86/chacha-avx2-x86_64.o \
  91. x86/chacha-avx512vl-x86_64.o
  92. endif # CONFIG_CRYPTO_LIB_CHACHA_ARCH
  93. ################################################################################
  94. obj-$(CONFIG_CRYPTO_LIB_CHACHA20POLY1305) += libchacha20poly1305.o
  95. libchacha20poly1305-y += chacha20poly1305.o
  96. libchacha20poly1305-$(CONFIG_CRYPTO_SELFTESTS) += chacha20poly1305-selftest.o
  97. ################################################################################
  98. obj-$(CONFIG_CRYPTO_LIB_CURVE25519) += libcurve25519.o
  99. libcurve25519-y := curve25519.o
  100. # Disable GCOV in odd or sensitive code
  101. GCOV_PROFILE_curve25519.o := n
  102. ifeq ($(CONFIG_ARCH_SUPPORTS_INT128),y)
  103. libcurve25519-$(CONFIG_CRYPTO_LIB_CURVE25519_GENERIC) += curve25519-hacl64.o
  104. else
  105. libcurve25519-$(CONFIG_CRYPTO_LIB_CURVE25519_GENERIC) += curve25519-fiat32.o
  106. endif
  107. # clang versions prior to 18 may blow out the stack with KASAN
  108. ifeq ($(CONFIG_CC_IS_CLANG)_$(call clang-min-version, 180000),y_)
  109. KASAN_SANITIZE_curve25519-hacl64.o := n
  110. endif
  111. ifeq ($(CONFIG_CRYPTO_LIB_CURVE25519_ARCH),y)
  112. CFLAGS_curve25519.o += -I$(src)/$(SRCARCH)
  113. libcurve25519-$(CONFIG_ARM) += arm/curve25519-core.o
  114. libcurve25519-$(CONFIG_PPC) += powerpc/curve25519-ppc64le_asm.o
  115. endif
  116. ################################################################################
  117. obj-$(CONFIG_CRYPTO_LIB_DES) += libdes.o
  118. libdes-y := des.o
  119. ################################################################################
  120. obj-$(CONFIG_CRYPTO_LIB_MD5) += libmd5.o
  121. libmd5-y := md5.o
  122. ifeq ($(CONFIG_CRYPTO_LIB_MD5_ARCH),y)
  123. CFLAGS_md5.o += -I$(src)/$(SRCARCH)
  124. libmd5-$(CONFIG_PPC) += powerpc/md5-asm.o
  125. libmd5-$(CONFIG_SPARC) += sparc/md5_asm.o
  126. endif # CONFIG_CRYPTO_LIB_MD5_ARCH
  127. ################################################################################
  128. obj-$(CONFIG_CRYPTO_LIB_MLDSA) += libmldsa.o
  129. libmldsa-y := mldsa.o
  130. ################################################################################
  131. obj-$(CONFIG_CRYPTO_LIB_NH) += libnh.o
  132. libnh-y := nh.o
  133. ifeq ($(CONFIG_CRYPTO_LIB_NH_ARCH),y)
  134. CFLAGS_nh.o += -I$(src)/$(SRCARCH)
  135. libnh-$(CONFIG_ARM) += arm/nh-neon-core.o
  136. libnh-$(CONFIG_ARM64) += arm64/nh-neon-core.o
  137. libnh-$(CONFIG_X86) += x86/nh-sse2.o x86/nh-avx2.o
  138. endif
  139. ################################################################################
  140. obj-$(CONFIG_CRYPTO_LIB_POLY1305) += libpoly1305.o
  141. libpoly1305-y := poly1305.o
  142. ifeq ($(CONFIG_ARCH_SUPPORTS_INT128),y)
  143. libpoly1305-$(CONFIG_CRYPTO_LIB_POLY1305_GENERIC) += poly1305-donna64.o
  144. else
  145. libpoly1305-$(CONFIG_CRYPTO_LIB_POLY1305_GENERIC) += poly1305-donna32.o
  146. endif
  147. ifeq ($(CONFIG_CRYPTO_LIB_POLY1305_ARCH),y)
  148. CFLAGS_poly1305.o += -I$(src)/$(SRCARCH)
  149. ifeq ($(CONFIG_ARM),y)
  150. libpoly1305-y += arm/poly1305-core.o
  151. $(obj)/arm/poly1305-core.S: $(src)/arm/poly1305-armv4.pl
  152. $(call cmd,perlasm)
  153. # massage the perlasm code a bit so we only get the NEON routine if we need it
  154. poly1305-aflags-$(CONFIG_CPU_V7) := -U__LINUX_ARM_ARCH__ -D__LINUX_ARM_ARCH__=5
  155. poly1305-aflags-$(CONFIG_KERNEL_MODE_NEON) := -U__LINUX_ARM_ARCH__ -D__LINUX_ARM_ARCH__=7
  156. AFLAGS_arm/poly1305-core.o += $(poly1305-aflags-y) $(aflags-thumb2-y)
  157. endif
  158. ifeq ($(CONFIG_ARM64),y)
  159. libpoly1305-y += arm64/poly1305-core.o
  160. $(obj)/arm64/poly1305-core.S: $(src)/arm64/poly1305-armv8.pl
  161. $(call cmd,perlasm_with_args)
  162. endif
  163. ifeq ($(CONFIG_MIPS),y)
  164. libpoly1305-y += mips/poly1305-core.o
  165. poly1305-perlasm-flavour-$(CONFIG_32BIT) := o32
  166. poly1305-perlasm-flavour-$(CONFIG_64BIT) := 64
  167. quiet_cmd_perlasm_poly1305 = PERLASM $@
  168. cmd_perlasm_poly1305 = $(PERL) $< $(poly1305-perlasm-flavour-y) $@
  169. # Use if_changed instead of cmd, in case the flavour changed.
  170. $(obj)/mips/poly1305-core.S: $(src)/mips/poly1305-mips.pl FORCE
  171. $(call if_changed,perlasm_poly1305)
  172. targets += mips/poly1305-core.S
  173. endif
  174. libpoly1305-$(CONFIG_PPC) += powerpc/poly1305-p10le_64.o
  175. ifeq ($(CONFIG_RISCV),y)
  176. libpoly1305-y += riscv/poly1305-core.o
  177. poly1305-perlasm-flavour-$(CONFIG_32BIT) := 32
  178. poly1305-perlasm-flavour-$(CONFIG_64BIT) := 64
  179. quiet_cmd_perlasm_poly1305 = PERLASM $@
  180. cmd_perlasm_poly1305 = $(PERL) $< $(poly1305-perlasm-flavour-y) $@
  181. # Use if_changed instead of cmd, in case the flavour changed.
  182. $(obj)/riscv/poly1305-core.S: $(src)/riscv/poly1305-riscv.pl FORCE
  183. $(call if_changed,perlasm_poly1305)
  184. targets += riscv/poly1305-core.S
  185. AFLAGS_riscv/poly1305-core.o += -Dpoly1305_init=poly1305_block_init
  186. endif
  187. ifeq ($(CONFIG_X86),y)
  188. libpoly1305-y += x86/poly1305-x86_64-cryptogams.o
  189. $(obj)/x86/poly1305-x86_64-cryptogams.S: $(src)/x86/poly1305-x86_64-cryptogams.pl
  190. $(call cmd,perlasm)
  191. endif
  192. endif # CONFIG_CRYPTO_LIB_POLY1305_ARCH
  193. # clean-files must be defined unconditionally
  194. clean-files += arm/poly1305-core.S \
  195. arm64/poly1305-core.S \
  196. mips/poly1305-core.S \
  197. riscv/poly1305-core.S \
  198. x86/poly1305-x86_64-cryptogams.S
  199. ################################################################################
  200. obj-$(CONFIG_CRYPTO_LIB_POLYVAL) += libpolyval.o
  201. libpolyval-y := polyval.o
  202. ifeq ($(CONFIG_CRYPTO_LIB_POLYVAL_ARCH),y)
  203. CFLAGS_polyval.o += -I$(src)/$(SRCARCH)
  204. libpolyval-$(CONFIG_ARM64) += arm64/polyval-ce-core.o
  205. libpolyval-$(CONFIG_X86) += x86/polyval-pclmul-avx.o
  206. endif
  207. ################################################################################
  208. obj-$(CONFIG_CRYPTO_LIB_SHA1) += libsha1.o
  209. libsha1-y := sha1.o
  210. ifeq ($(CONFIG_CRYPTO_LIB_SHA1_ARCH),y)
  211. CFLAGS_sha1.o += -I$(src)/$(SRCARCH)
  212. ifeq ($(CONFIG_ARM),y)
  213. libsha1-y += arm/sha1-armv4-large.o
  214. libsha1-$(CONFIG_KERNEL_MODE_NEON) += arm/sha1-armv7-neon.o \
  215. arm/sha1-ce-core.o
  216. endif
  217. libsha1-$(CONFIG_ARM64) += arm64/sha1-ce-core.o
  218. ifeq ($(CONFIG_PPC),y)
  219. libsha1-y += powerpc/sha1-powerpc-asm.o
  220. libsha1-$(CONFIG_SPE) += powerpc/sha1-spe-asm.o
  221. endif
  222. libsha1-$(CONFIG_SPARC) += sparc/sha1_asm.o
  223. libsha1-$(CONFIG_X86) += x86/sha1-ssse3-and-avx.o \
  224. x86/sha1-avx2-asm.o \
  225. x86/sha1-ni-asm.o
  226. endif # CONFIG_CRYPTO_LIB_SHA1_ARCH
  227. ################################################################################
  228. obj-$(CONFIG_CRYPTO_LIB_SHA256) += libsha256.o
  229. libsha256-y := sha256.o
  230. ifeq ($(CONFIG_CRYPTO_LIB_SHA256_ARCH),y)
  231. CFLAGS_sha256.o += -I$(src)/$(SRCARCH)
  232. ifeq ($(CONFIG_ARM),y)
  233. libsha256-y += arm/sha256-ce.o arm/sha256-core.o
  234. $(obj)/arm/sha256-core.S: $(src)/arm/sha256-armv4.pl
  235. $(call cmd,perlasm)
  236. AFLAGS_arm/sha256-core.o += $(aflags-thumb2-y)
  237. endif
  238. ifeq ($(CONFIG_ARM64),y)
  239. libsha256-y += arm64/sha256-core.o
  240. $(obj)/arm64/sha256-core.S: $(src)/arm64/sha2-armv8.pl
  241. $(call cmd,perlasm_with_args)
  242. libsha256-$(CONFIG_KERNEL_MODE_NEON) += arm64/sha256-ce.o
  243. endif
  244. libsha256-$(CONFIG_PPC) += powerpc/sha256-spe-asm.o
  245. libsha256-$(CONFIG_RISCV) += riscv/sha256-riscv64-zvknha_or_zvknhb-zvkb.o
  246. libsha256-$(CONFIG_SPARC) += sparc/sha256_asm.o
  247. libsha256-$(CONFIG_X86) += x86/sha256-ssse3-asm.o \
  248. x86/sha256-avx-asm.o \
  249. x86/sha256-avx2-asm.o \
  250. x86/sha256-ni-asm.o
  251. endif # CONFIG_CRYPTO_LIB_SHA256_ARCH
  252. ################################################################################
  253. obj-$(CONFIG_CRYPTO_LIB_SHA512) += libsha512.o
  254. libsha512-y := sha512.o
  255. ifeq ($(CONFIG_CRYPTO_LIB_SHA512_ARCH),y)
  256. CFLAGS_sha512.o += -I$(src)/$(SRCARCH)
  257. ifeq ($(CONFIG_ARM),y)
  258. libsha512-y += arm/sha512-core.o
  259. $(obj)/arm/sha512-core.S: $(src)/arm/sha512-armv4.pl
  260. $(call cmd,perlasm)
  261. AFLAGS_arm/sha512-core.o += $(aflags-thumb2-y)
  262. endif
  263. ifeq ($(CONFIG_ARM64),y)
  264. libsha512-y += arm64/sha512-core.o
  265. $(obj)/arm64/sha512-core.S: $(src)/arm64/sha2-armv8.pl
  266. $(call cmd,perlasm_with_args)
  267. libsha512-$(CONFIG_KERNEL_MODE_NEON) += arm64/sha512-ce-core.o
  268. endif
  269. libsha512-$(CONFIG_RISCV) += riscv/sha512-riscv64-zvknhb-zvkb.o
  270. libsha512-$(CONFIG_SPARC) += sparc/sha512_asm.o
  271. libsha512-$(CONFIG_X86) += x86/sha512-ssse3-asm.o \
  272. x86/sha512-avx-asm.o \
  273. x86/sha512-avx2-asm.o
  274. endif # CONFIG_CRYPTO_LIB_SHA512_ARCH
  275. ################################################################################
  276. obj-$(CONFIG_CRYPTO_LIB_SHA3) += libsha3.o
  277. libsha3-y := sha3.o
  278. ifeq ($(CONFIG_CRYPTO_LIB_SHA3_ARCH),y)
  279. CFLAGS_sha3.o += -I$(src)/$(SRCARCH)
  280. libsha3-$(CONFIG_ARM64) += arm64/sha3-ce-core.o
  281. endif # CONFIG_CRYPTO_LIB_SHA3_ARCH
  282. ################################################################################
  283. obj-$(CONFIG_MPILIB) += mpi/
  284. obj-$(CONFIG_CRYPTO_SELFTESTS_FULL) += simd.o
  285. obj-$(CONFIG_CRYPTO_LIB_SM3) += libsm3.o
  286. libsm3-y := sm3.o
  287. # clean-files must be defined unconditionally
  288. clean-files += arm/sha256-core.S arm/sha512-core.S
  289. clean-files += arm64/sha256-core.S arm64/sha512-core.S