# Note that these directories are filtered in Configure. Look for %skipdir
# there for further explanations.
-SUBDIRS=objects buffer bio stack lhash rand evp asn1 pem x509 x509v3 conf \
- txt_db pkcs7 pkcs12 ui kdf store \
+SUBDIRS=objects buffer bio stack lhash rand evp asn1 pem x509 conf \
+ txt_db pkcs7 pkcs12 ui kdf store property \
md2 md4 md5 sha mdc2 gmac hmac ripemd whrlpool poly1305 blake2 \
siphash sm3 des aes rc2 rc4 rc5 idea aria bf cast camellia \
seed sm4 chacha modes bn ec rsa dsa dh sm2 dso engine \
- err comp ocsp cms ts srp cmac ct async
+ err comp ocsp cms ts srp cmac ct async kmac ess crmf cmp
LIBS=../libcrypto
-SOURCE[../libcrypto]=\
- cryptlib.c mem.c mem_dbg.c cversion.c ex_data.c cpt_err.c \
- ebcdic.c uid.c o_time.c o_str.c o_dir.c o_fopen.c ctype.c \
- threads_pthread.c threads_win.c threads_none.c getenv.c \
- o_init.c o_fips.c mem_sec.c init.c {- $target{cpuid_asm_src} -} \
- {- $target{uplink_aux_src} -}
-EXTRA= ../ms/uplink-x86.pl ../ms/uplink.c ../ms/applink.c \
- x86cpuid.pl x86_64cpuid.pl ia64cpuid.S \
- ppccpuid.pl pariscid.pl alphacpuid.pl arm64cpuid.pl armv4cpuid.pl
+
+$UPLINKSRC=
+$UPLINKDEF=
+IF[{- !$disabled{uplink} -}]
+ $UPLINKSRC_common=../ms/uplink.c
+ $UPLINKSRC_x86=$UPLINKSRC_common uplink-x86.s
+ $UPLINKSRC_x86_64=$UPLINKSRC_common uplink-x86_64.s
+ $UPLINKSRC_ia64=$UPLINKSRC_common uplink-ia64.s
+
+ IF[$UPLINKSRC_{- $target{uplink_arch} -}]
+ $UPLINKSRC=$UPLINKSRC_{- $target{uplink_arch} -}
+ $UPLINKDEF=OPENSSL_USE_APPLINK
+ ENDIF
+ENDIF
+
+$CPUIDASM=mem_clr.c
+$CPUIDDEF=
+IF[{- !$disabled{asm} && $config{processor} ne '386' -}]
+ $CPUIDASM_x86=x86cpuid.s
+
+ $CPUIDASM_x86_64=x86_64cpuid.s
+
+ $CPUIDASM_ia64=ia64cpuid.s
+
+ $CPUIDASM_sparcv9=sparcv9cap.c sparccpuid.S
+
+ $CPUIDASM_alpha=alphacpuid.s
+
+ $CPUIDASM_s390x=s390xcap.c s390xcpuid.S
+
+ $CPUIDASM_armv4=armcap.c armv4cpuid.S
+
+ $CPUIDASM_aarch64=armcap.c arm64cpuid.S
+
+ $CPUIDASM_parisc11=pariscid.s
+ $CPUIDASM_parisc20_64=$CPUIDASM_parisc11
+
+ $CPUIDASM_ppc32=ppccpuid.s ppccap.c
+ $CPUIDASM_ppc64=$CPUIDASM_ppc32
+
+ $CPUIDASM_c64xplus=c64xpluscpuid.s
+
+ # Now that we have defined all the arch specific variables, use the
+ # appropriate one, and define the appropriate macros
+ IF[$CPUIDASM_{- $target{asm_arch} -}]
+ $CPUIDASM=$CPUIDASM_{- $target{asm_arch} -}
+ $CPUIDDEF=OPENSSL_CPUID_OBJ
+ ENDIF
+ENDIF
+
+# The Core
+$CORE_COMMON=provider_core.c provider_predefined.c core_fetch.c core_namemap.c
+
+SOURCE[../libcrypto]=$CORE_COMMON provider_conf.c
+SOURCE[../providers/fips]=$CORE_COMMON
+
+# Central utilities
+$UTIL_COMMON=\
+ cryptlib.c mem.c mem_sec.c params.c bsearch.c ex_data.c o_str.c \
+ ctype.c threads_pthread.c threads_win.c threads_none.c initthread.c \
+ context.c sparse_array.c $CPUIDASM
+$UTIL_DEFINE=$CPUIDDEF
+
+SOURCE[../libcrypto]=$UTIL_COMMON \
+ mem_dbg.c cversion.c info.c cpt_err.c ebcdic.c uid.c o_time.c o_dir.c \
+ o_fopen.c getenv.c o_init.c o_fips.c init.c trace.c provider.c \
+ $UPLINKSRC
+DEFINE[../libcrypto]=$UTIL_DEFINE $UPLINKDEF
+SOURCE[../providers/fips]=$UTIL_COMMON
+DEFINE[../providers/fips]=$UTIL_DEFINE
+
+
DEPEND[cversion.o]=buildinf.h
GENERATE[buildinf.h]=../util/mkbuildinf.pl "$(CC) $(LIB_CFLAGS) $(CPPFLAGS_Q)" "$(PLATFORM)"