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