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 2008 Sun Microsystems, Inc. All rights reserved.
23 # Use is subject to license terms.
24 #
25 #ident "@(#)Makefile 1.9 08/05/21 SMI"
26 #
27 # This makefile drives the production of the AES KEF provider.
28 #
29 # intel implementation architecture dependent
30 #
31
32 #
33 # Path to the base of the uts directory tree (usually /usr/src/uts).
34 #
35 UTSBASE = ../..
36 COM_DIR = $(COMMONBASE)/crypto/aes
37
38 #
39 # Define the module and object file sets.
40 #
41 MODULE = aes
42 LINTS = $(AESPROV_OBJS:%.o=$(LINTS_DIR)/%.ln)
43 AESPROV_OBJS_32 =
44 AESPROV_OBJS_64 = aes_amd64.o aeskey.o
45 AESPROV_OBJS += $(AESPROV_OBJS_$(CLASS))
46 OBJECTS = $(AESPROV_OBJS:%=$(OBJS_DIR)/%)
47 ROOTMODULE = $(ROOT_CRYPTO_DIR)/$(MODULE)
48
49 #
50 # Include common rules.
51 #
52 include $(UTSBASE)/intel/Makefile.intel
53
54 # set signing mode
55 ELFSIGN_MOD = $(ELFSIGN_CRYPTO)
56
57 #
58 # Define targets
59 #
60 ALL_TARGET = $(BINARY)
61 LINT_TARGET = $(MODULE).lint
62 INSTALL_TARGET = $(BINARY) $(ROOTMODULE)
63
64 #
65 # Linkage dependencies
66 #
67 LDFLAGS += -dy
68
69 CPPFLAGS += -I$(COM_DIR) -DCRYPTO_PROVIDER_NAME=\"$(MODULE)\"
70
71 #
72 # For now, disable these lint checks; maintainers should endeavor
73 # to investigate and remove these for maximum lint coverage.
74 # Please do not carry these forward to new Makefiles.
75 #
76 LINTTAGS += -erroff=E_BAD_PTR_CAST_ALIGN
77 LINTTAGS += -erroff=E_SUPPRESSION_DIRECTIVE_UNUSED
78 LINTTAGS += -erroff=E_PTRDIFF_OVERFLOW
79
80 #
81 # Default build targets.
82 #
83 .KEEP_STATE:
84
85 def: $(DEF_DEPS)
86
87 all: $(ALL_DEPS)
88
89 clean: $(CLEAN_DEPS)
90
91 clobber: $(CLOBBER_DEPS)
92
93 lint: $(LINT_DEPS)
94
95 modlintlib: $(MODLINTLIB_DEPS)
96
97 clean.lint: $(CLEAN_LINT_DEPS)
98
99 install: $(INSTALL_DEPS)
100
101 #
102 # Include common targets.
103 #
104 include $(UTSBASE)/intel/Makefile.targ
105
106 $(OBJS_DIR)/%.ln: $(COM_DIR)/amd64/%.c
107 @($(LHEAD) $(LINT.c) $(COM_DIR)/amd64/${@F:.ln=.c} $(LTAIL))
108
109 $(OBJS_DIR)/%.o: $(COM_DIR)/amd64/%.c
110 $(COMPILE.c) -o $@ $(COM_DIR)/amd64/${@F:.o=.c}
111 $(POST_PROCESS_O)
112
113 $(OBJS_DIR)/aes_amd64.o: $(COM_DIR)/amd64/aes_amd64.s
114 $(COMPILE.s) -o $@ $(COM_DIR)/amd64/${@F:.o=.s}
115 $(POST_PROCESS_O)
116
117 $(OBJS_DIR)/aes_amd64.ln: $(COM_DIR)/amd64/aes_amd64.s
118 @($(LHEAD) $(LINT.s) $(COM_DIR)/amd64/${@F:.ln=.s} $(LTAIL))