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