summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2014-05-03 11:41:06 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2014-05-03 11:41:06 +0000
commit777a981a6f889790c7a64f18ef0588a13bcbfe4e (patch)
treea87ef929d9e59fe4f0051dc94d0b3655f4d81667
parent803e6c7bb620f2ce10655afb8992e0a3c163b13f (diff)
Enable assembler bits for BN (Montgomery), SHA1 and SHA256.
Assembler bits for AES remain commented out as they run slower than the C code.
-rw-r--r--lib/libcrypto/crypto/arch/powerpc/Makefile.inc44
1 files changed, 44 insertions, 0 deletions
diff --git a/lib/libcrypto/crypto/arch/powerpc/Makefile.inc b/lib/libcrypto/crypto/arch/powerpc/Makefile.inc
new file mode 100644
index 00000000000..b6ef263046f
--- /dev/null
+++ b/lib/libcrypto/crypto/arch/powerpc/Makefile.inc
@@ -0,0 +1,44 @@
+# $OpenBSD: Makefile.inc,v 1.1 2014/05/03 11:41:05 miod Exp $
+
+# powerpc-specific libcrypto build rules
+
+# aes
+SRCS+= aes_core.c aes_cbc.c
+# slower than C code
+#CFLAGS+= -DAES_ASM
+#SSLASM+= aes aes-ppc aes-ppc
+# bf
+SRCS+= bf_enc.c
+# bn
+SSLASM+= bn ppc bn-ppc
+SSLASM+= bn ppc-mont ppc-mont # bn_mul_mont_int
+#SSLASM+= bn ppc64-mont ppc64-mont # bn_mul_mont_fpu64
+CFLAGS+= -DOPENSSL_BN_ASM_MONT
+# des
+SRCS+= des_enc.c fcrypt_b.c
+# rc4
+SRCS+= rc4_enc.c rc4_skey.c
+## rc5
+#SRCS+= rc5_enc.c
+# sha
+CFLAGS+= -DSHA1_ASM
+SSLASM+= sha sha1-ppc sha1-ppc
+CFLAGS+= -DSHA256_ASM
+SSLASM+= sha sha512-ppc sha256-ppc
+# whrlpool
+SRCS+= wp_block.c
+
+.for dir src dst in ${SSLASM}
+SRCS+= ${dst}.S
+GENERATED+=${dst}.S
+${dst}.S: ${LCRYPTO_SRC}/${dir}/asm/${src}.pl
+ /usr/bin/perl \
+ ${LCRYPTO_SRC}/${dir}/asm/${src}.pl linux32 ${.TARGET} > ${.TARGET}
+.endfor
+
+#CFLAGS+= -DOPENSSL_CPUID_OBJ # it's commented out in ppccap.c
+SRCS+= ppccpuid.S ppccap.c
+GENERATED+=ppccpuid.S
+ppccpuid.S: ${LCRYPTO_SRC}/ppccpuid.pl
+ /usr/bin/perl \
+ ${LCRYPTO_SRC}/ppccpuid.pl linux32 > ${.TARGET}