xref: /titanic_51/usr/src/uts/sun4u/seattle/Makefile (revision 72bdce51192b13a20009855f749004480874291b)
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 2007 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_PRTDIAG) \
83		$(USR_SEATTLE_SBIN_TRAPSTAT) \
84		$(USR_SEATTLE_SBIN_FRUADM) \
85		$(USR_SEATTLE_LIB_DIR) \
86		$(LINKED_PLATFORMS:%=$(USR_PLAT_DIR)/%) \
87		$(LINKED_PLATFORMS:%=$(ROOT_PLAT_DIR)/%) \
88		$(SEATTLE_CRYPTO_LINKS) \
89		.WAIT $(SEATTLE_KMODS)
90
91check install_h:
92
93lint:		modlintlib
94
95#
96# The 'lint.platmod' target lints the seattle platform module against the sun4u
97# kernel.  This ends up doing all the kernel cross-checks, so it takes a couple
98# of minutes.  Due to the low ROI, it's not run by default, but it's a good
99# idea to run this if you change os/seattle.c.
100#
101LINT_LIBS	 = $(LINT_LIB) \
102		   -L$(SEATTLE_LINT_LIB_DIR) \
103		   -L$(LINT_LIB_DIR) $(LINT_KMODS:%=-l%) \
104			$(CLOSED_LINT_KMODS:%=-l%) \
105		   -L$(SPARC_LIB_DIR) $(SPARC_LINTS:%=-l%)
106
107lint.platmod:	modlintlib
108	@-$(ECHO) "\nSeattle Platform-dependent module: global crosschecks:"
109	@-$(LINT) $(LINTFLAGS) $(LINT_LIBS) 2>&1 | $(LGREP.2)
110
111$(SEATTLE_KMODS): FRC
112	@cd $@; pwd; $(MAKE) $(NO_STATE) $(TARGET)
113
114$(SEATTLE_CRYPTO_LINKS): $(ROOT_SEATTLE_CRYPTO_DIR_64)
115	-$(RM) $(ROOT_SEATTLE_CRYPTO_DIR_64)/$@;
116	$(SYMLINK) $(ROOT_US3_CRYPTO_LINK)/$@ $(ROOT_SEATTLE_CRYPTO_DIR_64)/$@
117
118# EXPORT DELETE START
119
120EXPORT_SRC:
121	$(RM) Makefile+
122	sed -e "/^# EXPORT DELETE START/,/^# EXPORT DELETE END/d" \
123	    < Makefile > Makefile+
124	$(MV) Makefile+ Makefile
125	$(CHMOD) 444 Makefile
126
127# EXPORT DELETE END
128
129#
130#
131#	Include common targets.
132#
133include $(UTSBASE)/sun4u/seattle/Makefile.targ
134