xref: /titanic_50/usr/src/uts/intel/kcf/Makefile (revision 5d3b8cb7141cfa596d20cdc5043b8a6df635938d)
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 # Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
23 # Use is subject to license terms.
24 #
25 #	This makefile drives the production of the Kernel Cryptographic
26 #	Framework core module.
27 #
28 #	Intel implementation architecture dependent
29 #
30 
31 #
32 #	Path to the base of the uts directory tree (usually /usr/src/uts).
33 #
34 UTSBASE	= ../..
35 COM_DIR = $(COMMONBASE)/crypto
36 
37 #
38 #	Define the module and object file sets.
39 #
40 MODULE		= kcf
41 LINTS		= $(KCF_OBJS:%.o=$(LINTS_DIR)/%.ln)
42 KCF_OBJS_32	=
43 KCF_OBJS_64	= gcm_intel.o
44 KCF_OBJS	+= $(KCF_OBJS_$(CLASS))
45 OBJECTS		= $(KCF_OBJS:%=$(OBJS_DIR)/%)
46 ROOTMODULE	= $(ROOT_MISC_DIR)/$(MODULE)
47 
48 #
49 #	Include common rules.
50 #
51 include $(UTSBASE)/intel/Makefile.intel
52 
53 #
54 #	Define targets
55 #
56 ALL_TARGET	= $(BINARY)
57 LINT_TARGET	= $(MODULE).lint
58 INSTALL_TARGET	= $(BINARY) $(ROOTMODULE)
59 
60 #
61 # For now, disable these lint checks; maintainers should endeavor
62 # to investigate and remove these for maximum lint coverage.
63 # Please do not carry these forward to new Makefiles.
64 #
65 LINTTAGS	+= -erroff=E_SUSPICIOUS_COMPARISON
66 LINTTAGS	+= -erroff=E_BAD_PTR_CAST_ALIGN
67 
68 LINTTAGS	+= -I$(COM_DIR)
69 
70 #
71 # Linkage dependencies
72 #
73 
74 CFLAGS		+= $(CCVERBOSE) -I$(COM_DIR)
75 AS_CPPFLAGS	+= -I../../$(PLATFORM)
76 
77 #
78 #	Default build targets.
79 #
80 .KEEP_STATE:
81 
82 def:		$(DEF_DEPS)
83 
84 all:		$(ALL_DEPS)
85 
86 clean:		$(CLEAN_DEPS)
87 
88 clobber:	$(CLOBBER_DEPS)
89 
90 lint:		$(LINT_DEPS)
91 
92 modlintlib:	$(MODLINTLIB_DEPS)
93 
94 clean.lint:	$(CLEAN_LINT_DEPS)
95 
96 install:	$(INSTALL_DEPS)
97 
98 #
99 #	Include common targets.
100 #
101 include $(UTSBASE)/intel/Makefile.targ
102 
103 $(OBJS_DIR)/%.o: $(COM_DIR)/modes/amd64/%.s
104 	$(COMPILE.s) -o $@ $(COM_DIR)/modes/amd64/${@F:.o=.s}
105 	$(POST_PROCESS_O)
106 
107 $(OBJS_DIR)/%.ln: $(COM_DIR)/modes/amd64/%.s
108 	@($(LHEAD) $(LINT.s) $(COM_DIR)/modes/amd64/${@F:.ln=.s} $(LTAIL))
109