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) 2019, 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
45# not linted
46SMATCH=off
47
48AES_PSM_SRC =	$(AES_DIR)/$(MACH64)/aes_amd64.s \
49		$(AES_DIR)/$(MACH64)/aes_intel.s \
50		$(AES_DIR)/$(MACH64)/aeskey.c
51ARCFOUR_PSM_SRC = arcfour-x86_64.s
52BIGNUM_PSM_SRC = $(BIGNUM_DIR)/$(MACH64)/bignum_amd64.c \
53		$(BIGNUM_DIR)/$(MACH64)/bignum_amd64_asm.s
54
55MODES_PSM_SRC = $(MODES_DIR)/$(MACH64)/gcm_intel.s
56
57# Sources need to be redefined after Makefile.lib inclusion.
58SRCS =		$(AES_SRC) $(ARCFOUR_SRC) $(BIGNUM_SRC) $(BLOWFISH_SRC) \
59		$(DES_SRC) $(MODES_SRC) $(DH_SRC) $(DSA_SRC) $(RSA_SRC) \
60		$(PAD_SRC)
61
62SRCDIR =	$(SRC)/lib/pkcs11/libsoftcrypto/common
63
64LIBS =		$(DYNLIB) $(LINTLIB)
65MAPFILEDIR =	../common
66
67CFLAGS +=	-xO4 -xcrossfile
68CPPFLAGS +=	-I$(CRYPTODIR) -I$(UTSDIR) -D_POSIX_PTHREAD_SEMANTICS
69ASFLAGS +=	$(AS_PICFLAGS) -P -D__STDC__ -D_ASM
70BIGNUM_FLAGS +=	-DPSR_MUL
71CLEANFILES +=	arcfour-x86_64.s
72LDLIBS +=	-lcryptoutil -lc
73LINTFLAGS64 +=	$(EXTRA_LINT_FLAGS)
74
75.KEEP_STATE:
76
77all:		$(LIBS)
78
79lint:		$(SRCS)
80
81install:	all $(ROOTLIBS64) $(ROOTLINKS64) $(ROOTLINT64)
82
83pics/%.o: $(AES_DIR)/$(MACH64)/%.c
84		$(COMPILE.c) $(AES_FLAGS) -o $@ $<
85		$(POST_PROCESS_O)
86
87pics/%.o: $(AES_DIR)/$(MACH64)/%.s
88		$(COMPILE.s) $(AES_FLAGS) -o $@ $<
89		$(POST_PROCESS_S_O)
90
91pics/%.o: $(BIGNUM_DIR)/$(MACH64)/%.c
92		$(COMPILE.c) $(BIGNUM_FLAGS) -o $@ $<
93		$(POST_PROCESS_O)
94
95pics/%.o: $(BIGNUM_DIR)/$(MACH64)/%.s
96		$(COMPILE64.s) $(BIGNUM_FLAGS) -o $@ $<
97		$(POST_PROCESS_S_O)
98
99pics/%.o: $(MODES_DIR)/$(MACH64)/%.s
100		$(COMPILE64.s) $(MODES_FLAGS) -o $@ $<
101		$(POST_PROCESS_S_O)
102
103include		../Makefile.targ
104
105arcfour-x86_64.s: $(ARCFOUR_DIR)/amd64/arcfour-x86_64.pl
106		$(PERL) $? $@
107
108pics/%.o: arcfour-x86_64.s
109		$(COMPILE64.s) $(ARCFOUR_FLAGS) -o $@ $<
110		$(POST_PROCESS_S_O)
111