xref: /freebsd/crypto/openssl/crypto/bn/build.info (revision e7be843b4a162e68651d3911f0357ed464915629)
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