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