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