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