1#
2# CDDL HEADER START
3#
4# The contents of this file are subject to the terms of the
5# Common Development and Distribution License (the "License").
6# You may not use this file except in compliance with the License.
7#
8# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9# or http://www.opensolaris.org/os/licensing.
10# See the License for the specific language governing permissions
11# and limitations under the License.
12#
13# When distributing Covered Code, include this CDDL HEADER in each
14# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15# If applicable, add the following below this CDDL HEADER, with the
16# fields enclosed by brackets "[]" replaced with your own identifying
17# information: Portions Copyright [yyyy] [name of copyright owner]
18#
19# CDDL HEADER END
20#
21
22#
23# Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.
24# Copyright 2017 Jason King
25# Copyright (c) 2018, Joyent, Inc.
26#
27
28LIBRARY =	libsoftcrypto.a
29VERS =		.1
30
31include		../Makefile.com
32
33AES_PSM_OBJS =	aes_amd64.o aes_intel.o aeskey.o
34ARCFOUR_PSM_OBJS = arcfour-x86_64.o
35BIGNUM_PSM_OBJS = bignum_amd64.o bignum_amd64_asm.o
36MODES_PSM_OBJS = gcm_intel.o
37
38include		$(SRC)/lib/Makefile.lib
39include		$(SRC)/lib/Makefile.lib.64
40
41CERRWARN +=	-_gcc=-Wno-type-limits
42CERRWARN +=	-_gcc=-Wno-parentheses
43CERRWARN +=	-_gcc=-Wno-uninitialized
44
45AES_PSM_SRC =	$(AES_DIR)/$(MACH64)/aes_amd64.s \
46		$(AES_DIR)/$(MACH64)/aes_intel.s \
47		$(AES_DIR)/$(MACH64)/aeskey.c
48ARCFOUR_PSM_SRC = arcfour-x86_64.s
49BIGNUM_PSM_SRC = $(BIGNUM_DIR)/$(MACH64)/bignum_amd64.c \
50		$(BIGNUM_DIR)/$(MACH64)/bignum_amd64_asm.s
51
52MODES_PSM_SRC = $(MODES_DIR)/$(MACH64)/gcm_intel.s
53
54# Sources need to be redefined after Makefile.lib inclusion.
55SRCS =		$(AES_SRC) $(ARCFOUR_SRC) $(BIGNUM_SRC) $(BLOWFISH_SRC) \
56		$(DES_SRC) $(MODES_SRC) $(DH_SRC) $(DSA_SRC) $(RSA_SRC) \
57		$(PAD_SRC)
58
59SRCDIR =	$(SRC)/lib/pkcs11/libsoftcrypto/common
60
61LIBS =		$(DYNLIB) $(LINTLIB)
62MAPFILEDIR =	../common
63
64CFLAGS +=	-xO4 -xcrossfile
65CPPFLAGS +=	-I$(CRYPTODIR) -I$(UTSDIR) -D_POSIX_PTHREAD_SEMANTICS
66ASFLAGS +=	$(AS_PICFLAGS) -P -D__STDC__ -D_ASM
67BIGNUM_FLAGS +=	-DPSR_MUL
68CLEANFILES +=	arcfour-x86_64.s
69LDLIBS +=	-lcryptoutil -lc
70LINTFLAGS64 +=	$(EXTRA_LINT_FLAGS)
71
72.KEEP_STATE:
73
74all:		$(LIBS)
75
76lint:		$(SRCS)
77
78install:	all $(ROOTLIBS64) $(ROOTLINKS64) $(ROOTLINT64)
79
80pics/%.o: $(AES_DIR)/$(MACH64)/%.c
81		$(COMPILE.c) $(AES_FLAGS) -o $@ $<
82		$(POST_PROCESS_O)
83
84pics/%.o: $(AES_DIR)/$(MACH64)/%.s
85		$(COMPILE.s) $(AES_FLAGS) -o $@ $<
86		$(POST_PROCESS_O)
87
88pics/%.o: $(BIGNUM_DIR)/$(MACH64)/%.c
89		$(COMPILE.c) $(BIGNUM_FLAGS) -o $@ $<
90		$(POST_PROCESS_O)
91
92pics/%.o: $(BIGNUM_DIR)/$(MACH64)/%.s
93		$(COMPILE64.s) $(BIGNUM_FLAGS) -o $@ $<
94		$(POST_PROCESS_O)
95
96pics/%.o: $(MODES_DIR)/$(MACH64)/%.s
97		$(COMPILE64.s) $(MODES_FLAGS) -o $@ $<
98		$(POST_PROCESS_O)
99
100include		../Makefile.targ
101
102arcfour-x86_64.s: $(ARCFOUR_DIR)/amd64/arcfour-x86_64.pl
103		$(PERL) $? $@
104
105pics/%.o: arcfour-x86_64.s
106		$(COMPILE64.s) $(ARCFOUR_FLAGS) -o $@ $<
107		$(POST_PROCESS_O)
108