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 5fb9f9b97Skupfer# Common Development and Distribution License (the "License"). 6fb9f9b97Skupfer# 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# 2284d8c05bSMike Kupfer# Copyright (c) 1991, 2010, Oracle and/or its affiliates. All rights reserved. 23cd277642SGarrett D'Amore# Copyright 2014 Garrett D'Amore <garrett@damore.org> 24f73e0305SHans Rosenfeld# Copyright 2016 Hans Rosenfeld <rosenfeld@grumpf.hope-2000.org> 25*45a4b79dSSebastien Roy# Copyright (c) 2017 by Delphix. All rights reserved. 267c478bd9Sstevel@tonic-gate# 277c478bd9Sstevel@tonic-gate# This Makefiles contains the common targets and definitions for 287c478bd9Sstevel@tonic-gate# all kernels. It is to be included in the Makefiles for specific 297c478bd9Sstevel@tonic-gate# implementation architectures and processor architecture dependent 307c478bd9Sstevel@tonic-gate# modules: i.e.: all driving kernel Makefiles. 317c478bd9Sstevel@tonic-gate# 327c478bd9Sstevel@tonic-gate 337c478bd9Sstevel@tonic-gate# 347c478bd9Sstevel@tonic-gate# Default rule for building the lint library directory: 357c478bd9Sstevel@tonic-gate# 367c478bd9Sstevel@tonic-gate$(LINT_LIB_DIR): 377c478bd9Sstevel@tonic-gate -@mkdir -p $@ 2> /dev/null 387c478bd9Sstevel@tonic-gate 397c478bd9Sstevel@tonic-gate# 407c478bd9Sstevel@tonic-gate# All C objects depend on inline files. However, cc(1) doesn't generate 417c478bd9Sstevel@tonic-gate# the correct dependency info. Also, these Makefiles don't contain a 427c478bd9Sstevel@tonic-gate# separate list of C-derived object files (but it is light weight to 437c478bd9Sstevel@tonic-gate# let the assembler files think they depend upon this when they don't). 447c478bd9Sstevel@tonic-gate# Fortunately, the inline files won't change very often. So, for now, 457c478bd9Sstevel@tonic-gate# all objects depend on the inline files. Remove this when the inliner 467c478bd9Sstevel@tonic-gate# is fixed to drop correct dependency information. 477c478bd9Sstevel@tonic-gate# 487c478bd9Sstevel@tonic-gate$(OBJECTS): $(INLINES) 497c478bd9Sstevel@tonic-gate 507c478bd9Sstevel@tonic-gate# 517c478bd9Sstevel@tonic-gate# Partially link .o files to generate the kmod. The fake dependency 527c478bd9Sstevel@tonic-gate# on modstubs simplifies things... 537c478bd9Sstevel@tonic-gate# 543e3ca1ceSRobert Mustacchi$(BINARY): $(OBJECTS) $(DTRACE_MAPFILE) 557c478bd9Sstevel@tonic-gate $(LD) -r $(LDFLAGS) -o $@ $(OBJECTS) 567c478bd9Sstevel@tonic-gate $(CTFMERGE_UNIQUIFY_AGAINST_GENUNIX) 577c478bd9Sstevel@tonic-gate $(POST_PROCESS) 587c478bd9Sstevel@tonic-gate 597c478bd9Sstevel@tonic-gate# 607c478bd9Sstevel@tonic-gate# This target checks each kmod for undefined entry points. It does not 617c478bd9Sstevel@tonic-gate# modify the kmod in any way. 627c478bd9Sstevel@tonic-gate# 637c478bd9Sstevel@tonic-gate$(MODULE).check: FRC 647c478bd9Sstevel@tonic-gate @BUILD_TYPE=DBG32 $(MAKE) $(MODULE).check.targ 657c478bd9Sstevel@tonic-gate 667c478bd9Sstevel@tonic-gate$(MODULE).check.targ: $(BINARY) $(OBJECTS) $(EXTRA_CHECK_OBJS) $(UNIX_O) $(MODSTUBS_O) $(GENLIB) 677c478bd9Sstevel@tonic-gate $(LD) -o /dev/null $(OBJECTS) $(EXTRA_CHECK_OBJS) $(UNIX_O) $(MODSTUBS_O) $(GENLIB) 687c478bd9Sstevel@tonic-gate 697c478bd9Sstevel@tonic-gate# 707c478bd9Sstevel@tonic-gate# Module lint library construction targets. 717c478bd9Sstevel@tonic-gate# 727c478bd9Sstevel@tonic-gateMOD_LINT_LIB = $(LINT_LIB_DIR)/llib-l$(LINT_MODULE).ln 737c478bd9Sstevel@tonic-gate 747c478bd9Sstevel@tonic-gate$(MOD_LINT_LIB): $(LINT_LIB_DIR) $(LINTS) 757c478bd9Sstevel@tonic-gate @-$(ECHO) "\n$(OBJS_DIR)/$(MODULE): (library construction):" 76878eeb1bSGordon Ross @($(LINT) -o $(LINT_MODULE)-$(OBJS_DIR) \ 77878eeb1bSGordon Ross $(LINTFLAGS) $(LINTS) $(LTAIL)) 78ae115bc7Smrj @$(MV) llib-l$(LINT_MODULE)-$(OBJS_DIR).ln $@ 797c478bd9Sstevel@tonic-gate 807c478bd9Sstevel@tonic-gate$(LINT_MODULE).lint: $(MOD_LINT_LIB) $(LINT_LIB) $(GEN_LINT_LIB) 817c478bd9Sstevel@tonic-gate @-$(ECHO) "\n$(OBJS_DIR)/$(LINT_MODULE): global crosschecks:" 82878eeb1bSGordon Ross @($(LINT) $(LINTFLAGS) $(MOD_LINT_LIB) \ 83878eeb1bSGordon Ross $(LINT_LIB) $(GEN_LINT_LIB) $(LTAIL)) 847c478bd9Sstevel@tonic-gate 857c478bd9Sstevel@tonic-gate# 867c478bd9Sstevel@tonic-gate# Since assym.h is a derived file, the dependency must be explicit for 877c478bd9Sstevel@tonic-gate# all files including this file. (This is only actually required in the 887c478bd9Sstevel@tonic-gate# instance when the .nse_depinfo file does not exist.) It may seem that 897c478bd9Sstevel@tonic-gate# the lint targets should also have a similar dependency, but they don't 907c478bd9Sstevel@tonic-gate# since only C headers are included when #defined(lint) is true. The 917c478bd9Sstevel@tonic-gate# actual lists are defined in */Makefile.files. 927c478bd9Sstevel@tonic-gate# 937c478bd9Sstevel@tonic-gate$(ASSYM_DEPS:%=$(OBJS_DIR)/%): $(DSF_DIR)/$(OBJS_DIR)/assym.h 947c478bd9Sstevel@tonic-gate 957c478bd9Sstevel@tonic-gate# 967c478bd9Sstevel@tonic-gate# Everybody need to know how to create a modstubs.o built with the 977c478bd9Sstevel@tonic-gate# appropriate flags and located in the appropriate location. 987c478bd9Sstevel@tonic-gate# 997c478bd9Sstevel@tonic-gate$(MODSTUBS_O): $(MODSTUBS) 1007c478bd9Sstevel@tonic-gate $(COMPILE.s) -o $@ $(MODSTUBS) 1017c478bd9Sstevel@tonic-gate 1027c478bd9Sstevel@tonic-gate$(LINTS_DIR)/modstubs.ln: $(MODSTUBS) 1037c478bd9Sstevel@tonic-gate @($(LHEAD) $(LINT.s) $(MODSTUBS) $(LTAIL)) 1047c478bd9Sstevel@tonic-gate 1057c478bd9Sstevel@tonic-gate# 1067c478bd9Sstevel@tonic-gate# Build the source file which contains the kernel's utsname, 1077c478bd9Sstevel@tonic-gate# with release, version and machine set as follows: 1087c478bd9Sstevel@tonic-gate# 1097c478bd9Sstevel@tonic-gate# release: contents of $(RELEASE) (Spaces replaced by '_') 1107c478bd9Sstevel@tonic-gate# version: contents of $(PATCHID) (Spaces replaced by '_') 111ae115bc7Smrj# machine: contents of $(UNAME_M) 1127c478bd9Sstevel@tonic-gate# 1137c478bd9Sstevel@tonic-gate# Build environment information is only contained in the comment section. 1147c478bd9Sstevel@tonic-gate# 1157c478bd9Sstevel@tonic-gate 1167c478bd9Sstevel@tonic-gate$(OBJS_DIR)/vers.o: $(OBJECTS) 1177c478bd9Sstevel@tonic-gate $(COMPILE.c) -DUTS_RELEASE=\"`$(ECHO) $(RELEASE) | sed -e 's/ /_/g'`\" \ 11834ae5cdfSJosef 'Jeff' Sipek -DUTS_VERSION=\"`$(ECHO) $(PATCHID) | sed -e 's/ /_/g'`\" \ 119ae115bc7Smrj -DUTS_PLATFORM=\"$(UNAME_M)\" -o $@ $(SRC)/uts/common/os/vers.c 1207c478bd9Sstevel@tonic-gate $(CTFCONVERT_O) 1217c478bd9Sstevel@tonic-gate $(POST_PROCESS_O) 1227c478bd9Sstevel@tonic-gate 1237c478bd9Sstevel@tonic-gate$(LINTS_DIR)/vers.ln: $(SRC)/uts/common/os/vers.c 1247c478bd9Sstevel@tonic-gate @($(LHEAD) $(LINT.c) -DUTS_RELEASE=\"\" -DUTS_VERSION=\"\" \ 1257c478bd9Sstevel@tonic-gate -DUTS_PLATFORM=\"\" $(SRC)/uts/common/os/vers.c $(LTAIL)) 1267c478bd9Sstevel@tonic-gate 1277c478bd9Sstevel@tonic-gate# 1287c478bd9Sstevel@tonic-gate# Installation targets and rules: 1297c478bd9Sstevel@tonic-gate# 1307c478bd9Sstevel@tonic-gate$(ROOT_MOD_DIR) $(USR_MOD_DIR): 13148bc00d6Sjmcp -$(INS.dir) 1327c478bd9Sstevel@tonic-gate 1337c478bd9Sstevel@tonic-gate$(ROOT_MOD_DIRS_32): $(ROOT_MOD_DIR) 13448bc00d6Sjmcp -$(INS.dir) 1357c478bd9Sstevel@tonic-gate 1367c478bd9Sstevel@tonic-gate$(USR_MOD_DIRS_32): $(USR_MOD_DIR) 13748bc00d6Sjmcp -$(INS.dir) 1387c478bd9Sstevel@tonic-gate 1397c478bd9Sstevel@tonic-gate$(ROOT_MOD_DIR)/%: $(OBJS_DIR)/% $(ROOT_MOD_DIR) FRC 1407c478bd9Sstevel@tonic-gate $(INS.file) 1417c478bd9Sstevel@tonic-gate 1427aec1d6eScindi$(ROOT_CPU_DIR)/%: $(OBJS_DIR)/% $(ROOT_CPU_DIR) FRC 1437aec1d6eScindi $(INS.file) 1447aec1d6eScindi 1457c478bd9Sstevel@tonic-gate$(ROOT_DRV_DIR)/%: $(OBJS_DIR)/% $(ROOT_DRV_DIR) FRC 1467c478bd9Sstevel@tonic-gate $(INS.file) 1477c478bd9Sstevel@tonic-gate 1487c478bd9Sstevel@tonic-gate$(ROOT_DTRACE_DIR)/%: $(OBJS_DIR)/% $(ROOT_DTRACE_DIR) FRC 1497c478bd9Sstevel@tonic-gate $(INS.file) 1507c478bd9Sstevel@tonic-gate 1517c478bd9Sstevel@tonic-gate$(ROOT_EXEC_DIR)/%: $(OBJS_DIR)/% $(ROOT_EXEC_DIR) FRC 1527c478bd9Sstevel@tonic-gate $(INS.file) 1537c478bd9Sstevel@tonic-gate 1547c478bd9Sstevel@tonic-gate$(ROOT_FS_DIR)/%: $(OBJS_DIR)/% $(ROOT_FS_DIR) FRC 1557c478bd9Sstevel@tonic-gate $(INS.file) 1567c478bd9Sstevel@tonic-gate 1577c478bd9Sstevel@tonic-gate$(ROOT_SCHED_DIR)/%: $(OBJS_DIR)/% $(ROOT_SCHED_DIR) FRC 1587c478bd9Sstevel@tonic-gate $(INS.file) 1597c478bd9Sstevel@tonic-gate 1600f1702c5SYu Xiangning$(ROOT_SOCK_DIR)/%: $(OBJS_DIR)/% $(ROOT_SOCK_DIR) FRC 1610f1702c5SYu Xiangning $(INS.file) 1620f1702c5SYu Xiangning 1637c478bd9Sstevel@tonic-gate$(ROOT_STRMOD_DIR)/%: $(OBJS_DIR)/% $(ROOT_STRMOD_DIR) FRC 1647c478bd9Sstevel@tonic-gate $(INS.file) 1657c478bd9Sstevel@tonic-gate 1667c478bd9Sstevel@tonic-gate$(ROOT_IPP_DIR)/%: $(OBJS_DIR)/% $(ROOT_IPP_DIR) FRC 1677c478bd9Sstevel@tonic-gate $(INS.file) 1687c478bd9Sstevel@tonic-gate 1697c478bd9Sstevel@tonic-gate$(ROOT_SYS_DIR)/%: $(OBJS_DIR)/% $(ROOT_SYS_DIR) FRC 1707c478bd9Sstevel@tonic-gate $(INS.file) 1717c478bd9Sstevel@tonic-gate 1727c478bd9Sstevel@tonic-gate$(ROOT_MISC_DIR)/%: $(OBJS_DIR)/% $(ROOT_MISC_DIR) FRC 1737c478bd9Sstevel@tonic-gate $(INS.file) 1747c478bd9Sstevel@tonic-gate 1757c478bd9Sstevel@tonic-gate$(ROOT_DACF_DIR)/%: $(OBJS_DIR)/% $(ROOT_DACF_DIR) FRC 1767c478bd9Sstevel@tonic-gate $(INS.file) 1777c478bd9Sstevel@tonic-gate 1789acbbeafSnn$(ROOT_BRAND_DIR)/%: $(OBJS_DIR)/% $(ROOT_BRAND_DIR) FRC 1799acbbeafSnn $(INS.file) 1809acbbeafSnn 181*45a4b79dSSebastien Roy$(ROOT_CC_DIR)/%: $(OBJS_DIR)/% $(ROOT_MOD_DIR) $(ROOT_CC_DIR) FRC 182*45a4b79dSSebastien Roy $(INS.file) 183*45a4b79dSSebastien Roy 1847c478bd9Sstevel@tonic-gate$(ROOT_CRYPTO_DIR)/%: $(OBJS_DIR)/% $(ROOT_CRYPTO_DIR) FRC 1857c478bd9Sstevel@tonic-gate $(INS.file) 1867c478bd9Sstevel@tonic-gate 1877c478bd9Sstevel@tonic-gate$(ROOT_KGSS_DIR)/%: $(OBJS_DIR)/% $(ROOT_KGSS_DIR) FRC 1887c478bd9Sstevel@tonic-gate $(INS.file) 1897c478bd9Sstevel@tonic-gate 1901e1ddd6cScth$(ROOT_SCSI_VHCI_DIR)/%: $(OBJS_DIR)/% $(ROOT_SCSI_VHCI_DIR) FRC 1911e1ddd6cScth $(INS.file) 1921e1ddd6cScth 1934c06356bSdh$(ROOT_PMCS_FW_DIR)/%: $(OBJS_DIR)/% $(ROOT_PMCS_FW_DIR) FRC 1944c06356bSdh $(INS.file) 1954c06356bSdh 196fcf3ce44SJohn Forte$(ROOT_QLC_FW_DIR)/%: $(OBJS_DIR)/% $(ROOT_QLC_FW_DIR) FRC 197fcf3ce44SJohn Forte $(INS.file) 198fcf3ce44SJohn Forte 199291a2b48SSukumar Swaminathan$(ROOT_EMLXS_FW_DIR)/%: $(OBJS_DIR)/% $(ROOT_EMLXS_FW_DIR) FRC 200291a2b48SSukumar Swaminathan $(INS.file) 201291a2b48SSukumar Swaminathan 2027c478bd9Sstevel@tonic-gate$(ROOT_MACH_DIR)/%: $(OBJS_DIR)/% $(ROOT_MACH_DIR) FRC 2037c478bd9Sstevel@tonic-gate $(INS.file) 2047c478bd9Sstevel@tonic-gate 2057c478bd9Sstevel@tonic-gate$(ROOT_FONT_DIR)/%: $(OBJS_DIR)/% $(ROOT_MOD_DIR) $(ROOT_FONT_DIR) FRC 2067c478bd9Sstevel@tonic-gate $(INS.file) 2077c478bd9Sstevel@tonic-gate 208ba2e4443Sseb$(ROOT_MAC_DIR)/%: $(OBJS_DIR)/% $(ROOT_MOD_DIR) $(ROOT_MAC_DIR) FRC 209ba2e4443Sseb $(INS.file) 210ba2e4443Sseb 2117c478bd9Sstevel@tonic-gate$(USR_DRV_DIR)/%: $(OBJS_DIR)/% $(USR_DRV_DIR) FRC 2127c478bd9Sstevel@tonic-gate $(INS.file) 2137c478bd9Sstevel@tonic-gate 2147c478bd9Sstevel@tonic-gate$(USR_EXEC_DIR)/%: $(OBJS_DIR)/% $(USR_EXEC_DIR) FRC 2157c478bd9Sstevel@tonic-gate $(INS.file) 2167c478bd9Sstevel@tonic-gate 2177c478bd9Sstevel@tonic-gate$(USR_FS_DIR)/%: $(OBJS_DIR)/% $(USR_FS_DIR) FRC 2187c478bd9Sstevel@tonic-gate $(INS.file) 2197c478bd9Sstevel@tonic-gate 2207c478bd9Sstevel@tonic-gate$(USR_SCHED_DIR)/%: $(OBJS_DIR)/% $(USR_SCHED_DIR) FRC 2217c478bd9Sstevel@tonic-gate $(INS.file) 2227c478bd9Sstevel@tonic-gate 2230a0e9771SDarren Reed$(USR_SOCK_DIR)/%: $(OBJS_DIR)/% $(USR_SOCK_DIR) FRC 2240a0e9771SDarren Reed $(INS.file) 2250a0e9771SDarren Reed 2267c478bd9Sstevel@tonic-gate$(USR_STRMOD_DIR)/%: $(OBJS_DIR)/% $(USR_STRMOD_DIR) FRC 2277c478bd9Sstevel@tonic-gate $(INS.file) 2287c478bd9Sstevel@tonic-gate 2297c478bd9Sstevel@tonic-gate$(USR_SYS_DIR)/%: $(OBJS_DIR)/% $(USR_SYS_DIR) FRC 2307c478bd9Sstevel@tonic-gate $(INS.file) 2317c478bd9Sstevel@tonic-gate 2327c478bd9Sstevel@tonic-gate$(USR_MISC_DIR)/%: $(OBJS_DIR)/% $(USR_MISC_DIR) FRC 2337c478bd9Sstevel@tonic-gate $(INS.file) 2347c478bd9Sstevel@tonic-gate 2357c478bd9Sstevel@tonic-gate$(USR_DACF_DIR)/%: $(OBJS_DIR)/% $(USR_DACF_DIR) FRC 2367c478bd9Sstevel@tonic-gate $(INS.file) 2377c478bd9Sstevel@tonic-gate 2387c478bd9Sstevel@tonic-gate$(USR_PCBE_DIR)/%: $(OBJS_DIR)/% $(USR_PCBE_DIR) FRC 2397c478bd9Sstevel@tonic-gate $(INS.file) 2407c478bd9Sstevel@tonic-gate 2419a9ae70fSjv$(USR_DTRACE_DIR)/%: $(OBJS_DIR)/% $(USR_DTRACE_DIR) FRC 2429a9ae70fSjv $(INS.file) 2439a9ae70fSjv 2449a9ae70fSjv$(USR_BRAND_DIR)/%: $(OBJS_DIR)/% $(USR_BRAND_DIR) FRC 2459a9ae70fSjv $(INS.file) 2469a9ae70fSjv 247d14d7d31Sis$(ROOT_KICONV_DIR)/%: $(OBJS_DIR)/% $(ROOT_KICONV_DIR) FRC 248d14d7d31Sis $(INS.file) 249d14d7d31Sis 250f73e0305SHans Rosenfeld$(ROOT_FIRMWARE_DIR)/$(MODULE): 251f73e0305SHans Rosenfeld $(INS.dir) 252f73e0305SHans Rosenfeld 253f73e0305SHans Rosenfeld$(ROOT_FIRMWARE_DIR)/$(MODULE)/%:= FILEMODE = $(CFILEMODE) 254f73e0305SHans Rosenfeld 255f73e0305SHans Rosenfeld$(ROOT_FIRMWARE_DIR)/$(MODULE)/%: $(ROOT_FIRMWARE_DIR)/$(MODULE) $(FWDIR)/% 256f73e0305SHans Rosenfeld $(INS.file) 257f73e0305SHans Rosenfeld 2587c478bd9Sstevel@tonic-gateinclude $(SRC)/Makefile.psm.targ 2597c478bd9Sstevel@tonic-gate 2607c478bd9Sstevel@tonic-gate# 2617c478bd9Sstevel@tonic-gate# Target for 64b modules 2627c478bd9Sstevel@tonic-gate# 2637c478bd9Sstevel@tonic-gate$(ROOT_KERN_DIR_64): 26448bc00d6Sjmcp -$(INS.dir) 2657c478bd9Sstevel@tonic-gate 2667c478bd9Sstevel@tonic-gate$(ROOT_KERN_DIR_64)/%: $(OBJS_DIR)/% $(ROOT_KERN_DIR_64) FRC 2677c478bd9Sstevel@tonic-gate $(INS.file) 2687c478bd9Sstevel@tonic-gate 2697c478bd9Sstevel@tonic-gate%/$(SUBDIR64): % 27048bc00d6Sjmcp -$(INS.dir) 2717c478bd9Sstevel@tonic-gate 2727c478bd9Sstevel@tonic-gate# 2737c478bd9Sstevel@tonic-gate# Targets for '.conf' file installation. 2747c478bd9Sstevel@tonic-gate# 2757c478bd9Sstevel@tonic-gate$(ROOT_CONFFILE): $(SRC_CONFFILE) $(ROOT_CONFFILE:%/$(CONFFILE)=%) 2767c478bd9Sstevel@tonic-gate $(INS.conffile) 2777c478bd9Sstevel@tonic-gate 2787c478bd9Sstevel@tonic-gate# 2797c478bd9Sstevel@tonic-gate# Targets for creating links between common platforms. ROOT_PLAT_LINKS 2807c478bd9Sstevel@tonic-gate# are are the /platform level while ROOT_PLAT_LINKS_2 are one level 2817c478bd9Sstevel@tonic-gate# down (/platform/`uname -i`/{lib|sbin|kernel}. 2827c478bd9Sstevel@tonic-gate# 2837c478bd9Sstevel@tonic-gate$(ROOT_PLAT_LINKS): 2847c478bd9Sstevel@tonic-gate $(INS.slink1) 2857c478bd9Sstevel@tonic-gate 2867c478bd9Sstevel@tonic-gate$(ROOT_PLAT_LINKS_2): 2877c478bd9Sstevel@tonic-gate $(INS.slink2) 2887c478bd9Sstevel@tonic-gate 2897c478bd9Sstevel@tonic-gate$(USR_PLAT_LINKS): 2907c478bd9Sstevel@tonic-gate $(INS.slink1) 2917c478bd9Sstevel@tonic-gate 2927c478bd9Sstevel@tonic-gate$(USR_PLAT_LINKS_2): 2937c478bd9Sstevel@tonic-gate $(INS.slink2) 2947c478bd9Sstevel@tonic-gate 2957c478bd9Sstevel@tonic-gate# 2967c478bd9Sstevel@tonic-gate# multiple builds support 2977c478bd9Sstevel@tonic-gate# 2987c478bd9Sstevel@tonic-gatedef $(DEF_DEPS) := TARGET = def 2997c478bd9Sstevel@tonic-gateall $(ALL_DEPS) := TARGET = all 3007c478bd9Sstevel@tonic-gateclean $(CLEAN_DEPS) := TARGET = clean 3017c478bd9Sstevel@tonic-gateclobber $(CLOBBER_DEPS) := TARGET = clobber 3027c478bd9Sstevel@tonic-gatelint $(LINT_DEPS) := TARGET = lint 3037c478bd9Sstevel@tonic-gatemodlintlib $(MODLINTLIB_DEPS) := TARGET = modlintlib 304fb9f9b97Skupfermodlist $(MODLIST_DEPS) := TARGET = modlist 305fb9f9b97Skupfermodlist $(MODLIST_DEPS) := NO_STATE= -K $$MODSTATE$$$$ 3067c478bd9Sstevel@tonic-gateclean.lint $(CLEAN_LINT_DEPS) := TARGET = clean.lint 3077c478bd9Sstevel@tonic-gateinstall $(INSTALL_DEPS) := TARGET = install 3087c478bd9Sstevel@tonic-gatesymcheck $(SYM_DEPS) := TARGET = symcheck 3097c478bd9Sstevel@tonic-gate 310fb9f9b97SkupferALL_TARGS = def all clean clobber lint modlintlib \ 311fb9f9b97Skupfer clean.lint lintlib install symcheck 3127c478bd9Sstevel@tonic-gate 313bbbed746SGordon RossALL_OBJ32 = $(ALL_TARGS:%=%.obj32) 314bbbed746SGordon Ross 315bbbed746SGordon Ross$(ALL_OBJ32): FRC 316bbbed746SGordon Ross @BUILD_TYPE=OBJ32 VERSION='$(VERSION)' $(MAKE) $(NO_STATE) $(TARGET).targ 317bbbed746SGordon Ross 318bbbed746SGordon RossALL_DEBUG32 = $(ALL_TARGS:%=%.debug32) 319bbbed746SGordon Ross 320bbbed746SGordon Ross$(ALL_DEBUG32): FRC 321bbbed746SGordon Ross @BUILD_TYPE=DBG32 VERSION='$(VERSION)' $(MAKE) $(NO_STATE) $(TARGET).targ 322bbbed746SGordon Ross 3237c478bd9Sstevel@tonic-gateALL_OBJ64 = $(ALL_TARGS:%=%.obj64) 3247c478bd9Sstevel@tonic-gate 3257c478bd9Sstevel@tonic-gate$(ALL_OBJ64): FRC 326fb9f9b97Skupfer @BUILD_TYPE=OBJ64 VERSION='$(VERSION)' $(MAKE) $(NO_STATE) $(TARGET).targ 3277c478bd9Sstevel@tonic-gate 3287c478bd9Sstevel@tonic-gateALL_DEBUG64 = $(ALL_TARGS:%=%.debug64) 3297c478bd9Sstevel@tonic-gate 3307c478bd9Sstevel@tonic-gate$(ALL_DEBUG64): FRC 331fb9f9b97Skupfer @BUILD_TYPE=DBG64 VERSION='$(VERSION)' $(MAKE) $(NO_STATE) $(TARGET).targ 3327c478bd9Sstevel@tonic-gate 333112f9fc1Syz# 334112f9fc1Syz# Currently only the IP module needs symbol checking on obj64. 335112f9fc1Syz# Other modules have the same global-objs nm output for debug64 and obj64. 336112f9fc1Syz# 337112f9fc1Syz$(SISCHECK_DEPS): $(DEF_DEPS) 338112f9fc1Syz @TARG=`$(ECHO) $@ | $(CUT) -d'.' -f2`; \ 339112f9fc1Syz MODSYMS=$(MODULE).symbols.$$TARG; \ 340112f9fc1Syz if [ -f "$(MODULE).global-objs.$$TARG" ]; then \ 341112f9fc1Syz $(GREP) -v '#' $(MODULE).global-objs.$$TARG |$(GREP) . | \ 342112f9fc1Syz $(SORT) -u > $$MODSYMS.tmp; \ 343112f9fc1Syz $(NM) $$TARG/$(MODULE) |$(GREP) OBJT |$(GREP) -v UNDEF | \ 344756e192dSyz $(CUT) -d'|' -f8 |$(GREP) -v '^___const_' | \ 345756e192dSyz $(GREP) -v '\.[0-9]*$$' |$(SORT) -u \ 346112f9fc1Syz > $$MODSYMS.tmp.new; \ 347112f9fc1Syz $(DIFF) $$MODSYMS.tmp $$MODSYMS.tmp.new > $$MODSYMS.diff || \ 348112f9fc1Syz ($(ECHO) "warning: $(MODULE) symbol checking:" \ 349112f9fc1Syz "global variable(s) introduced and/or removed."; \ 350112f9fc1Syz $(CAT) $$MODSYMS.diff; exit 1) \ 351112f9fc1Syz fi 352112f9fc1Syz 353112f9fc1Syz$(SISCLEAN_DEPS): 354112f9fc1Syz -TARG=`$(ECHO) $@ | $(CUT) -d'.' -f2`; \ 355112f9fc1Syz MODSYMS=$(MODULE).symbols.$$TARG; \ 356112f9fc1Syz $(RM) $$MODSYMS.tmp $$MODSYMS.tmp.new $$MODSYMS.diff Nothing_to_remove 357112f9fc1Syz 3587c478bd9Sstevel@tonic-gate 3597c478bd9Sstevel@tonic-gate$(OBJS_DIR): 3607c478bd9Sstevel@tonic-gate -@mkdir -p $@ 2> /dev/null 3617c478bd9Sstevel@tonic-gate 3627c478bd9Sstevel@tonic-gatedef.targ: $(OBJS_DIR) $(ALL_TARGET) 3637c478bd9Sstevel@tonic-gate 3647c478bd9Sstevel@tonic-gateall.targ: $(OBJS_DIR) $(ALL_TARGET) 3657c478bd9Sstevel@tonic-gate 3667c478bd9Sstevel@tonic-gatelint.targ: $(OBJS_DIR) $(LINT_TARGET) 3677c478bd9Sstevel@tonic-gate 3687c478bd9Sstevel@tonic-gatemodlintlib.targ: $(OBJS_DIR) $(MOD_LINT_LIB) 3697c478bd9Sstevel@tonic-gate 3707c478bd9Sstevel@tonic-gateinstall.targ: $(OBJS_DIR) $(INSTALL_TARGET) 3717c478bd9Sstevel@tonic-gate 372fb9f9b97Skupfer# 373fb9f9b97Skupfer# Support for Install.sh. 374fb9f9b97Skupfer# 375fb9f9b97Skupfer 376fb9f9b97Skupfermodlist: $(MODLIST_DEPS) 377fb9f9b97Skupfer 378fb9f9b97Skupfer# paths relative to $(ROOT). 379fb9f9b97SkupferRELMODULE = $(ROOTMODULE:$(ROOT)/%=%) 380fb9f9b97SkupferRELCONF = $(ROOT_CONFFILE:$(ROOT)/%=%) 381fb9f9b97SkupferRELLINK = $(ROOTLINK:$(ROOT)/%=%) 382fb9f9b97SkupferRELUNIX = $(UNIX32_LINK:$(ROOT)/%=%) 383fb9f9b97SkupferRELSOFTLINKS = $(ROOTSOFTLINKS:$(ROOT)/%=%) 384fb9f9b97Skupfer 385fb9f9b97SkupferMODSRC:sh= pwd 386fb9f9b97Skupfer 38784d8c05bSMike Kupfer# 38884d8c05bSMike Kupfer# Generate module information for Install.sh, i.e., specify what files 38984d8c05bSMike Kupfer# Install.sh should include. Each line looks like 39084d8c05bSMike Kupfer# <tag> <srcdir> <arg1> <arg2> ... 39184d8c05bSMike Kupfer# where <tag> specifies the type of file, <srcdir> gives the source 39284d8c05bSMike Kupfer# path (useful if there is an error), and <argN> is one or more 39384d8c05bSMike Kupfer# additional bits of information that Install.sh needs (e.g., source 39484d8c05bSMike Kupfer# directory, install directory, filtering tags). See Install.sh for 39584d8c05bSMike Kupfer# details on the arguments for each tag type, especially the functions 39684d8c05bSMike Kupfer# copymod, filtmod, and filtimpl. 397fb9f9b97Skupfer# 398fb9f9b97Skupfer# Changes to this target may require corresponding changes to 399fb9f9b97Skupfer# Install.sh. 40084d8c05bSMike Kupfer# 401fb9f9b97Skupfer# Don't issue a MOD entry if it's not in the install list. 402fb9f9b97Skupfer# 40384d8c05bSMike Kupfer 404fb9f9b97Skupfer$(MODLIST_DEPS): FRC 405fb9f9b97Skupfer @case $@ in \ 406fb9f9b97Skupfer *32) \ 407fb9f9b97Skupfer class=32; \ 40884d8c05bSMike Kupfer [ -n "$(RELMODULE)" ] && relmodule=`dirname $(RELMODULE)`;; \ 409fb9f9b97Skupfer *64) \ 410fb9f9b97Skupfer class=64; \ 41184d8c05bSMike Kupfer [ -n "$(RELMODULE)" ] && \ 41284d8c05bSMike Kupfer relmodule=`dirname $(RELMODULE)`/$(SUBDIR64);; \ 413fb9f9b97Skupfer esac; \ 414fb9f9b97Skupfer if [ -z "$(THISIMPL)" ]; then \ 415fb9f9b97Skupfer impl=all; \ 416fb9f9b97Skupfer else \ 417fb9f9b97Skupfer impl=$(THISIMPL); \ 418fb9f9b97Skupfer fi; \ 419fb9f9b97Skupfer if [ -n "$(ROOTMODULE)" -a -n "$(INSTALL_TARGET)" ]; then \ 420fb9f9b97Skupfer if [ -z "$(MODULE)" ]; then \ 421fb9f9b97Skupfer module=`basename $(ROOTMODULE)`; \ 422fb9f9b97Skupfer else \ 423fb9f9b97Skupfer module=$(MODULE); \ 424fb9f9b97Skupfer fi; \ 425fb9f9b97Skupfer tinstall="$(INSTALL_TARGET)"; \ 426fb9f9b97Skupfer for t in $$tinstall; do \ 427fb9f9b97Skupfer if [ "$(ROOTMODULE)" = $$t ]; then \ 42884d8c05bSMike Kupfer echo MOD $(MODSRC) $$module $$relmodule \ 42984d8c05bSMike Kupfer $$class $$impl; \ 430fb9f9b97Skupfer break; \ 431fb9f9b97Skupfer fi \ 432fb9f9b97Skupfer done \ 433fb9f9b97Skupfer fi; \ 434fb9f9b97Skupfer if [ -n "$(CONF_SRCDIR)" ]; then \ 435fb9f9b97Skupfer tinstall="$(INSTALL_TARGET)"; \ 436fb9f9b97Skupfer for t in $$tinstall; do \ 437fb9f9b97Skupfer if [ $(ROOT_CONFFILE) = $$t ]; then \ 43884d8c05bSMike Kupfer echo CONF $(MODSRC) $(RELCONF) \ 439fb9f9b97Skupfer $(MODSRC)/$(CONF_SRCDIR) $$impl $$module; \ 440fb9f9b97Skupfer break; \ 441fb9f9b97Skupfer fi \ 442fb9f9b97Skupfer done \ 443fb9f9b97Skupfer fi; \ 444fb9f9b97Skupfer if [ -n "$(ROOTLINK)" ]; then \ 4450f1702c5SYu Xiangning rellinks="$(RELLINK)"; \ 4460f1702c5SYu Xiangning for r in $$rellinks; do \ 44784d8c05bSMike Kupfer if [ $$class = 32 ]; then \ 44884d8c05bSMike Kupfer linkdir=`dirname $$r`; \ 44984d8c05bSMike Kupfer else \ 45084d8c05bSMike Kupfer linkdir=`dirname $$r`/$(SUBDIR64); \ 45184d8c05bSMike Kupfer fi; \ 45284d8c05bSMike Kupfer echo LINK $(MODSRC) $$relmodule $$module \ 45384d8c05bSMike Kupfer $$linkdir `basename $$r` $$impl; \ 4540f1702c5SYu Xiangning done \ 455fb9f9b97Skupfer fi; \ 456fb9f9b97Skupfer if [ -n "$(UNIX32_LINK)" ]; then \ 45784d8c05bSMike Kupfer echo SYMLINK $(MODSRC) $(SUBDIR64)/$(UNIX) \ 458fb9f9b97Skupfer `dirname $(RELUNIX)` unix $$impl $$module; \ 459fb9f9b97Skupfer fi; \ 460fb9f9b97Skupfer trelsoftlinks="$(RELSOFTLINKS)"; \ 461fb9f9b97Skupfer for t in $$trelsoftlinks; do \ 462fb9f9b97Skupfer if [ $$class = 32 ]; then \ 463fb9f9b97Skupfer linkdir=`dirname $$t`; \ 464fb9f9b97Skupfer else \ 465fb9f9b97Skupfer linkdir=`dirname $$t`/$(SUBDIR64); \ 466fb9f9b97Skupfer fi; \ 467fb9f9b97Skupfer linkname=`basename $$t`; \ 46884d8c05bSMike Kupfer echo SYMLINK $(MODSRC) $(MODULE) $$linkdir $$linkname \ 469fb9f9b97Skupfer $$impl $$module; \ 470fb9f9b97Skupfer done 471fb9f9b97Skupfer 4727c478bd9Sstevel@tonic-gate# 4737c478bd9Sstevel@tonic-gate# Cleanliness is next to ... 4747c478bd9Sstevel@tonic-gate# 4757c478bd9Sstevel@tonic-gateclean.targ: 4767c478bd9Sstevel@tonic-gate -$(RM) $(CLEANFILES) Nothing_to_remove 4777c478bd9Sstevel@tonic-gate 4787c478bd9Sstevel@tonic-gateclobber.targ: 4797c478bd9Sstevel@tonic-gate -$(RM) $(CLOBBERFILES) Nothing_to_remove 4807c478bd9Sstevel@tonic-gate 4817c478bd9Sstevel@tonic-gateclean.lint.targ: 4827c478bd9Sstevel@tonic-gate -$(RM) $(CLEANLINTFILES) Nothing_to_remove 4837c478bd9Sstevel@tonic-gate 4847c478bd9Sstevel@tonic-gate# 4857c478bd9Sstevel@tonic-gate# Create fake lintlibs in the 64b dirs so 4867c478bd9Sstevel@tonic-gate# global linting works 4877c478bd9Sstevel@tonic-gate# 4887c478bd9Sstevel@tonic-gatelint64: 4897c478bd9Sstevel@tonic-gate @$(ECHO) $(MODULE) fake lints 4907c478bd9Sstevel@tonic-gate @for dir in $(LINT64_DIRS); do \ 4917c478bd9Sstevel@tonic-gate if [ ! -d $$dir ]; then mkdir $$dir; fi \ 4927c478bd9Sstevel@tonic-gate done 4937c478bd9Sstevel@tonic-gate @for file in $(LINT64_FILES); do \ 4947c478bd9Sstevel@tonic-gate if [ ! -f $$file ]; then touch $$file; fi \ 4957c478bd9Sstevel@tonic-gate done 4967c478bd9Sstevel@tonic-gate 497bbbed746SGordon Ross# 498bbbed746SGordon Ross# In some places we also need to create fake lintlibs for 32b 499bbbed746SGordon Ross# dirs so global linting works 500bbbed746SGordon Ross# 501bbbed746SGordon Rosslint32: 502bbbed746SGordon Ross @$(ECHO) $(MODULE) fake lints 503bbbed746SGordon Ross @for dir in $(LINT32_DIRS); do \ 504bbbed746SGordon Ross if [ ! -d $$dir ]; then mkdir $$dir; fi \ 505bbbed746SGordon Ross done 506bbbed746SGordon Ross @for file in $(LINT32_FILES); do \ 507bbbed746SGordon Ross if [ ! -f $$file ]; then touch $$file; fi \ 508bbbed746SGordon Ross done 509bbbed746SGordon Ross 5107c478bd9Sstevel@tonic-gateFRC: 511