xref: /titanic_50/usr/src/uts/intel/aes/Makefile (revision 90bcde942a3919300ffc73f98ea903b58386c395)
17c478bd9Sstevel@tonic-gate#
27c478bd9Sstevel@tonic-gate# CDDL HEADER START
37c478bd9Sstevel@tonic-gate#
47c478bd9Sstevel@tonic-gate# The contents of this file are subject to the terms of the
5bb25c06cSjg# Common Development and Distribution License (the "License").
6bb25c06cSjg# You may not use this file except in compliance with the License.
77c478bd9Sstevel@tonic-gate#
87c478bd9Sstevel@tonic-gate# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
97c478bd9Sstevel@tonic-gate# or http://www.opensolaris.org/os/licensing.
107c478bd9Sstevel@tonic-gate# See the License for the specific language governing permissions
117c478bd9Sstevel@tonic-gate# and limitations under the License.
127c478bd9Sstevel@tonic-gate#
137c478bd9Sstevel@tonic-gate# When distributing Covered Code, include this CDDL HEADER in each
147c478bd9Sstevel@tonic-gate# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
157c478bd9Sstevel@tonic-gate# If applicable, add the following below this CDDL HEADER, with the
167c478bd9Sstevel@tonic-gate# fields enclosed by brackets "[]" replaced with your own identifying
177c478bd9Sstevel@tonic-gate# information: Portions Copyright [yyyy] [name of copyright owner]
187c478bd9Sstevel@tonic-gate#
197c478bd9Sstevel@tonic-gate# CDDL HEADER END
207c478bd9Sstevel@tonic-gate#
217c478bd9Sstevel@tonic-gate#
22160abee0Sda73024# Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
237c478bd9Sstevel@tonic-gate# Use is subject to license terms.
247c478bd9Sstevel@tonic-gate#
257c478bd9Sstevel@tonic-gate#ident	"%Z%%M%	%I%	%E% SMI"
267c478bd9Sstevel@tonic-gate#
277c478bd9Sstevel@tonic-gate#	This makefile drives the production of the AES KEF provider.
287c478bd9Sstevel@tonic-gate#
297c478bd9Sstevel@tonic-gate#	intel implementation architecture dependent
307c478bd9Sstevel@tonic-gate#
317c478bd9Sstevel@tonic-gate
327c478bd9Sstevel@tonic-gate#
337c478bd9Sstevel@tonic-gate#	Path to the base of the uts directory tree (usually /usr/src/uts).
347c478bd9Sstevel@tonic-gate#
357c478bd9Sstevel@tonic-gateUTSBASE	= ../..
36160abee0Sda73024COM_DIR	= $(COMMONBASE)/crypto/aes
377c478bd9Sstevel@tonic-gate
387c478bd9Sstevel@tonic-gate#
397c478bd9Sstevel@tonic-gate#	Define the module and object file sets.
407c478bd9Sstevel@tonic-gate#
417c478bd9Sstevel@tonic-gateMODULE		= aes
427c478bd9Sstevel@tonic-gateLINTS		= $(AESPROV_OBJS:%.o=$(LINTS_DIR)/%.ln)
43*90bcde94Sda73024AESPROV_OBJS_32	=
44*90bcde94Sda73024AESPROV_OBJS_64	= aes_amd64.o aeskey.o
45*90bcde94Sda73024AESPROV_OBJS	+= $(AESPROV_OBJS_$(CLASS))
46*90bcde94Sda73024OBJECTS		= $(AESPROV_OBJS:%=$(OBJS_DIR)/%)
477c478bd9Sstevel@tonic-gateROOTMODULE	= $(ROOT_CRYPTO_DIR)/$(MODULE)
487c478bd9Sstevel@tonic-gate
497c478bd9Sstevel@tonic-gate#
507c478bd9Sstevel@tonic-gate#	Include common rules.
517c478bd9Sstevel@tonic-gate#
527c478bd9Sstevel@tonic-gateinclude $(UTSBASE)/intel/Makefile.intel
537c478bd9Sstevel@tonic-gate
547c478bd9Sstevel@tonic-gate#	set signing mode
557c478bd9Sstevel@tonic-gateELFSIGN_MOD	= $(ELFSIGN_CRYPTO)
567c478bd9Sstevel@tonic-gate
577c478bd9Sstevel@tonic-gate#
587c478bd9Sstevel@tonic-gate#	Define targets
597c478bd9Sstevel@tonic-gate#
607c478bd9Sstevel@tonic-gateALL_TARGET	= $(BINARY)
617c478bd9Sstevel@tonic-gateLINT_TARGET	= $(MODULE).lint
627c478bd9Sstevel@tonic-gateINSTALL_TARGET	= $(BINARY) $(ROOTMODULE)
637c478bd9Sstevel@tonic-gate
647c478bd9Sstevel@tonic-gate#
657c478bd9Sstevel@tonic-gate#	Linkage dependencies
667c478bd9Sstevel@tonic-gate#
677c478bd9Sstevel@tonic-gateLDFLAGS += -dy
687c478bd9Sstevel@tonic-gate
697c478bd9Sstevel@tonic-gateCPPFLAGS	+= -I$(COM_DIR) -DCRYPTO_PROVIDER_NAME=\"$(MODULE)\"
707c478bd9Sstevel@tonic-gate
717c478bd9Sstevel@tonic-gate#
72bb25c06cSjg# For now, disable these lint checks; maintainers should endeavor
73bb25c06cSjg# to investigate and remove these for maximum lint coverage.
74bb25c06cSjg# Please do not carry these forward to new Makefiles.
75bb25c06cSjg#
76bb25c06cSjgLINTTAGS	+= -erroff=E_BAD_PTR_CAST_ALIGN
77bb25c06cSjgLINTTAGS	+= -erroff=E_SUPPRESSION_DIRECTIVE_UNUSED
78bb25c06cSjgLINTTAGS	+= -erroff=E_PTRDIFF_OVERFLOW
79bb25c06cSjg
80bb25c06cSjg#
817c478bd9Sstevel@tonic-gate#	Default build targets.
827c478bd9Sstevel@tonic-gate#
837c478bd9Sstevel@tonic-gate.KEEP_STATE:
847c478bd9Sstevel@tonic-gate
857c478bd9Sstevel@tonic-gatedef:		$(DEF_DEPS)
867c478bd9Sstevel@tonic-gate
877c478bd9Sstevel@tonic-gateall:		$(ALL_DEPS)
887c478bd9Sstevel@tonic-gate
897c478bd9Sstevel@tonic-gateclean:		$(CLEAN_DEPS)
907c478bd9Sstevel@tonic-gate
917c478bd9Sstevel@tonic-gateclobber:	$(CLOBBER_DEPS)
927c478bd9Sstevel@tonic-gate
937c478bd9Sstevel@tonic-gatelint:		$(LINT_DEPS)
947c478bd9Sstevel@tonic-gate
957c478bd9Sstevel@tonic-gatemodlintlib:	$(MODLINTLIB_DEPS)
967c478bd9Sstevel@tonic-gate
977c478bd9Sstevel@tonic-gateclean.lint:	$(CLEAN_LINT_DEPS)
987c478bd9Sstevel@tonic-gate
997c478bd9Sstevel@tonic-gateinstall:	$(INSTALL_DEPS)
1007c478bd9Sstevel@tonic-gate
1017c478bd9Sstevel@tonic-gate#
1027c478bd9Sstevel@tonic-gate#	Include common targets.
1037c478bd9Sstevel@tonic-gate#
1047c478bd9Sstevel@tonic-gateinclude $(UTSBASE)/intel/Makefile.targ
105*90bcde94Sda73024
106*90bcde94Sda73024$(OBJS_DIR)/%.ln: $(COM_DIR)/amd64/%.c
107*90bcde94Sda73024	@($(LHEAD) $(LINT.c) $(COM_DIR)/amd64/${@F:.ln=.c} $(LTAIL))
108*90bcde94Sda73024
109*90bcde94Sda73024$(OBJS_DIR)/%.o:  $(COM_DIR)/amd64/%.c
110*90bcde94Sda73024	$(COMPILE.c) -o $@ $(COM_DIR)/amd64/${@F:.o=.c}
111*90bcde94Sda73024	$(POST_PROCESS_O)
112*90bcde94Sda73024
113*90bcde94Sda73024$(OBJS_DIR)/aes_amd64.o: $(COM_DIR)/amd64/aes_amd64.s
114*90bcde94Sda73024	$(COMPILE.s) -o $@ $(COM_DIR)/amd64/${@F:.o=.s}
115*90bcde94Sda73024	$(POST_PROCESS_O)
116*90bcde94Sda73024
117*90bcde94Sda73024$(OBJS_DIR)/aes_amd64.ln: $(COM_DIR)/amd64/aes_amd64.s
118*90bcde94Sda73024	@($(LHEAD) $(LINT.s) $(COM_DIR)/amd64/${@F:.ln=.s} $(LTAIL))
119