xref: /titanic_41/usr/src/uts/sun4u/opl/Makefile (revision 74e20cfe817b82802b16fac8690dadcda76f54f5)
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 2006 Sun Microsystems, Inc.  All rights reserved.
23# Use is subject to license terms.
24#
25# ident	"%Z%%M%	%I%	%E% SMI"
26#
27#	This makefile drives the production of the sun4u opl platform
28#	module.
29#
30#	sun4u opl implementation architecture dependent
31#
32# uts/sun4u/opl/Makefile
33
34#
35#	Path to the base of the uts directory tree (usually /usr/src/uts).
36#
37UTSBASE	= ../..
38
39#
40#       Include common rules.
41#
42include $(UTSBASE)/sun4u/opl/Makefile.opl
43
44def		:=	TARGET= def
45all		:=	TARGET= all
46install		:=	TARGET= install
47install_h	:=	TARGET= install_h
48clean		:=	TARGET= clean
49clobber		:=	TARGET= clobber
50lint		:=	TARGET= lint
51lintlib		:=	TARGET= lintlib
52modlist		:=	TARGET= modlist
53modlist		:=	NO_STATE= -K $$MODSTATE$$$$
54modlintlib	:=	TARGET= modlintlib
55clean.lint	:=	TARGET= clean.lint
56check		:=	TARGET= check
57
58#
59#	Default build targets.
60#
61.KEEP_STATE:
62
63def all clean clobber clean.lint: genassym unix .WAIT \
64		$(OPL_CPU_KMODS) $(OPL_KMODS) $(CLOSED_OPL_KMODS)
65
66modlist:	unix $(OPL_CPU_KMODS) $(OPL_KMODS) $(CLOSED_OPL_KMODS)
67
68lintlib:	unix
69
70modlintlib:	$(OPL_KMODS) $(CLOSED_OPL_KMODS)
71
72IMPLEMENTED_PLATFORM	= SUNW,SPARC-Enterprise
73
74# EXPORT DELETE START
75#
76# aes256 is delivered in the SUNWcryr package which is removed from
77# the EXPORT_SRC build.
78#
79OPL_CRYPTO_LINKS	+= aes256
80# EXPORT DELETE END
81
82install: $(ROOT_OPL_DIR) $(USR_OPL_DIR) \
83	$(USR_OPL_INC_DIR) \
84	$(USR_OPL_SBIN_DIR) \
85	$(USR_OPL_SBIN_EEPROM) \
86	$(USR_OPL_SBIN_PRTDIAG) \
87	$(USR_OPL_SBIN_TRAPSTAT) \
88	$(USR_OPL_SBIN_FRUADM) \
89	$(USR_OPL_LIB_DIR) \
90	$(OPL_CRYPTO_LINKS) \
91	genassym unix .WAIT $(OPL_CPU_KMODS) $(OPL_KMODS) \
92	$(CLOSED_OPL_KMODS) $(OPLMSU_OPTION)
93
94genassym unix $(OPL_KMODS) $(OPL_CPU_KMODS): FRC
95	@cd $@; pwd; $(MAKE) $(TARGET)
96
97$(CLOSED_OPL_KMODS): FRC
98	cd $(CLOSED)/uts/sun4u/opl/$@; pwd; $(MAKE) $(NO_STATE) $(TARGET)
99
100$(OPL_CRYPTO_LINKS): $(ROOT_OPL_CRYPTO_DIR_64)
101	-$(RM) $(ROOT_OPL_CRYPTO_DIR_64)/$@
102	$(SYMLINK) $(ROOT_US3_CRYPTO_LINK)/$@ $(ROOT_OPL_CRYPTO_DIR_64)/$@
103
104$(OPLMSU_OPTION):	FRC
105	@cd $@; pwd; $(MAKE) $(TARGET)
106
107install_h check:	FRC
108	@cd sys; pwd; $(MAKE) $(TARGET)
109
110lint:	modlintlib
111
112
113#
114# The 'lint.platmod' target lints the opl platform module against
115# the sun4u kernel.  This ends up doing all the kernel cross-checks,
116# so it takes a couple of minutes.
117# Due to the low ROI, it's not run by default, but it's a good
118# idea to run this if you change os/opl.c.
119#
120
121LINT_LIBS	= $(LINT_LIB) \
122		  -L$(OPL_LINT_LIB_DIR) \
123		  -L$(LINT_LIB_DIR) $(LINT_KMODS:%=-l%) \
124		      $(CLOSED_LINT_KMODS:%=-l%) \
125		  -L$(SPARC_LIB_DIR) $(SPARC_LINTS:%=-l%)
126
127lint.platmod:   modlintlib
128	@-$(ECHO) "\nOpl Platform-dependent module: global crosschecks:"
129	@-$(LINT) $(LINTFLAGS) $(LINT_LIBS) 2>&1 | $(LGREP.2)
130
131# EXPORT DELETE START
132
133EXPORT_SRC:
134	$(RM) Makefile+
135	$(SED) -e "/^# EXPORT DELETE START/,/^# EXPORT DELETE END/d" \
136	    < Makefile > Makefile+
137	$(MV) Makefile+ Makefile
138	$(CHMOD) 444 Makefile
139
140# EXPORT DELETE END
141
142#
143#
144#	Include common targets.
145#
146include $(UTSBASE)/sun4u/opl/Makefile.targ
147