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)