xref: /titanic_51/usr/src/uts/sun4v/Makefile (revision 9ef7884d729f1f09cb82e5c2f57d12cb9f4c1fee)
17c478bd9Sstevel@tonic-gate#
27c478bd9Sstevel@tonic-gate# CDDL HEADER START
37c478bd9Sstevel@tonic-gate#
47c478bd9Sstevel@tonic-gate# The contents of this file are subject to the terms of the
5*9ef7884dSanovick# Common Development and Distribution License (the "License").
6*9ef7884dSanovick# You may not use this file except in compliance with the License.
77c478bd9Sstevel@tonic-gate#
87c478bd9Sstevel@tonic-gate# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
97c478bd9Sstevel@tonic-gate# or http://www.opensolaris.org/os/licensing.
107c478bd9Sstevel@tonic-gate# See the License for the specific language governing permissions
117c478bd9Sstevel@tonic-gate# and limitations under the License.
127c478bd9Sstevel@tonic-gate#
137c478bd9Sstevel@tonic-gate# When distributing Covered Code, include this CDDL HEADER in each
147c478bd9Sstevel@tonic-gate# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
157c478bd9Sstevel@tonic-gate# If applicable, add the following below this CDDL HEADER, with the
167c478bd9Sstevel@tonic-gate# fields enclosed by brackets "[]" replaced with your own identifying
177c478bd9Sstevel@tonic-gate# information: Portions Copyright [yyyy] [name of copyright owner]
187c478bd9Sstevel@tonic-gate#
197c478bd9Sstevel@tonic-gate# CDDL HEADER END
207c478bd9Sstevel@tonic-gate#
217c478bd9Sstevel@tonic-gate#
22*9ef7884dSanovick# Copyright 2006 Sun Microsystems, Inc.  All rights reserved.
237c478bd9Sstevel@tonic-gate# Use is subject to license terms.
247c478bd9Sstevel@tonic-gate#
257c478bd9Sstevel@tonic-gate# ident	"%Z%%M%	%I%	%E% SMI"
267c478bd9Sstevel@tonic-gate#
277c478bd9Sstevel@tonic-gate#	This makefile drives the production of all implementation architecture
287c478bd9Sstevel@tonic-gate#	dependent modules for the sun4v architecture.
297c478bd9Sstevel@tonic-gate#
307c478bd9Sstevel@tonic-gate
317c478bd9Sstevel@tonic-gateUTSBASE = ..
327c478bd9Sstevel@tonic-gate
337c478bd9Sstevel@tonic-gateinclude Makefile.sun4v
34*9ef7884dSanovickinclude Makefile.stpaul
357c478bd9Sstevel@tonic-gate
367c478bd9Sstevel@tonic-gate#
377c478bd9Sstevel@tonic-gate#	The following are SPARC specific (rather than sun4v) specific modules
387c478bd9Sstevel@tonic-gate#	which are required for the sun4v kernel to completely lint. They are
397c478bd9Sstevel@tonic-gate#	not involved in the build in any other way. In order to minimize
407c478bd9Sstevel@tonic-gate#	build time, it is assumed that they are up to date. But since sun4v
417c478bd9Sstevel@tonic-gate#	is really a separate architecture we cannot use the v7 sparc modules.
427c478bd9Sstevel@tonic-gate#
437c478bd9Sstevel@tonic-gateSPARC_LIB_DIR	 = $(UTSBASE)/sparc/lint-libs/$(OBJS_DIR)
447c478bd9Sstevel@tonic-gate
457c478bd9Sstevel@tonic-gateSPARC_LINTS	 =
467c478bd9Sstevel@tonic-gate
477c478bd9Sstevel@tonic-gate#
487c478bd9Sstevel@tonic-gate#
497c478bd9Sstevel@tonic-gate#
507c478bd9Sstevel@tonic-gateLINT_LIBS	 = $(LINT_LIB) \
517c478bd9Sstevel@tonic-gate		   $(LINT_KMODS:%=$(LINT_LIB_DIR)/llib-l%.ln) \
52fb9f9b97Skupfer		   $(CLOSED_LINT_KMODS:%=$(LINT_LIB_DIR)/llib-l%.ln) \
537c478bd9Sstevel@tonic-gate		   $(SPARC_LINTS:%=$(SPARC_LIB_DIR)/llib-l%.ln)
547c478bd9Sstevel@tonic-gate
55554ff184Skais# EXPORT DELETE START
56554ff184Skais#
57554ff184Skais# CRYPTO_EK_KMODS modules go in the encryption pack (SUNWcry*)
58554ff184Skais# They need to be listed separately since they duplicate global symbols
59554ff184Skais# causing the 2nd pass of lint on the kernel to complain. CRYPTO_EK_KMODS
60554ff184Skais# should not be listed in the lint target.
61554ff184Skais#
62fb9f9b97Skupfer# Don't build this for OpenSolaris, since it will be replaced by
63fb9f9b97Skupfer# a binary that is signed by Sun RE.
64fb9f9b97Skupfer#
65fb9f9b97Skupfer$(CLOSED_BUILD)CRYPTO_EK_KMODS	+= arcfour2048
66554ff184Skais# EXPORT DELETE END
67554ff184Skais
687c478bd9Sstevel@tonic-gatedef		:=	TARGET= def
697c478bd9Sstevel@tonic-gateall		:=	TARGET= all
707c478bd9Sstevel@tonic-gateinstall		:=	TARGET= install
717c478bd9Sstevel@tonic-gateinstall_h	:=	TARGET= install_h
727c478bd9Sstevel@tonic-gateclean		:=	TARGET= clean
737c478bd9Sstevel@tonic-gateclobber		:=	TARGET= clobber
747c478bd9Sstevel@tonic-gatelint		:=	TARGET= lint
757c478bd9Sstevel@tonic-gatelintlib		:=	TARGET= lintlib
767c478bd9Sstevel@tonic-gatemodlintlib	:=	TARGET= modlintlib
77fb9f9b97Skupfermodlist		:=	TARGET= modlist
78fb9f9b97Skupfermodlist	modlist.sparc :=	NO_STATE= -K $$MODSTATE$$$$
797c478bd9Sstevel@tonic-gateclean.lint	:=	TARGET= clean.lint
807c478bd9Sstevel@tonic-gatecheck		:=	TARGET= check
817c478bd9Sstevel@tonic-gate
827c478bd9Sstevel@tonic-gate.KEEP_STATE:
837c478bd9Sstevel@tonic-gate
84fb9f9b97Skupfer.PARALLEL:	$(KMODS) $(CLOSED_KMODS) $(XMODS) $(CLOSED_XMODS) \
85fb9f9b97Skupfer		modlist modlist.sparc
867c478bd9Sstevel@tonic-gate
877c478bd9Sstevel@tonic-gate# Override for CPU_KMODS... they cannot be built
887c478bd9Sstevel@tonic-gate# in parallel
897c478bd9Sstevel@tonic-gate.NO_PARALLEL:	$(CPU_KMODS)
907c478bd9Sstevel@tonic-gate
91fb9f9b97Skupferdef all clean clobber clean.lint: genassym unix .WAIT \
92fb9f9b97Skupfer	$(KMODS) $(CLOSED_KMODS) $(XMODS) $(CLOSED_XMODS) $(IMPLEMENTATIONS)
93fb9f9b97Skupfer
94fb9f9b97Skupfer# list the modules under sun4v.
95fb9f9b97Skupfermodlist: unix $(KMODS) $(CLOSED_KMODS) $(XMODS) $(CLOSED_XMODS) \
967c478bd9Sstevel@tonic-gate	$(IMPLEMENTATIONS)
977c478bd9Sstevel@tonic-gate
98fb9f9b97Skupfer# list the modules for Install -k sun4v.
99fb9f9b97Skupfermodlist.karch: modlist modlist.sparc
100fb9f9b97Skupfer
101fb9f9b97Skupfermodlist.sparc:
102fb9f9b97Skupfer	@cd $(SRC)/uts/sparc; pwd; $(MAKE) $(NO_STATE) modlist
103fb9f9b97Skupfer
104fb9f9b97Skupferinstall: install_platforms genassym unix .WAIT $(KMODS) $(CLOSED_KMODS) \
105fb9f9b97Skupfer	$(XMODS) $(CLOSED_XMODS) $(IMPLEMENTATIONS)
1067c478bd9Sstevel@tonic-gate
1077c478bd9Sstevel@tonic-gatelintlib:	unix
1087c478bd9Sstevel@tonic-gate
109fb9f9b97Skupfermodlintlib:	$(LINT_KMODS) $(CLOSED_LINT_KMODS)
1107c478bd9Sstevel@tonic-gate
111fb9f9b97Skupfergenassym unix $(KMODS):	FRC
112fb9f9b97Skupfer	@cd $@; pwd; $(MAKE) $(NO_STATE) $(TARGET)
113fb9f9b97Skupfer
114fb9f9b97Skupfer$(IMPLEMENTATIONS):	FRC
115fb9f9b97Skupfer	@cd $@; pwd; THISIMPL=$@ $(MAKE) $(NO_STATE) $(TARGET)
1167c478bd9Sstevel@tonic-gate
1177c478bd9Sstevel@tonic-gate$(XMODS):	FRC
1187c478bd9Sstevel@tonic-gate	@if [ -f $@/Makefile  ]; then \
119fb9f9b97Skupfer		cd $@; pwd; $(MAKE) $(NO_STATE) $(TARGET); \
1207c478bd9Sstevel@tonic-gate	else \
1217c478bd9Sstevel@tonic-gate		true; \
1227c478bd9Sstevel@tonic-gate	fi
1237c478bd9Sstevel@tonic-gate
124fb9f9b97Skupfer$(CLOSED_XMODS):	FRC
125fb9f9b97Skupfer	@if [ -f $(CLOSED)/uts/sun4v/$@/Makefile  ]; then \
126fb9f9b97Skupfer		cd $(CLOSED)/uts/sun4v/$@; pwd; \
127fb9f9b97Skupfer		    $(MAKE) $(NO_STATE) $(TARGET); \
128fb9f9b97Skupfer	else \
129fb9f9b97Skupfer		true; \
130fb9f9b97Skupfer	fi
131fb9f9b97Skupfer
132fb9f9b97Skupfer$(CLOSED_KMODS):	FRC
133fb9f9b97Skupfer	cd $(CLOSED)/uts/sun4v/$@; pwd; $(MAKE) $(NO_STATE) $(TARGET)
134fb9f9b97Skupfer
1357c478bd9Sstevel@tonic-gateinstall_h check:	install_platforms $(IMPLEMENTATIONS) FRC
1367c478bd9Sstevel@tonic-gate	@cd sys; pwd; $(MAKE) $(TARGET)
1377c478bd9Sstevel@tonic-gate	@cd vm; pwd; $(MAKE) $(TARGET)
1387c478bd9Sstevel@tonic-gate
1397c478bd9Sstevel@tonic-gate#
1407c478bd9Sstevel@tonic-gate# Rules for the /platforms directories.  This is hardwired here because
1417c478bd9Sstevel@tonic-gate# the first stage of the project (KBI) only implements the userland
1427c478bd9Sstevel@tonic-gate# changes, but the only reasonable place to record the aliases is
1437c478bd9Sstevel@tonic-gate# here in kernel land.
1447c478bd9Sstevel@tonic-gate#
1457c478bd9Sstevel@tonic-gate$(ROOT_PLAT_DIRS): $(ROOT_PLAT_DIR)
1467c478bd9Sstevel@tonic-gate	-$(INS.dir.root.sys)
1477c478bd9Sstevel@tonic-gate
148b7f45089Sdf157793$(LINKED_PLATFORMS:%=$(ROOT_PLAT_DIR)/%): $(ROOT_PLAT_DIR)
149b7f45089Sdf157793	$(INS.slink1)
150b7f45089Sdf157793
1517c478bd9Sstevel@tonic-gate#
1527c478bd9Sstevel@tonic-gate# create directories in /usr/platform/ for the implementations that are
1537c478bd9Sstevel@tonic-gate# defined in $(IMPLEMENTED_PLATFORM)
1547c478bd9Sstevel@tonic-gate#
1557c478bd9Sstevel@tonic-gate
1567c478bd9Sstevel@tonic-gate# Foreach $(IMPLEMENTED_PLATFORM) there can be a list of $(LINKED_PLATFORMS)
1577c478bd9Sstevel@tonic-gate# that are linked to it.
1587c478bd9Sstevel@tonic-gate#
1597c478bd9Sstevel@tonic-gate$(USR_PLAT_DIR)/$(IMPLEMENTED_PLATFORM):	$(USR_PLAT_DIR)
1607c478bd9Sstevel@tonic-gate	-$(INS.dir.root.sys)
1617c478bd9Sstevel@tonic-gate
1627c478bd9Sstevel@tonic-gate#
1637c478bd9Sstevel@tonic-gate# create the links in /usr/platform/ foreach $(LINKED_PLATFORMS)
1647c478bd9Sstevel@tonic-gate# to it's corresponding $(IMPLEMENTED_PLATFORM).
1657c478bd9Sstevel@tonic-gate#
1667c478bd9Sstevel@tonic-gatePLATFORMS	= $(LINKED_PLATFORMS)
1677c478bd9Sstevel@tonic-gate
1687c478bd9Sstevel@tonic-gate$(USR_PLAT_DIRS): $(USR_PLAT_DIR)
1697c478bd9Sstevel@tonic-gate	$(INS.slink3)
1707c478bd9Sstevel@tonic-gate
1717c478bd9Sstevel@tonic-gatePLATFORMS	+= $(IMPLEMENTED_PLATFORM)
1727c478bd9Sstevel@tonic-gate
1737c478bd9Sstevel@tonic-gate#
1747c478bd9Sstevel@tonic-gate# Make the /platforms directories.  This is hardwired here because
1757c478bd9Sstevel@tonic-gate# the first stage of the project (KBI) only implements the userland
1767c478bd9Sstevel@tonic-gate# changes, but the only reasonable place to record the aliases is
1777c478bd9Sstevel@tonic-gate# here in kernel land.
1787c478bd9Sstevel@tonic-gate#
1797c478bd9Sstevel@tonic-gateinstall_platforms:	$(ROOT_PSM_DIR) $(USR_PSM_DIR) \
1807c478bd9Sstevel@tonic-gate			$(ROOT_PLAT_DIRS) $(USR_PLAT_DIRS) \
181b7f45089Sdf157793			$(LINKED_PLATFORMS:%=$(ROOT_PLAT_DIR)/%) \
1827c478bd9Sstevel@tonic-gate			$(USR_DESKTOP_DIR) $(USR_DESKTOP_INC_DIR) \
183*9ef7884dSanovick			$(USR_DESKTOP_SBIN_DIR) $(USR_DESKTOP_LIB_DIR) \
184*9ef7884dSanovick			$(USR_STPAUL_DIR) $(USR_STPAUL_SBIN_DIR) \
185*9ef7884dSanovick			$(USR_STPAUL_LIB_DIR)
1867c478bd9Sstevel@tonic-gate
1877c478bd9Sstevel@tonic-gate#
1887c478bd9Sstevel@tonic-gate# rules for making include, sbin, lib dirs/links in
1897c478bd9Sstevel@tonic-gate# /usr/platform/$(PLATFORM)/ for desktop platforms
1907c478bd9Sstevel@tonic-gate#
1917c478bd9Sstevel@tonic-gate$(USR_DESKTOP_INC_DIR):		$(USR_DESKTOP_DIR)
1927c478bd9Sstevel@tonic-gate	$(INS.slink4)
1937c478bd9Sstevel@tonic-gate
1947c478bd9Sstevel@tonic-gate$(USR_DESKTOP_SBIN_DIR):	$(USR_DESKTOP_DIR)
1957c478bd9Sstevel@tonic-gate	$(INS.slink5)
1967c478bd9Sstevel@tonic-gate
197*9ef7884dSanovick$(USR_STPAUL_DIR):		$(USR_SUN4V_PLAT_DIR)
198*9ef7884dSanovick	-$(INS.dir.root.sys)
199*9ef7884dSanovick
200*9ef7884dSanovick$(USR_STPAUL_SBIN_DIR):		$(USR_STPAUL_DIR)
201*9ef7884dSanovick	$(INS.slink5)
202*9ef7884dSanovick
203*9ef7884dSanovick$(USR_STPAUL_LIB_DIR):		$(USR_STPAUL_DIR)
204*9ef7884dSanovick	-$(INS.dir.root.bin)
205*9ef7884dSanovick
2067c478bd9Sstevel@tonic-gate$(USR_DESKTOP_LIB_DIR):		$(USR_DESKTOP_DIR)
2077c478bd9Sstevel@tonic-gate	-$(INS.dir.root.bin)
2087c478bd9Sstevel@tonic-gate
2097c478bd9Sstevel@tonic-gate#
2107c478bd9Sstevel@tonic-gate#	Full kernel lint target.
2117c478bd9Sstevel@tonic-gate#
2127c478bd9Sstevel@tonic-gateLINT_TARGET	= globallint
2137c478bd9Sstevel@tonic-gate
2147c478bd9Sstevel@tonic-gategloballint:
2157c478bd9Sstevel@tonic-gate	@-$(ECHO) "\nSUN4V KERNEL: global crosschecks:"
2167c478bd9Sstevel@tonic-gate	@-$(LINT) $(LINTFLAGS) $(LINT_LIBS) 2>&1 | $(LGREP.2)
2177c478bd9Sstevel@tonic-gate
2187c478bd9Sstevel@tonic-gatelint:	lintlib .WAIT modlintlib .WAIT $(SPARC_LINTS) $(LINT_DEPS) \
2197c478bd9Sstevel@tonic-gate	$(IMPLEMENTATIONS)
2207c478bd9Sstevel@tonic-gate
2217c478bd9Sstevel@tonic-gate# EXPORT DELETE START
2227c478bd9Sstevel@tonic-gate
2237c478bd9Sstevel@tonic-gateEXPORT_SRC:
2247c478bd9Sstevel@tonic-gate	$(RM) Makefile+
2257c478bd9Sstevel@tonic-gate	sed -e "/^# EXPORT DELETE START/,/^# EXPORT DELETE END/d" \
2267c478bd9Sstevel@tonic-gate	    < Makefile > Makefile+
2277c478bd9Sstevel@tonic-gate	$(MV) Makefile+ Makefile
2287c478bd9Sstevel@tonic-gate	$(CHMOD) 444 Makefile
2297c478bd9Sstevel@tonic-gate
2307c478bd9Sstevel@tonic-gate# EXPORT DELETE END
2317c478bd9Sstevel@tonic-gate
2327c478bd9Sstevel@tonic-gateinclude ../Makefile.targ
2337c478bd9Sstevel@tonic-gate
2347c478bd9Sstevel@tonic-gate#
2357c478bd9Sstevel@tonic-gate# Cross-reference customization: build a cross-reference over all of the
2367c478bd9Sstevel@tonic-gate# sun4v-related directories.
2377c478bd9Sstevel@tonic-gate#
238fb9f9b97SkupferSHARED_XRDIRS	= ../sun4v ../sun4 ../sfmmu ../sparc ../sun ../common
239fb9f9b97SkupferCLOSED_XRDIRS	= $(SHARED_XRDIRS:../%=../% ../../../closed/uts/%)
240fb9f9b97SkupferXRDIRS		= $(SHARED_XRDIRS)
241fb9f9b97Skupfer$(CLOSED_BUILD)XRDIRS	= $(CLOSED_XRDIRS:../../../closed/uts/sfmmu=)
242fb9f9b97Skupfer
2437c478bd9Sstevel@tonic-gateXRPRUNE = i86pc
2447c478bd9Sstevel@tonic-gate
2457c478bd9Sstevel@tonic-gatecscope.out tags: FRC
2467c478bd9Sstevel@tonic-gate	$(XREF) -x $@
247