1LIBS=../../libcrypto 2 3$BNASM=bn_asm.c 4IF[{- !$disabled{asm} -}] 5 # Define source files and macros per asm architecture 6 # Known macros are: 7 # 8 # OPENSSL_BN_ASM_PART_WORDS For any collection with /-586/ file names 9 # OPENSSL_BN_ASM_MONT For any collection with /-mont/ file names 10 # OPENSSL_BN_ASM_MONT5 For any collection with /-mont5/ file names 11 # OPENSSL_BN_ASM_GF2m For any collection with /-gf2m/ file names 12 # OPENSSL_IA32_SSE2 For any collection with /86/ file names 13 # when sse2 is enabled 14 # BN_DIV3W For any collection with /-div3w/ file names 15 # 16 # All variables are named in such a way that they can be "indexed" with 17 # $target{asm_arch} 18 19 $BNASM_x86=bn-586.S co-586.S x86-mont.S x86-gf2m.S 20 # bn-586 is the only one implementing bn_*_part_words 21 # => OPENSSL_BN_ASM_PART_WORDS 22 $BNDEF_x86=OPENSSL_BN_ASM_PART_WORDS OPENSSL_BN_ASM_MONT OPENSSL_BN_ASM_GF2m 23 $BNDEF_x86_sse2=OPENSSL_IA32_SSE2 24 25 $BNASM_x86_64=\ 26 x86_64-mont.s x86_64-mont5.s x86_64-gf2m.s rsaz_exp.c rsaz-x86_64.s \ 27 rsaz-avx2.s rsaz_exp_x2.c rsaz-2k-avx512.s rsaz-3k-avx512.s rsaz-4k-avx512.s \ 28 rsaz-2k-avxifma.s rsaz-3k-avxifma.s rsaz-4k-avxifma.s 29 IF[{- $config{target} !~ /^VC/ -}] 30 $BNASM_x86_64=asm/x86_64-gcc.c $BNASM_x86_64 31 ELSE 32 $BNASM_x86_64=bn_asm.c $BNASM_x86_64 33 ENDIF 34 $BNDEF_x86_64=OPENSSL_BN_ASM_MONT OPENSSL_BN_ASM_MONT5 OPENSSL_BN_ASM_GF2m 35 $BNDEF_x86_64_sse2=OPENSSL_IA32_SSE2 36 37 IF[{- $config{target} !~ /^VC/ -}] 38 $BNASM_ia64=bn-ia64.s ia64-mont.s 39 ELSE 40 $BNASM_ia64=bn_asm.c ia64-mont.s 41 ENDIF 42 43 $BNASM_sparcv9=asm/sparcv8plus.S sparcv9-mont.S sparcv9a-mont.S vis3-mont.S \ 44 sparct4-mont.S bn_sparc.c 45 $BNDEF_sparcv9=OPENSSL_BN_ASM_MONT 46 $BNASM_sparcv9_ec2m=sparcv9-gf2m.S 47 $BNDEF_sparcv9_ec2m=OPENSSL_BN_ASM_GF2m 48 49 $BNASM_sparcv8=asm/sparcv8.S 50 51 $BNASM_alpha=bn_asm.c alpha-mont.S 52 $BNDEF_alpha=OPENSSL_BN_ASM_MONT 53 54 $BNASM_mips32=bn-mips.S mips-mont.S 55 $BNDEF_mips32=OPENSSL_BN_ASM_MONT 56 $BNASM_mips64=$BNASM_mips32 57 $BNDEF_mips64=$BNDEF_mips32 58 59 IF[{- ($target{perlasm_scheme} // '') eq '31' -}] 60 $BNASM_s390x=bn_asm.c s390x-mont.S 61 ELSE 62 $BNASM_s390x=asm/s390x.S s390x-mont.S bn_s390x.c 63 ENDIF 64 $BNDEF_s390x=OPENSSL_BN_ASM_MONT 65 $BNASM_s390x_ec2m=s390x-gf2m.s 66 $BNDEF_s390x_ec2m=OPENSSL_BN_ASM_GF2m 67 68 $BNASM_armv4=bn_asm.c armv4-mont.S 69 $BNDEF_armv4=OPENSSL_BN_ASM_MONT 70 $BNASM_armv4_ec2m=armv4-gf2m.S 71 $BNDEF_armv4_ec2m=OPENSSL_BN_ASM_GF2m 72 73 $BNASM_aarch64=bn_asm.c armv8-mont.S 74 $BNDEF_aarch64=OPENSSL_BN_ASM_MONT 75 76 $BNASM_parisc11=bn_asm.c parisc-mont.s 77 $BNDEF_parisc11=OPENSSL_BN_ASM_MONT 78 $BNASM_parisc20_64=$BNASM_parisc11 79 $BNDEF_parisc20_64=$BNDEF_parisc11 80 81 $BNASM_ppc32=bn_ppc.c bn-ppc.s ppc-mont.s 82 $BNDEF_ppc32=OPENSSL_BN_ASM_MONT 83 $BNASM_ppc64=$BNASM_ppc32 ppc64-mont-fixed.s 84 $BNDEF_ppc64=$BNDEF_ppc32 85 86 $BNASM_c64xplus=asm/bn-c64xplus.asm 87 $BNASM_c64xplus_ec2m=c64xplus-gf2m.s 88 $BNDEF_c64xplus_ec2m=OPENSSL_BN_ASM_GF2m 89 90 # Now that we have defined all the arch specific variables, use the 91 # appropriate ones, and define the appropriate macros 92 IF[$BNASM_{- $target{asm_arch} -}] 93 $BNASM=$BNASM_{- $target{asm_arch} -} 94 $BNDEF=$BNDEF_{- $target{asm_arch} -} 95 IF[{- !$disabled{ec2m} -}] 96 $BNASM=$BNASM $BNASM_{- $target{asm_arch} -}_ec2m 97 $BNDEF=$BNDEF $BNDEF_{- $target{asm_arch} -}_ec2m 98 ENDIF 99 IF[{- !$disabled{sse2} -}] 100 $BNDEF=$BNDEF $BNDEF_{- $target{asm_arch} -}_sse2 101 ENDIF 102 ENDIF 103ENDIF 104 105$COMMON=bn_add.c bn_div.c bn_exp.c bn_lib.c bn_ctx.c bn_mul.c \ 106 bn_mod.c bn_conv.c bn_rand.c bn_shift.c bn_word.c bn_blind.c \ 107 bn_kron.c bn_sqrt.c bn_gcd.c bn_prime.c bn_sqr.c \ 108 bn_recp.c bn_mont.c bn_mpi.c bn_exp2.c bn_gf2m.c bn_nist.c \ 109 bn_intern.c bn_dh.c bn_rsa_fips186_4.c bn_const.c 110SOURCE[../../libcrypto]=$COMMON $BNASM bn_print.c bn_err.c bn_srp.c 111DEFINE[../../libcrypto]=$BNDEF 112IF[{- !$disabled{'deprecated-0.9.8'} -}] 113 SOURCE[../../libcrypto]=bn_depr.c 114ENDIF 115IF[{- !$disabled{'deprecated-3.0'} -}] 116 SOURCE[../../libcrypto]=bn_x931p.c 117ENDIF 118SOURCE[../../providers/libfips.a]=$COMMON $BNASM 119DEFINE[../../providers/libfips.a]=$BNDEF 120# Implementations are now spread across several libraries, so the defines 121# need to be applied to all affected libraries and modules. 122DEFINE[../../providers/libcommon.a]=$BNDEF 123 124INCLUDE[bn_exp.o]=.. 125 126GENERATE[bn-586.S]=asm/bn-586.pl 127DEPEND[bn-586.S]=../perlasm/x86asm.pl 128GENERATE[co-586.S]=asm/co-586.pl 129DEPEND[co-586.S]=../perlasm/x86asm.pl 130GENERATE[x86-mont.S]=asm/x86-mont.pl 131DEPEND[x86-mont.S]=../perlasm/x86asm.pl 132GENERATE[x86-gf2m.S]=asm/x86-gf2m.pl 133DEPEND[x86-gf2m.S]=../perlasm/x86asm.pl 134 135GENERATE[sparcv9a-mont.S]=asm/sparcv9a-mont.pl 136INCLUDE[sparcv9a-mont.o]=.. 137GENERATE[sparcv9-mont.S]=asm/sparcv9-mont.pl 138INCLUDE[sparcv9-mont.o]=.. 139GENERATE[vis3-mont.S]=asm/vis3-mont.pl 140INCLUDE[vis3-mont.o]=.. 141GENERATE[sparct4-mont.S]=asm/sparct4-mont.pl 142INCLUDE[sparct4-mont.o]=.. 143GENERATE[sparcv9-gf2m.S]=asm/sparcv9-gf2m.pl 144INCLUDE[sparcv9-gf2m.o]=.. 145 146GENERATE[bn-mips.S]=asm/mips.pl 147INCLUDE[bn-mips.o]=.. 148GENERATE[mips-mont.S]=asm/mips-mont.pl 149INCLUDE[mips-mont.o]=.. 150 151GENERATE[s390x-mont.S]=asm/s390x-mont.pl 152GENERATE[s390x-gf2m.s]=asm/s390x-gf2m.pl 153 154GENERATE[x86_64-mont.s]=asm/x86_64-mont.pl 155GENERATE[x86_64-mont5.s]=asm/x86_64-mont5.pl 156GENERATE[x86_64-gf2m.s]=asm/x86_64-gf2m.pl 157GENERATE[rsaz-x86_64.s]=asm/rsaz-x86_64.pl 158GENERATE[rsaz-avx2.s]=asm/rsaz-avx2.pl 159GENERATE[rsaz-2k-avx512.s]=asm/rsaz-2k-avx512.pl 160GENERATE[rsaz-3k-avx512.s]=asm/rsaz-3k-avx512.pl 161GENERATE[rsaz-4k-avx512.s]=asm/rsaz-4k-avx512.pl 162GENERATE[rsaz-2k-avxifma.s]=asm/rsaz-2k-avxifma.pl 163GENERATE[rsaz-3k-avxifma.s]=asm/rsaz-3k-avxifma.pl 164GENERATE[rsaz-4k-avxifma.s]=asm/rsaz-4k-avxifma.pl 165 166GENERATE[bn-ia64.s]=asm/ia64.S 167GENERATE[ia64-mont.s]=asm/ia64-mont.pl 168 169GENERATE[parisc-mont.s]=asm/parisc-mont.pl 170 171# ppc - AIX, Linux, MacOS X... 172GENERATE[bn-ppc.s]=asm/ppc.pl 173GENERATE[ppc-mont.s]=asm/ppc-mont.pl 174GENERATE[ppc64-mont.s]=asm/ppc64-mont.pl 175GENERATE[ppc64-mont-fixed.s]=asm/ppc64-mont-fixed.pl 176 177GENERATE[alpha-mont.S]=asm/alpha-mont.pl 178 179GENERATE[armv4-mont.S]=asm/armv4-mont.pl 180INCLUDE[armv4-mont.o]=.. 181GENERATE[armv4-gf2m.S]=asm/armv4-gf2m.pl 182INCLUDE[armv4-gf2m.o]=.. 183GENERATE[armv8-mont.S]=asm/armv8-mont.pl 184INCLUDE[armv8-mont.o]=.. 185