xref: /titanic_52/usr/src/uts/intel/Makefile (revision 080575042aba2197b425ebfd52061dea061a9aa1)
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
588543b5cSkrishna# Common Development and Distribution License (the "License").
688543b5cSkrishna# 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# uts/intel/Makefile
227c478bd9Sstevel@tonic-gate#
23ae115bc7Smrj# Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
247c478bd9Sstevel@tonic-gate# Use is subject to license terms.
257c478bd9Sstevel@tonic-gate#
267c478bd9Sstevel@tonic-gate# ident	"%Z%%M%	%I%	%E% SMI"
277c478bd9Sstevel@tonic-gate#
287c478bd9Sstevel@tonic-gate#
297c478bd9Sstevel@tonic-gate#	This makefile drives the production of all implementation architecture
307c478bd9Sstevel@tonic-gate#	independent modules for Intel processors.
317c478bd9Sstevel@tonic-gate
327c478bd9Sstevel@tonic-gateUTSBASE = ..
337c478bd9Sstevel@tonic-gate
347c478bd9Sstevel@tonic-gateinclude Makefile.intel
357c478bd9Sstevel@tonic-gate
36*08057504Sxy150489LINT_KMODLIBS	= $(LINT_KMODS:e1000g=)
377c478bd9Sstevel@tonic-gateLINT_LIBS	= $(LINT_LIB) $(GEN_LINT_LIB) \
38*08057504Sxy150489		  $(LINT_KMODLIBS:%=$(LINT_LIB_DIR)/llib-l%.ln) \
39fb9f9b97Skupfer		  $(CLOSED_LINT_KMODS:%=$(LINT_LIB_DIR)/llib-l%.ln)
407c478bd9Sstevel@tonic-gate
417c478bd9Sstevel@tonic-gate# EXPORT DELETE START
4288543b5cSkrishna$(CLOSED_BUILD)LINT_LIBS	+= $(SVVS_KMODS:%=$(LINT_LIB_DIR)/llib-l%.ln)
43*08057504Sxy150489$(CLOSED_BUILD)LINT_CLOSED_XMOD3	= $(CLOSED_XMODS:lsimega=)
44*08057504Sxy150489$(CLOSED_BUILD)LINT_CLOSED_XMOD2	= $(LINT_CLOSED_XMOD3:spwr=)
45*08057504Sxy150489$(CLOSED_BUILD)LINT_CLOSED_XMOD1	= $(LINT_CLOSED_XMOD2:adpu320=)
46fb9f9b97Skupfer$(CLOSED_BUILD)LINT_XMODLIBS	= $(LINT_CLOSED_XMOD1:nge=)
47fb9f9b97Skupfer$(CLOSED_BUILD)LINT_LIBS	+= $(LINT_XMODLIBS:%=$(LINT_LIB_DIR)/llib-l%.ln)
487c478bd9Sstevel@tonic-gate
497c478bd9Sstevel@tonic-gate#
507c478bd9Sstevel@tonic-gate# dprov is delivered in the SUNWcrtptoint package.
517c478bd9Sstevel@tonic-gate#
527c478bd9Sstevel@tonic-gateDRV_KMODS	+= dprov
537c478bd9Sstevel@tonic-gate
547c478bd9Sstevel@tonic-gate#
557c478bd9Sstevel@tonic-gate# CRYPTO_EK_KMODS modules go in the encryption pack (SUNWcry*)
567c478bd9Sstevel@tonic-gate# They need to be listed separately since they duplicate global symbols
577c478bd9Sstevel@tonic-gate# causing the 2nd pass of lint on the kernel to complain. CRYPTO_EK_KMODS
587c478bd9Sstevel@tonic-gate# should not be listed in the lint target.
597c478bd9Sstevel@tonic-gate#
60fb9f9b97Skupfer# Don't build these for OpenSolaris, since they will be replaced by
61fb9f9b97Skupfer# binaries that are signed by Sun RE.
62fb9f9b97Skupfer#
63fb9f9b97Skupfer$(CLOSED_BUILD)CRYPTO_EK_KMODS	+= aes256
64fb9f9b97Skupfer$(CLOSED_BUILD)CRYPTO_EK_KMODS	+= arcfour2048
65fb9f9b97Skupfer$(CLOSED_BUILD)CRYPTO_EK_KMODS	+= blowfish448
667c478bd9Sstevel@tonic-gate
677c478bd9Sstevel@tonic-gate# EXPORT DELETE END
687c478bd9Sstevel@tonic-gate
697c478bd9Sstevel@tonic-gate#
707c478bd9Sstevel@tonic-gate#
717c478bd9Sstevel@tonic-gatedef		:=	TARGET= def
727c478bd9Sstevel@tonic-gateall		:=	TARGET= all
737c478bd9Sstevel@tonic-gateinstall		:=	TARGET= install
747c478bd9Sstevel@tonic-gateclean		:=	TARGET= clean
757c478bd9Sstevel@tonic-gateclobber		:=	TARGET= clobber
767c478bd9Sstevel@tonic-gatelint		:=	TARGET= lint
777c478bd9Sstevel@tonic-gatemodlintlib	:=	TARGET= modlintlib
78fb9f9b97Skupfermodlist		:=	TARGET= modlist
79fb9f9b97Skupfermodlist		:=	NO_STATE= -K $$MODSTATE$$$$
807c478bd9Sstevel@tonic-gateclean.lint	:=	TARGET= clean.lint
817c478bd9Sstevel@tonic-gatecheck		:=	TARGET= check
827c478bd9Sstevel@tonic-gateinstall_h	:=	TARGET= install_h
837c478bd9Sstevel@tonic-gate
847c478bd9Sstevel@tonic-gate.KEEP_STATE:
857c478bd9Sstevel@tonic-gate
86ae115bc7Smrj.PARALLEL:	$(PARALLEL_KMODS) $(CLOSED_KMODS) $(SVVS) $(XMODS) \
87ae115bc7Smrj		$(CLOSED_XMODS) config $(LINT_DEPS)
887c478bd9Sstevel@tonic-gate
899acbbeafSnn35248def all install clean clobber modlist: genassym $(KMODS) $(CLOSED_KMODS) \
90fb9f9b97Skupfer	$(SVVS) $(XMODS) $(CLOSED_XMODS) config
917c478bd9Sstevel@tonic-gate
92fb9f9b97Skupfermodlintlib clean.lint: $(LINT_KMODS) $(CLOSED_LINT_KMODS) $(SVVS) \
93fb9f9b97Skupfer	$(XMODS) $(CLOSED_XMODS)
947c478bd9Sstevel@tonic-gate
959acbbeafSnn35248genassym $(KMODS) $(SUBDIRS) config:	FRC
96fb9f9b97Skupfer	@cd $@; pwd; $(MAKE) $(NO_STATE) $(TARGET)
977c478bd9Sstevel@tonic-gate
98fb9f9b97Skupfer$(CLOSED_KMODS):	FRC
99fb9f9b97Skupfer	cd $(CLOSED)/uts/intel/$@; pwd; $(MAKE) $(NO_STATE) $(TARGET)
100fb9f9b97Skupfer
101fb9f9b97Skupfer$(XMODS):	FRC
1027c478bd9Sstevel@tonic-gate	@if [ -f $@/Makefile  ]; then \
103fb9f9b97Skupfer		cd $@; pwd; $(MAKE) $(NO_STATE) $(TARGET); \
104fb9f9b97Skupfer	else \
105fb9f9b97Skupfer		true; \
106fb9f9b97Skupfer	fi
107fb9f9b97Skupfer
108fb9f9b97Skupfer$(SVVS) $(CLOSED_XMODS):	FRC
109fb9f9b97Skupfer	@if [ -f $(CLOSED)/uts/intel/$@/Makefile  ]; then \
110fb9f9b97Skupfer		cd $(CLOSED)/uts/intel/$@; pwd; \
111fb9f9b97Skupfer		    $(MAKE) $(NO_STATE) $(TARGET); \
1127c478bd9Sstevel@tonic-gate	else \
1137c478bd9Sstevel@tonic-gate		true; \
1147c478bd9Sstevel@tonic-gate	fi
1157c478bd9Sstevel@tonic-gate
1167c478bd9Sstevel@tonic-gateinstall_h check:	FRC
1177c478bd9Sstevel@tonic-gate	@cd sys; pwd; $(MAKE) $(TARGET)
1187c478bd9Sstevel@tonic-gate	@cd asm; pwd; $(MAKE) $(TARGET)
1197c478bd9Sstevel@tonic-gate	@cd ia32/sys; pwd; $(MAKE) $(TARGET)
1207c478bd9Sstevel@tonic-gate	@cd amd64/sys; pwd; $(MAKE) $(TARGET)
1217c478bd9Sstevel@tonic-gate
1227c478bd9Sstevel@tonic-gate#
123ae115bc7Smrj# Work-around to disable acpica global crosscheck lint warnings
124ae115bc7Smrj#
125ae115bc7SmrjLGREP.intel =	grep -v 'intel/io/acpica'
126ae115bc7Smrj
127ae115bc7Smrj#
1287c478bd9Sstevel@tonic-gate#	Full kernel lint target.
1297c478bd9Sstevel@tonic-gate#
1307c478bd9Sstevel@tonic-gateLINT_TARGET	= globallint
1317c478bd9Sstevel@tonic-gate
132ae115bc7Smrj# workaround for multiply defined errors
133ae115bc7Smrjgloballint := LINTFLAGS += -erroff=E_NAME_MULTIPLY_DEF2
134ae115bc7Smrj
1357c478bd9Sstevel@tonic-gategloballint:
1367c478bd9Sstevel@tonic-gate	@-$(ECHO) "\nFULL KERNEL: global crosschecks:"
1376e541dddSmrj	@-$(LINT) $(LINTFLAGS) $(LINT_LIBS) 2>&1 | $(LGREP.intel) | $(LGREP.2)
1387c478bd9Sstevel@tonic-gate
1397c478bd9Sstevel@tonic-gatelint:	modlintlib .WAIT $(LINT_DEPS)
1407c478bd9Sstevel@tonic-gate
1417c478bd9Sstevel@tonic-gate# EXPORT DELETE START
1427c478bd9Sstevel@tonic-gate
1437c478bd9Sstevel@tonic-gateEXPORT_SRC:
1447c478bd9Sstevel@tonic-gate	$(RM) Makefile+
1457c478bd9Sstevel@tonic-gate	sed -e "/^# EXPORT DELETE START/,/^# EXPORT DELETE END/d" \
1467c478bd9Sstevel@tonic-gate	    < Makefile > Makefile+
1477c478bd9Sstevel@tonic-gate	$(MV) Makefile+ Makefile
1487c478bd9Sstevel@tonic-gate	$(CHMOD) 444 Makefile
1497c478bd9Sstevel@tonic-gate
1507c478bd9Sstevel@tonic-gate# EXPORT DELETE END
1517c478bd9Sstevel@tonic-gate
1527c478bd9Sstevel@tonic-gateinclude ../Makefile.targ
153