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# 238f8c16c4SGarrett D'Amore# Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved. 24*7b07063dSIgor Kozhukhov# Copyright 2015 Igor Kozhukhov <ikozhukhov@gmail.com> 257c478bd9Sstevel@tonic-gate# 267c478bd9Sstevel@tonic-gate# This makefile drives the production of all implementation architecture 277c478bd9Sstevel@tonic-gate# independent modules for Intel processors. 287c478bd9Sstevel@tonic-gate 297c478bd9Sstevel@tonic-gateUTSBASE = .. 307c478bd9Sstevel@tonic-gate 317c478bd9Sstevel@tonic-gateinclude Makefile.intel 327c478bd9Sstevel@tonic-gate 334bff34e3SthurlowLINT_KMODS_X1 = $(LINT_KMODS:nsmb=) 344bff34e3SthurlowLINT_KMODS_X2 = $(LINT_KMODS_X1:smbfs=) 354bff34e3SthurlowLINT_KMODLIBS = $(LINT_KMODS_X2:e1000g=) 367c478bd9Sstevel@tonic-gateLINT_LIBS = $(LINT_LIB) $(GEN_LINT_LIB) \ 37c0e7977aSJosef 'Jeff' Sipek $(LINT_KMODLIBS:%=$(LINT_LIB_DIR)/llib-l%.ln) 387c478bd9Sstevel@tonic-gate 397c478bd9Sstevel@tonic-gate# 40b6c3f786Sbubbva# dprov is delivered in the SUNWcryptoint package. 417c478bd9Sstevel@tonic-gate# 427c478bd9Sstevel@tonic-gateDRV_KMODS += dprov 437c478bd9Sstevel@tonic-gate 447c478bd9Sstevel@tonic-gate# 457c478bd9Sstevel@tonic-gate# 467c478bd9Sstevel@tonic-gatedef := TARGET= def 4798157a70Sakolbdef.prereq := TARGET= def 487c478bd9Sstevel@tonic-gateall := TARGET= all 4998157a70Sakolball.prereq := TARGET= all 507c478bd9Sstevel@tonic-gateinstall := TARGET= install 5198157a70Sakolbinstall.prereq := TARGET= all 527c478bd9Sstevel@tonic-gateclean := TARGET= clean 537c478bd9Sstevel@tonic-gateclobber := TARGET= clobber 547c478bd9Sstevel@tonic-gatelint := TARGET= lint 5598157a70Sakolblint.prereq := TARGET= lint 567c478bd9Sstevel@tonic-gatemodlintlib := TARGET= modlintlib 57fb9f9b97Skupfermodlist := TARGET= modlist 58fb9f9b97Skupfermodlist := NO_STATE= -K $$MODSTATE$$$$ 597c478bd9Sstevel@tonic-gateclean.lint := TARGET= clean.lint 607c478bd9Sstevel@tonic-gatecheck := TARGET= check 617c478bd9Sstevel@tonic-gateinstall_h := TARGET= install_h 6298157a70Sakolbinstall_h.prereq := TARGET= install_h 637c478bd9Sstevel@tonic-gate 647c478bd9Sstevel@tonic-gate.KEEP_STATE: 657c478bd9Sstevel@tonic-gate 66c0e7977aSJosef 'Jeff' Sipek.PARALLEL: $(PARALLEL_KMODS) $(XMODS) config $(LINT_DEPS) 677c478bd9Sstevel@tonic-gate 68c0e7977aSJosef 'Jeff' Sipekdef all install clean clobber modlist: $(KMODS) $(XMODS) config 697c478bd9Sstevel@tonic-gate 70b6805bf7SGordon Rossclobber: clobber.targ 7198157a70Sakolb 7298157a70Sakolb# 7398157a70Sakolb# Privilege constants 7498157a70Sakolb# 7598157a70Sakolb# NOTE: The rules for generating priv_const.c file are shared between all 7698157a70Sakolb# processor architectures and and should be kept in sync. If they are changed in 7798157a70Sakolb# this file make sure that sparc rules are updated as well. 7898157a70Sakolb# 7998157a70SakolbPRIVS_C = $(SRC)/uts/common/os/priv_const.c 8098157a70Sakolb 8198157a70Sakolb$(PRIVS_C): $(PRIVS_AWK) $(PRIVS_DEF) 82*7b07063dSIgor Kozhukhov $(AWK) -f $(PRIVS_AWK) < $(PRIVS_DEF) cfile=$@ 8398157a70Sakolb 84b6805bf7SGordon RossCLOBBERFILES += $(PRIVS_C) 85b6805bf7SGordon Ross 8698157a70Sakolb# 8798157a70Sakolb# Prerequisites 8898157a70Sakolb# 8998157a70Sakolb# The uts/Makefile defines build parallelism for x86 platforms such that i86pc, 9098157a70Sakolb# i86xpv and intel are all built in parallel. This requires building certain 9198157a70Sakolb# parts before the parallel build can start. The uts/Makefile appends the 9298157a70Sakolb# '.prereq' string to the original target and executes this Makefile to build 9398157a70Sakolb# any prerequisites needed before the full parallel build can start. After that 9498157a70Sakolb# make continues with normal targets. 9598157a70Sakolb# 9698157a70Sakolb# Any build prerequisites for x86 builds should be described here. 9798157a70Sakolb# 9898157a70Sakolb# genassym is used to build intel/dtrace and genunix, so it should be built 9998157a70Sakolb# first. 10098157a70Sakolb# 10198157a70Sakolb# priv_const.c is required to build genunix. 10298157a70Sakolb# 10398157a70Sakolb# genunix is used by everyone to ctf-merge with. Genunix is CTF-merged with 10498157a70Sakolb# intel/ip so as a side effect this dependency builds intel/ip as part of the 10598157a70Sakolb# prerequisites. 10698157a70Sakolb# 10798157a70Sakolb# intel/dtrace depends on i86pc/genassym, so we need to build both 10898157a70Sakolb# i86pc/genassym and intel/genassym. 10998157a70Sakolb# 110eb5a5c78SSurya Prakkiall.prereq install.prereq def.prereq: genunix FRC 11198157a70Sakolb @cd ../i86pc/genassym; pwd; $(MAKE) $(@:%.prereq=%) 11298157a70Sakolb 11398157a70Sakolb# 11498157a70Sakolb# i86pc lint libraries should be built first 11598157a70Sakolb# 11698157a70Sakolblint.prereq: FRC 11798157a70Sakolb @cd ../i86pc; pwd; $(MAKE) $(NO_STATE) lint 11898157a70Sakolb 11998157a70Sakolb# 12098157a70Sakolb# Nothing to do for any other prerequisite targets. 12198157a70Sakolb# 12298157a70Sakolb%.prereq: 12398157a70Sakolb 12498157a70Sakolbgenunix: $(PRIVS_C) 12598157a70Sakolb 126c0e7977aSJosef 'Jeff' Sipekmodlintlib clean.lint: $(LINT_KMODS) $(XMODS) 1277c478bd9Sstevel@tonic-gate 128eb5a5c78SSurya Prakki$(KMODS) $(SUBDIRS) config: FRC 129fb9f9b97Skupfer @cd $@; pwd; $(MAKE) $(NO_STATE) $(TARGET) 1307c478bd9Sstevel@tonic-gate 131fb9f9b97Skupfer$(XMODS): FRC 1327c478bd9Sstevel@tonic-gate @if [ -f $@/Makefile ]; then \ 133fb9f9b97Skupfer cd $@; pwd; $(MAKE) $(NO_STATE) $(TARGET); \ 134fb9f9b97Skupfer else \ 135fb9f9b97Skupfer true; \ 136fb9f9b97Skupfer fi 137fb9f9b97Skupfer 1387c478bd9Sstevel@tonic-gateinstall_h check: FRC 1397c478bd9Sstevel@tonic-gate @cd sys; pwd; $(MAKE) $(TARGET) 1407c478bd9Sstevel@tonic-gate @cd asm; pwd; $(MAKE) $(TARGET) 1417c478bd9Sstevel@tonic-gate @cd ia32/sys; pwd; $(MAKE) $(TARGET) 1427c478bd9Sstevel@tonic-gate @cd amd64/sys; pwd; $(MAKE) $(TARGET) 1437c478bd9Sstevel@tonic-gate 1447c478bd9Sstevel@tonic-gate# 145ae115bc7Smrj# Work-around to disable acpica global crosscheck lint warnings 146ae115bc7Smrj# 147ae115bc7SmrjLGREP.intel = grep -v 'intel/io/acpica' 148ae115bc7Smrj 149ae115bc7Smrj# 1507c478bd9Sstevel@tonic-gate# Full kernel lint target. 1517c478bd9Sstevel@tonic-gate# 1527c478bd9Sstevel@tonic-gateLINT_TARGET = globallint 1537c478bd9Sstevel@tonic-gate 154ae115bc7Smrj# workaround for multiply defined errors 155ae115bc7Smrjgloballint := LINTFLAGS += -erroff=E_NAME_MULTIPLY_DEF2 156ae115bc7Smrj 1577c478bd9Sstevel@tonic-gategloballint: 15898157a70Sakolb @pwd 1597c478bd9Sstevel@tonic-gate @-$(ECHO) "\nFULL KERNEL: global crosschecks:" 1606e541dddSmrj @-$(LINT) $(LINTFLAGS) $(LINT_LIBS) 2>&1 | $(LGREP.intel) | $(LGREP.2) 1617c478bd9Sstevel@tonic-gate 1627c478bd9Sstevel@tonic-gatelint: modlintlib .WAIT $(LINT_DEPS) 1637c478bd9Sstevel@tonic-gate 1647c478bd9Sstevel@tonic-gateinclude ../Makefile.targ 165