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> 257c478bd9Sstevel@tonic-gate# 267c478bd9Sstevel@tonic-gate# This Makefiles contains the common targets and definitions for 277c478bd9Sstevel@tonic-gate# all kernels. It is to be included in the Makefiles for specific 287c478bd9Sstevel@tonic-gate# implementation architectures and processor architecture dependent 297c478bd9Sstevel@tonic-gate# modules: i.e.: all driving kernel Makefiles. 307c478bd9Sstevel@tonic-gate# 317c478bd9Sstevel@tonic-gate 327c478bd9Sstevel@tonic-gate# 337c478bd9Sstevel@tonic-gate# Default rule for building the lint library directory: 347c478bd9Sstevel@tonic-gate# 357c478bd9Sstevel@tonic-gate$(LINT_LIB_DIR): 367c478bd9Sstevel@tonic-gate -@mkdir -p $@ 2> /dev/null 377c478bd9Sstevel@tonic-gate 387c478bd9Sstevel@tonic-gate# 397c478bd9Sstevel@tonic-gate# All C objects depend on inline files. However, cc(1) doesn't generate 407c478bd9Sstevel@tonic-gate# the correct dependency info. Also, these Makefiles don't contain a 417c478bd9Sstevel@tonic-gate# separate list of C-derived object files (but it is light weight to 427c478bd9Sstevel@tonic-gate# let the assembler files think they depend upon this when they don't). 437c478bd9Sstevel@tonic-gate# Fortunately, the inline files won't change very often. So, for now, 447c478bd9Sstevel@tonic-gate# all objects depend on the inline files. Remove this when the inliner 457c478bd9Sstevel@tonic-gate# is fixed to drop correct dependency information. 467c478bd9Sstevel@tonic-gate# 477c478bd9Sstevel@tonic-gate$(OBJECTS): $(INLINES) 487c478bd9Sstevel@tonic-gate 497c478bd9Sstevel@tonic-gate# 507c478bd9Sstevel@tonic-gate# Partially link .o files to generate the kmod. The fake dependency 517c478bd9Sstevel@tonic-gate# on modstubs simplifies things... 527c478bd9Sstevel@tonic-gate# 537c478bd9Sstevel@tonic-gate$(BINARY): $(OBJECTS) 547c478bd9Sstevel@tonic-gate $(LD) -r $(LDFLAGS) -o $@ $(OBJECTS) 557c478bd9Sstevel@tonic-gate $(CTFMERGE_UNIQUIFY_AGAINST_GENUNIX) 567c478bd9Sstevel@tonic-gate $(POST_PROCESS) 577c478bd9Sstevel@tonic-gate 587c478bd9Sstevel@tonic-gate# 597c478bd9Sstevel@tonic-gate# This target checks each kmod for undefined entry points. It does not 607c478bd9Sstevel@tonic-gate# modify the kmod in any way. 617c478bd9Sstevel@tonic-gate# 627c478bd9Sstevel@tonic-gate$(MODULE).check: FRC 637c478bd9Sstevel@tonic-gate @BUILD_TYPE=DBG32 $(MAKE) $(MODULE).check.targ 647c478bd9Sstevel@tonic-gate 657c478bd9Sstevel@tonic-gate$(MODULE).check.targ: $(BINARY) $(OBJECTS) $(EXTRA_CHECK_OBJS) $(UNIX_O) $(MODSTUBS_O) $(GENLIB) 667c478bd9Sstevel@tonic-gate $(LD) -o /dev/null $(OBJECTS) $(EXTRA_CHECK_OBJS) $(UNIX_O) $(MODSTUBS_O) $(GENLIB) 677c478bd9Sstevel@tonic-gate 687c478bd9Sstevel@tonic-gate# 697c478bd9Sstevel@tonic-gate# Module lint library construction targets. 707c478bd9Sstevel@tonic-gate# 717c478bd9Sstevel@tonic-gateMOD_LINT_LIB = $(LINT_LIB_DIR)/llib-l$(LINT_MODULE).ln 727c478bd9Sstevel@tonic-gate 737c478bd9Sstevel@tonic-gate$(MOD_LINT_LIB): $(LINT_LIB_DIR) $(LINTS) 747c478bd9Sstevel@tonic-gate @-$(ECHO) "\n$(OBJS_DIR)/$(MODULE): (library construction):" 75878eeb1bSGordon Ross @($(LINT) -o $(LINT_MODULE)-$(OBJS_DIR) \ 76878eeb1bSGordon Ross $(LINTFLAGS) $(LINTS) $(LTAIL)) 77ae115bc7Smrj @$(MV) llib-l$(LINT_MODULE)-$(OBJS_DIR).ln $@ 787c478bd9Sstevel@tonic-gate 797c478bd9Sstevel@tonic-gate$(LINT_MODULE).lint: $(MOD_LINT_LIB) $(LINT_LIB) $(GEN_LINT_LIB) 807c478bd9Sstevel@tonic-gate @-$(ECHO) "\n$(OBJS_DIR)/$(LINT_MODULE): global crosschecks:" 81878eeb1bSGordon Ross @($(LINT) $(LINTFLAGS) $(MOD_LINT_LIB) \ 82878eeb1bSGordon Ross $(LINT_LIB) $(GEN_LINT_LIB) $(LTAIL)) 837c478bd9Sstevel@tonic-gate 847c478bd9Sstevel@tonic-gate# 857c478bd9Sstevel@tonic-gate# Since assym.h is a derived file, the dependency must be explicit for 867c478bd9Sstevel@tonic-gate# all files including this file. (This is only actually required in the 877c478bd9Sstevel@tonic-gate# instance when the .nse_depinfo file does not exist.) It may seem that 887c478bd9Sstevel@tonic-gate# the lint targets should also have a similar dependency, but they don't 897c478bd9Sstevel@tonic-gate# since only C headers are included when #defined(lint) is true. The 907c478bd9Sstevel@tonic-gate# actual lists are defined in */Makefile.files. 917c478bd9Sstevel@tonic-gate# 927c478bd9Sstevel@tonic-gate$(ASSYM_DEPS:%=$(OBJS_DIR)/%): $(DSF_DIR)/$(OBJS_DIR)/assym.h 937c478bd9Sstevel@tonic-gate 947c478bd9Sstevel@tonic-gate# 957c478bd9Sstevel@tonic-gate# Everybody need to know how to create a modstubs.o built with the 967c478bd9Sstevel@tonic-gate# appropriate flags and located in the appropriate location. 977c478bd9Sstevel@tonic-gate# 987c478bd9Sstevel@tonic-gate$(MODSTUBS_O): $(MODSTUBS) 997c478bd9Sstevel@tonic-gate $(COMPILE.s) -o $@ $(MODSTUBS) 1007c478bd9Sstevel@tonic-gate 1017c478bd9Sstevel@tonic-gate$(LINTS_DIR)/modstubs.ln: $(MODSTUBS) 1027c478bd9Sstevel@tonic-gate @($(LHEAD) $(LINT.s) $(MODSTUBS) $(LTAIL)) 1037c478bd9Sstevel@tonic-gate 1047c478bd9Sstevel@tonic-gate# 1057c478bd9Sstevel@tonic-gate# Build the source file which contains the kernel's utsname, 1067c478bd9Sstevel@tonic-gate# with release, version and machine set as follows: 1077c478bd9Sstevel@tonic-gate# 1087c478bd9Sstevel@tonic-gate# release: contents of $(RELEASE) (Spaces replaced by '_') 1097c478bd9Sstevel@tonic-gate# version: contents of $(PATCHID) (Spaces replaced by '_') 110ae115bc7Smrj# machine: contents of $(UNAME_M) 1117c478bd9Sstevel@tonic-gate# 1127c478bd9Sstevel@tonic-gate# Build environment information is only contained in the comment section. 1137c478bd9Sstevel@tonic-gate# 1147c478bd9Sstevel@tonic-gate 1157c478bd9Sstevel@tonic-gate$(OBJS_DIR)/vers.o: $(OBJECTS) 1167c478bd9Sstevel@tonic-gate $(COMPILE.c) -DUTS_RELEASE=\"`$(ECHO) $(RELEASE) | sed -e 's/ /_/g'`\" \ 11734ae5cdfSJosef 'Jeff' Sipek -DUTS_VERSION=\"`$(ECHO) $(PATCHID) | sed -e 's/ /_/g'`\" \ 118ae115bc7Smrj -DUTS_PLATFORM=\"$(UNAME_M)\" -o $@ $(SRC)/uts/common/os/vers.c 1197c478bd9Sstevel@tonic-gate $(CTFCONVERT_O) 1207c478bd9Sstevel@tonic-gate $(POST_PROCESS_O) 1217c478bd9Sstevel@tonic-gate 1227c478bd9Sstevel@tonic-gate$(LINTS_DIR)/vers.ln: $(SRC)/uts/common/os/vers.c 1237c478bd9Sstevel@tonic-gate @($(LHEAD) $(LINT.c) -DUTS_RELEASE=\"\" -DUTS_VERSION=\"\" \ 1247c478bd9Sstevel@tonic-gate -DUTS_PLATFORM=\"\" $(SRC)/uts/common/os/vers.c $(LTAIL)) 1257c478bd9Sstevel@tonic-gate 1267c478bd9Sstevel@tonic-gate# 1277c478bd9Sstevel@tonic-gate# Installation targets and rules: 1287c478bd9Sstevel@tonic-gate# 1297c478bd9Sstevel@tonic-gate$(ROOT_MOD_DIR) $(USR_MOD_DIR): 13048bc00d6Sjmcp -$(INS.dir) 1317c478bd9Sstevel@tonic-gate 1327c478bd9Sstevel@tonic-gate$(ROOT_MOD_DIRS_32): $(ROOT_MOD_DIR) 13348bc00d6Sjmcp -$(INS.dir) 1347c478bd9Sstevel@tonic-gate 1357c478bd9Sstevel@tonic-gate$(USR_MOD_DIRS_32): $(USR_MOD_DIR) 13648bc00d6Sjmcp -$(INS.dir) 1377c478bd9Sstevel@tonic-gate 1387c478bd9Sstevel@tonic-gate$(ROOT_MOD_DIR)/%: $(OBJS_DIR)/% $(ROOT_MOD_DIR) FRC 1397c478bd9Sstevel@tonic-gate $(INS.file) 1407c478bd9Sstevel@tonic-gate 1417aec1d6eScindi$(ROOT_CPU_DIR)/%: $(OBJS_DIR)/% $(ROOT_CPU_DIR) FRC 1427aec1d6eScindi $(INS.file) 1437aec1d6eScindi 1447c478bd9Sstevel@tonic-gate$(ROOT_DRV_DIR)/%: $(OBJS_DIR)/% $(ROOT_DRV_DIR) FRC 1457c478bd9Sstevel@tonic-gate $(INS.file) 1467c478bd9Sstevel@tonic-gate 1477c478bd9Sstevel@tonic-gate$(ROOT_DTRACE_DIR)/%: $(OBJS_DIR)/% $(ROOT_DTRACE_DIR) FRC 1487c478bd9Sstevel@tonic-gate $(INS.file) 1497c478bd9Sstevel@tonic-gate 1507c478bd9Sstevel@tonic-gate$(ROOT_EXEC_DIR)/%: $(OBJS_DIR)/% $(ROOT_EXEC_DIR) FRC 1517c478bd9Sstevel@tonic-gate $(INS.file) 1527c478bd9Sstevel@tonic-gate 1537c478bd9Sstevel@tonic-gate$(ROOT_FS_DIR)/%: $(OBJS_DIR)/% $(ROOT_FS_DIR) FRC 1547c478bd9Sstevel@tonic-gate $(INS.file) 1557c478bd9Sstevel@tonic-gate 1567c478bd9Sstevel@tonic-gate$(ROOT_SCHED_DIR)/%: $(OBJS_DIR)/% $(ROOT_SCHED_DIR) FRC 1577c478bd9Sstevel@tonic-gate $(INS.file) 1587c478bd9Sstevel@tonic-gate 1590f1702c5SYu Xiangning$(ROOT_SOCK_DIR)/%: $(OBJS_DIR)/% $(ROOT_SOCK_DIR) FRC 1600f1702c5SYu Xiangning $(INS.file) 1610f1702c5SYu Xiangning 1627c478bd9Sstevel@tonic-gate$(ROOT_STRMOD_DIR)/%: $(OBJS_DIR)/% $(ROOT_STRMOD_DIR) FRC 1637c478bd9Sstevel@tonic-gate $(INS.file) 1647c478bd9Sstevel@tonic-gate 1657c478bd9Sstevel@tonic-gate$(ROOT_IPP_DIR)/%: $(OBJS_DIR)/% $(ROOT_IPP_DIR) FRC 1667c478bd9Sstevel@tonic-gate $(INS.file) 1677c478bd9Sstevel@tonic-gate 1687c478bd9Sstevel@tonic-gate$(ROOT_SYS_DIR)/%: $(OBJS_DIR)/% $(ROOT_SYS_DIR) FRC 1697c478bd9Sstevel@tonic-gate $(INS.file) 1707c478bd9Sstevel@tonic-gate 1717c478bd9Sstevel@tonic-gate$(ROOT_MISC_DIR)/%: $(OBJS_DIR)/% $(ROOT_MISC_DIR) FRC 1727c478bd9Sstevel@tonic-gate $(INS.file) 1737c478bd9Sstevel@tonic-gate 1747c478bd9Sstevel@tonic-gate$(ROOT_DACF_DIR)/%: $(OBJS_DIR)/% $(ROOT_DACF_DIR) FRC 1757c478bd9Sstevel@tonic-gate $(INS.file) 1767c478bd9Sstevel@tonic-gate 1779acbbeafSnn$(ROOT_BRAND_DIR)/%: $(OBJS_DIR)/% $(ROOT_BRAND_DIR) FRC 1789acbbeafSnn $(INS.file) 1799acbbeafSnn 1807c478bd9Sstevel@tonic-gate$(ROOT_CRYPTO_DIR)/%: $(OBJS_DIR)/% $(ROOT_CRYPTO_DIR) FRC 1817c478bd9Sstevel@tonic-gate $(INS.file) 1827c478bd9Sstevel@tonic-gate 1837c478bd9Sstevel@tonic-gate$(ROOT_KGSS_DIR)/%: $(OBJS_DIR)/% $(ROOT_KGSS_DIR) FRC 1847c478bd9Sstevel@tonic-gate $(INS.file) 1857c478bd9Sstevel@tonic-gate 1861e1ddd6cScth$(ROOT_SCSI_VHCI_DIR)/%: $(OBJS_DIR)/% $(ROOT_SCSI_VHCI_DIR) FRC 1871e1ddd6cScth $(INS.file) 1881e1ddd6cScth 1894c06356bSdh$(ROOT_PMCS_FW_DIR)/%: $(OBJS_DIR)/% $(ROOT_PMCS_FW_DIR) FRC 1904c06356bSdh $(INS.file) 1914c06356bSdh 192fcf3ce44SJohn Forte$(ROOT_QLC_FW_DIR)/%: $(OBJS_DIR)/% $(ROOT_QLC_FW_DIR) FRC 193fcf3ce44SJohn Forte $(INS.file) 194fcf3ce44SJohn Forte 195291a2b48SSukumar Swaminathan$(ROOT_EMLXS_FW_DIR)/%: $(OBJS_DIR)/% $(ROOT_EMLXS_FW_DIR) FRC 196291a2b48SSukumar Swaminathan $(INS.file) 197291a2b48SSukumar Swaminathan 1987c478bd9Sstevel@tonic-gate$(ROOT_MACH_DIR)/%: $(OBJS_DIR)/% $(ROOT_MACH_DIR) FRC 1997c478bd9Sstevel@tonic-gate $(INS.file) 2007c478bd9Sstevel@tonic-gate 2017c478bd9Sstevel@tonic-gate$(ROOT_FONT_DIR)/%: $(OBJS_DIR)/% $(ROOT_MOD_DIR) $(ROOT_FONT_DIR) FRC 2027c478bd9Sstevel@tonic-gate $(INS.file) 2037c478bd9Sstevel@tonic-gate 204ba2e4443Sseb$(ROOT_MAC_DIR)/%: $(OBJS_DIR)/% $(ROOT_MOD_DIR) $(ROOT_MAC_DIR) FRC 205ba2e4443Sseb $(INS.file) 206ba2e4443Sseb 2077c478bd9Sstevel@tonic-gate$(USR_DRV_DIR)/%: $(OBJS_DIR)/% $(USR_DRV_DIR) FRC 2087c478bd9Sstevel@tonic-gate $(INS.file) 2097c478bd9Sstevel@tonic-gate 2107c478bd9Sstevel@tonic-gate$(USR_EXEC_DIR)/%: $(OBJS_DIR)/% $(USR_EXEC_DIR) FRC 2117c478bd9Sstevel@tonic-gate $(INS.file) 2127c478bd9Sstevel@tonic-gate 2137c478bd9Sstevel@tonic-gate$(USR_FS_DIR)/%: $(OBJS_DIR)/% $(USR_FS_DIR) FRC 2147c478bd9Sstevel@tonic-gate $(INS.file) 2157c478bd9Sstevel@tonic-gate 2167c478bd9Sstevel@tonic-gate$(USR_SCHED_DIR)/%: $(OBJS_DIR)/% $(USR_SCHED_DIR) FRC 2177c478bd9Sstevel@tonic-gate $(INS.file) 2187c478bd9Sstevel@tonic-gate 2190a0e9771SDarren Reed$(USR_SOCK_DIR)/%: $(OBJS_DIR)/% $(USR_SOCK_DIR) FRC 2200a0e9771SDarren Reed $(INS.file) 2210a0e9771SDarren Reed 2227c478bd9Sstevel@tonic-gate$(USR_STRMOD_DIR)/%: $(OBJS_DIR)/% $(USR_STRMOD_DIR) FRC 2237c478bd9Sstevel@tonic-gate $(INS.file) 2247c478bd9Sstevel@tonic-gate 2257c478bd9Sstevel@tonic-gate$(USR_SYS_DIR)/%: $(OBJS_DIR)/% $(USR_SYS_DIR) FRC 2267c478bd9Sstevel@tonic-gate $(INS.file) 2277c478bd9Sstevel@tonic-gate 2287c478bd9Sstevel@tonic-gate$(USR_MISC_DIR)/%: $(OBJS_DIR)/% $(USR_MISC_DIR) FRC 2297c478bd9Sstevel@tonic-gate $(INS.file) 2307c478bd9Sstevel@tonic-gate 2317c478bd9Sstevel@tonic-gate$(USR_DACF_DIR)/%: $(OBJS_DIR)/% $(USR_DACF_DIR) FRC 2327c478bd9Sstevel@tonic-gate $(INS.file) 2337c478bd9Sstevel@tonic-gate 2347c478bd9Sstevel@tonic-gate$(USR_PCBE_DIR)/%: $(OBJS_DIR)/% $(USR_PCBE_DIR) FRC 2357c478bd9Sstevel@tonic-gate $(INS.file) 2367c478bd9Sstevel@tonic-gate 2379a9ae70fSjv$(USR_DTRACE_DIR)/%: $(OBJS_DIR)/% $(USR_DTRACE_DIR) FRC 2389a9ae70fSjv $(INS.file) 2399a9ae70fSjv 2409a9ae70fSjv$(USR_BRAND_DIR)/%: $(OBJS_DIR)/% $(USR_BRAND_DIR) FRC 2419a9ae70fSjv $(INS.file) 2429a9ae70fSjv 243d14d7d31Sis$(ROOT_KICONV_DIR)/%: $(OBJS_DIR)/% $(ROOT_KICONV_DIR) FRC 244d14d7d31Sis $(INS.file) 245d14d7d31Sis 246f73e0305SHans Rosenfeld$(ROOT_FIRMWARE_DIR)/$(MODULE): 247f73e0305SHans Rosenfeld $(INS.dir) 248f73e0305SHans Rosenfeld 249f73e0305SHans Rosenfeld$(ROOT_FIRMWARE_DIR)/$(MODULE)/%:= FILEMODE = $(CFILEMODE) 250f73e0305SHans Rosenfeld 251f73e0305SHans Rosenfeld$(ROOT_FIRMWARE_DIR)/$(MODULE)/%: $(ROOT_FIRMWARE_DIR)/$(MODULE) $(FWDIR)/% 252f73e0305SHans Rosenfeld $(INS.file) 253f73e0305SHans Rosenfeld 2547c478bd9Sstevel@tonic-gateinclude $(SRC)/Makefile.psm.targ 2557c478bd9Sstevel@tonic-gate 2567c478bd9Sstevel@tonic-gate# 2577c478bd9Sstevel@tonic-gate# Target for 64b modules 2587c478bd9Sstevel@tonic-gate# 2597c478bd9Sstevel@tonic-gate$(ROOT_KERN_DIR_64): 26048bc00d6Sjmcp -$(INS.dir) 2617c478bd9Sstevel@tonic-gate 2627c478bd9Sstevel@tonic-gate$(ROOT_KERN_DIR_64)/%: $(OBJS_DIR)/% $(ROOT_KERN_DIR_64) FRC 2637c478bd9Sstevel@tonic-gate $(INS.file) 2647c478bd9Sstevel@tonic-gate 2657c478bd9Sstevel@tonic-gate%/$(SUBDIR64): % 26648bc00d6Sjmcp -$(INS.dir) 2677c478bd9Sstevel@tonic-gate 2687c478bd9Sstevel@tonic-gate# 2697c478bd9Sstevel@tonic-gate# Targets for '.conf' file installation. 2707c478bd9Sstevel@tonic-gate# 2717c478bd9Sstevel@tonic-gate$(ROOT_CONFFILE): $(SRC_CONFFILE) $(ROOT_CONFFILE:%/$(CONFFILE)=%) 2727c478bd9Sstevel@tonic-gate $(INS.conffile) 2737c478bd9Sstevel@tonic-gate 2747c478bd9Sstevel@tonic-gate# 2757c478bd9Sstevel@tonic-gate# Targets for creating links between common platforms. ROOT_PLAT_LINKS 2767c478bd9Sstevel@tonic-gate# are are the /platform level while ROOT_PLAT_LINKS_2 are one level 2777c478bd9Sstevel@tonic-gate# down (/platform/`uname -i`/{lib|sbin|kernel}. 2787c478bd9Sstevel@tonic-gate# 2797c478bd9Sstevel@tonic-gate$(ROOT_PLAT_LINKS): 2807c478bd9Sstevel@tonic-gate $(INS.slink1) 2817c478bd9Sstevel@tonic-gate 2827c478bd9Sstevel@tonic-gate$(ROOT_PLAT_LINKS_2): 2837c478bd9Sstevel@tonic-gate $(INS.slink2) 2847c478bd9Sstevel@tonic-gate 2857c478bd9Sstevel@tonic-gate$(USR_PLAT_LINKS): 2867c478bd9Sstevel@tonic-gate $(INS.slink1) 2877c478bd9Sstevel@tonic-gate 2887c478bd9Sstevel@tonic-gate$(USR_PLAT_LINKS_2): 2897c478bd9Sstevel@tonic-gate $(INS.slink2) 2907c478bd9Sstevel@tonic-gate 2917c478bd9Sstevel@tonic-gate# 2927c478bd9Sstevel@tonic-gate# multiple builds support 2937c478bd9Sstevel@tonic-gate# 2947c478bd9Sstevel@tonic-gatedef $(DEF_DEPS) := TARGET = def 2957c478bd9Sstevel@tonic-gateall $(ALL_DEPS) := TARGET = all 2967c478bd9Sstevel@tonic-gateclean $(CLEAN_DEPS) := TARGET = clean 2977c478bd9Sstevel@tonic-gateclobber $(CLOBBER_DEPS) := TARGET = clobber 2987c478bd9Sstevel@tonic-gatelint $(LINT_DEPS) := TARGET = lint 2997c478bd9Sstevel@tonic-gatemodlintlib $(MODLINTLIB_DEPS) := TARGET = modlintlib 300fb9f9b97Skupfermodlist $(MODLIST_DEPS) := TARGET = modlist 301fb9f9b97Skupfermodlist $(MODLIST_DEPS) := NO_STATE= -K $$MODSTATE$$$$ 3027c478bd9Sstevel@tonic-gateclean.lint $(CLEAN_LINT_DEPS) := TARGET = clean.lint 3037c478bd9Sstevel@tonic-gateinstall $(INSTALL_DEPS) := TARGET = install 3047c478bd9Sstevel@tonic-gatesymcheck $(SYM_DEPS) := TARGET = symcheck 3057c478bd9Sstevel@tonic-gate 306fb9f9b97SkupferALL_TARGS = def all clean clobber lint modlintlib \ 307fb9f9b97Skupfer clean.lint lintlib install symcheck 3087c478bd9Sstevel@tonic-gate 309*bbbed746SGordon RossALL_OBJ32 = $(ALL_TARGS:%=%.obj32) 310*bbbed746SGordon Ross 311*bbbed746SGordon Ross$(ALL_OBJ32): FRC 312*bbbed746SGordon Ross @BUILD_TYPE=OBJ32 VERSION='$(VERSION)' $(MAKE) $(NO_STATE) $(TARGET).targ 313*bbbed746SGordon Ross 314*bbbed746SGordon RossALL_DEBUG32 = $(ALL_TARGS:%=%.debug32) 315*bbbed746SGordon Ross 316*bbbed746SGordon Ross$(ALL_DEBUG32): FRC 317*bbbed746SGordon Ross @BUILD_TYPE=DBG32 VERSION='$(VERSION)' $(MAKE) $(NO_STATE) $(TARGET).targ 318*bbbed746SGordon Ross 3197c478bd9Sstevel@tonic-gateALL_OBJ64 = $(ALL_TARGS:%=%.obj64) 3207c478bd9Sstevel@tonic-gate 3217c478bd9Sstevel@tonic-gate$(ALL_OBJ64): FRC 322fb9f9b97Skupfer @BUILD_TYPE=OBJ64 VERSION='$(VERSION)' $(MAKE) $(NO_STATE) $(TARGET).targ 3237c478bd9Sstevel@tonic-gate 3247c478bd9Sstevel@tonic-gateALL_DEBUG64 = $(ALL_TARGS:%=%.debug64) 3257c478bd9Sstevel@tonic-gate 3267c478bd9Sstevel@tonic-gate$(ALL_DEBUG64): FRC 327fb9f9b97Skupfer @BUILD_TYPE=DBG64 VERSION='$(VERSION)' $(MAKE) $(NO_STATE) $(TARGET).targ 3287c478bd9Sstevel@tonic-gate 329112f9fc1Syz# 330112f9fc1Syz# Currently only the IP module needs symbol checking on obj64. 331112f9fc1Syz# Other modules have the same global-objs nm output for debug64 and obj64. 332112f9fc1Syz# 333112f9fc1Syz$(SISCHECK_DEPS): $(DEF_DEPS) 334112f9fc1Syz @TARG=`$(ECHO) $@ | $(CUT) -d'.' -f2`; \ 335112f9fc1Syz MODSYMS=$(MODULE).symbols.$$TARG; \ 336112f9fc1Syz if [ -f "$(MODULE).global-objs.$$TARG" ]; then \ 337112f9fc1Syz $(GREP) -v '#' $(MODULE).global-objs.$$TARG |$(GREP) . | \ 338112f9fc1Syz $(SORT) -u > $$MODSYMS.tmp; \ 339112f9fc1Syz $(NM) $$TARG/$(MODULE) |$(GREP) OBJT |$(GREP) -v UNDEF | \ 340756e192dSyz $(CUT) -d'|' -f8 |$(GREP) -v '^___const_' | \ 341756e192dSyz $(GREP) -v '\.[0-9]*$$' |$(SORT) -u \ 342112f9fc1Syz > $$MODSYMS.tmp.new; \ 343112f9fc1Syz $(DIFF) $$MODSYMS.tmp $$MODSYMS.tmp.new > $$MODSYMS.diff || \ 344112f9fc1Syz ($(ECHO) "warning: $(MODULE) symbol checking:" \ 345112f9fc1Syz "global variable(s) introduced and/or removed."; \ 346112f9fc1Syz $(CAT) $$MODSYMS.diff; exit 1) \ 347112f9fc1Syz fi 348112f9fc1Syz 349112f9fc1Syz$(SISCLEAN_DEPS): 350112f9fc1Syz -TARG=`$(ECHO) $@ | $(CUT) -d'.' -f2`; \ 351112f9fc1Syz MODSYMS=$(MODULE).symbols.$$TARG; \ 352112f9fc1Syz $(RM) $$MODSYMS.tmp $$MODSYMS.tmp.new $$MODSYMS.diff Nothing_to_remove 353112f9fc1Syz 3547c478bd9Sstevel@tonic-gate 3557c478bd9Sstevel@tonic-gate$(OBJS_DIR): 3567c478bd9Sstevel@tonic-gate -@mkdir -p $@ 2> /dev/null 3577c478bd9Sstevel@tonic-gate 3587c478bd9Sstevel@tonic-gatedef.targ: $(OBJS_DIR) $(ALL_TARGET) 3597c478bd9Sstevel@tonic-gate 3607c478bd9Sstevel@tonic-gateall.targ: $(OBJS_DIR) $(ALL_TARGET) 3617c478bd9Sstevel@tonic-gate 3627c478bd9Sstevel@tonic-gatelint.targ: $(OBJS_DIR) $(LINT_TARGET) 3637c478bd9Sstevel@tonic-gate 3647c478bd9Sstevel@tonic-gatemodlintlib.targ: $(OBJS_DIR) $(MOD_LINT_LIB) 3657c478bd9Sstevel@tonic-gate 3667c478bd9Sstevel@tonic-gateinstall.targ: $(OBJS_DIR) $(INSTALL_TARGET) 3677c478bd9Sstevel@tonic-gate 368fb9f9b97Skupfer# 369fb9f9b97Skupfer# Support for Install.sh. 370fb9f9b97Skupfer# 371fb9f9b97Skupfer 372fb9f9b97Skupfermodlist: $(MODLIST_DEPS) 373fb9f9b97Skupfer 374fb9f9b97Skupfer# paths relative to $(ROOT). 375fb9f9b97SkupferRELMODULE = $(ROOTMODULE:$(ROOT)/%=%) 376fb9f9b97SkupferRELCONF = $(ROOT_CONFFILE:$(ROOT)/%=%) 377fb9f9b97SkupferRELLINK = $(ROOTLINK:$(ROOT)/%=%) 378fb9f9b97SkupferRELUNIX = $(UNIX32_LINK:$(ROOT)/%=%) 379fb9f9b97SkupferRELSOFTLINKS = $(ROOTSOFTLINKS:$(ROOT)/%=%) 380fb9f9b97Skupfer 381fb9f9b97SkupferMODSRC:sh= pwd 382fb9f9b97Skupfer 38384d8c05bSMike Kupfer# 38484d8c05bSMike Kupfer# Generate module information for Install.sh, i.e., specify what files 38584d8c05bSMike Kupfer# Install.sh should include. Each line looks like 38684d8c05bSMike Kupfer# <tag> <srcdir> <arg1> <arg2> ... 38784d8c05bSMike Kupfer# where <tag> specifies the type of file, <srcdir> gives the source 38884d8c05bSMike Kupfer# path (useful if there is an error), and <argN> is one or more 38984d8c05bSMike Kupfer# additional bits of information that Install.sh needs (e.g., source 39084d8c05bSMike Kupfer# directory, install directory, filtering tags). See Install.sh for 39184d8c05bSMike Kupfer# details on the arguments for each tag type, especially the functions 39284d8c05bSMike Kupfer# copymod, filtmod, and filtimpl. 393fb9f9b97Skupfer# 394fb9f9b97Skupfer# Changes to this target may require corresponding changes to 395fb9f9b97Skupfer# Install.sh. 39684d8c05bSMike Kupfer# 397fb9f9b97Skupfer# Don't issue a MOD entry if it's not in the install list. 398fb9f9b97Skupfer# 39984d8c05bSMike Kupfer 400fb9f9b97Skupfer$(MODLIST_DEPS): FRC 401fb9f9b97Skupfer @case $@ in \ 402fb9f9b97Skupfer *32) \ 403fb9f9b97Skupfer class=32; \ 40484d8c05bSMike Kupfer [ -n "$(RELMODULE)" ] && relmodule=`dirname $(RELMODULE)`;; \ 405fb9f9b97Skupfer *64) \ 406fb9f9b97Skupfer class=64; \ 40784d8c05bSMike Kupfer [ -n "$(RELMODULE)" ] && \ 40884d8c05bSMike Kupfer relmodule=`dirname $(RELMODULE)`/$(SUBDIR64);; \ 409fb9f9b97Skupfer esac; \ 410fb9f9b97Skupfer if [ -z "$(THISIMPL)" ]; then \ 411fb9f9b97Skupfer impl=all; \ 412fb9f9b97Skupfer else \ 413fb9f9b97Skupfer impl=$(THISIMPL); \ 414fb9f9b97Skupfer fi; \ 415fb9f9b97Skupfer if [ -n "$(ROOTMODULE)" -a -n "$(INSTALL_TARGET)" ]; then \ 416fb9f9b97Skupfer if [ -z "$(MODULE)" ]; then \ 417fb9f9b97Skupfer module=`basename $(ROOTMODULE)`; \ 418fb9f9b97Skupfer else \ 419fb9f9b97Skupfer module=$(MODULE); \ 420fb9f9b97Skupfer fi; \ 421fb9f9b97Skupfer tinstall="$(INSTALL_TARGET)"; \ 422fb9f9b97Skupfer for t in $$tinstall; do \ 423fb9f9b97Skupfer if [ "$(ROOTMODULE)" = $$t ]; then \ 42484d8c05bSMike Kupfer echo MOD $(MODSRC) $$module $$relmodule \ 42584d8c05bSMike Kupfer $$class $$impl; \ 426fb9f9b97Skupfer break; \ 427fb9f9b97Skupfer fi \ 428fb9f9b97Skupfer done \ 429fb9f9b97Skupfer fi; \ 430fb9f9b97Skupfer if [ -n "$(CONF_SRCDIR)" ]; then \ 431fb9f9b97Skupfer tinstall="$(INSTALL_TARGET)"; \ 432fb9f9b97Skupfer for t in $$tinstall; do \ 433fb9f9b97Skupfer if [ $(ROOT_CONFFILE) = $$t ]; then \ 43484d8c05bSMike Kupfer echo CONF $(MODSRC) $(RELCONF) \ 435fb9f9b97Skupfer $(MODSRC)/$(CONF_SRCDIR) $$impl $$module; \ 436fb9f9b97Skupfer break; \ 437fb9f9b97Skupfer fi \ 438fb9f9b97Skupfer done \ 439fb9f9b97Skupfer fi; \ 440fb9f9b97Skupfer if [ -n "$(ROOTLINK)" ]; then \ 4410f1702c5SYu Xiangning rellinks="$(RELLINK)"; \ 4420f1702c5SYu Xiangning for r in $$rellinks; do \ 44384d8c05bSMike Kupfer if [ $$class = 32 ]; then \ 44484d8c05bSMike Kupfer linkdir=`dirname $$r`; \ 44584d8c05bSMike Kupfer else \ 44684d8c05bSMike Kupfer linkdir=`dirname $$r`/$(SUBDIR64); \ 44784d8c05bSMike Kupfer fi; \ 44884d8c05bSMike Kupfer echo LINK $(MODSRC) $$relmodule $$module \ 44984d8c05bSMike Kupfer $$linkdir `basename $$r` $$impl; \ 4500f1702c5SYu Xiangning done \ 451fb9f9b97Skupfer fi; \ 452fb9f9b97Skupfer if [ -n "$(UNIX32_LINK)" ]; then \ 45384d8c05bSMike Kupfer echo SYMLINK $(MODSRC) $(SUBDIR64)/$(UNIX) \ 454fb9f9b97Skupfer `dirname $(RELUNIX)` unix $$impl $$module; \ 455fb9f9b97Skupfer fi; \ 456fb9f9b97Skupfer trelsoftlinks="$(RELSOFTLINKS)"; \ 457fb9f9b97Skupfer for t in $$trelsoftlinks; do \ 458fb9f9b97Skupfer if [ $$class = 32 ]; then \ 459fb9f9b97Skupfer linkdir=`dirname $$t`; \ 460fb9f9b97Skupfer else \ 461fb9f9b97Skupfer linkdir=`dirname $$t`/$(SUBDIR64); \ 462fb9f9b97Skupfer fi; \ 463fb9f9b97Skupfer linkname=`basename $$t`; \ 46484d8c05bSMike Kupfer echo SYMLINK $(MODSRC) $(MODULE) $$linkdir $$linkname \ 465fb9f9b97Skupfer $$impl $$module; \ 466fb9f9b97Skupfer done 467fb9f9b97Skupfer 4687c478bd9Sstevel@tonic-gate# 4697c478bd9Sstevel@tonic-gate# Cleanliness is next to ... 4707c478bd9Sstevel@tonic-gate# 4717c478bd9Sstevel@tonic-gateclean.targ: 4727c478bd9Sstevel@tonic-gate -$(RM) $(CLEANFILES) Nothing_to_remove 4737c478bd9Sstevel@tonic-gate 4747c478bd9Sstevel@tonic-gateclobber.targ: 4757c478bd9Sstevel@tonic-gate -$(RM) $(CLOBBERFILES) Nothing_to_remove 4767c478bd9Sstevel@tonic-gate 4777c478bd9Sstevel@tonic-gateclean.lint.targ: 4787c478bd9Sstevel@tonic-gate -$(RM) $(CLEANLINTFILES) Nothing_to_remove 4797c478bd9Sstevel@tonic-gate 4807c478bd9Sstevel@tonic-gate# 4817c478bd9Sstevel@tonic-gate# Create fake lintlibs in the 64b dirs so 4827c478bd9Sstevel@tonic-gate# global linting works 4837c478bd9Sstevel@tonic-gate# 4847c478bd9Sstevel@tonic-gatelint64: 4857c478bd9Sstevel@tonic-gate @$(ECHO) $(MODULE) fake lints 4867c478bd9Sstevel@tonic-gate @for dir in $(LINT64_DIRS); do \ 4877c478bd9Sstevel@tonic-gate if [ ! -d $$dir ]; then mkdir $$dir; fi \ 4887c478bd9Sstevel@tonic-gate done 4897c478bd9Sstevel@tonic-gate @for file in $(LINT64_FILES); do \ 4907c478bd9Sstevel@tonic-gate if [ ! -f $$file ]; then touch $$file; fi \ 4917c478bd9Sstevel@tonic-gate done 4927c478bd9Sstevel@tonic-gate 493*bbbed746SGordon Ross# 494*bbbed746SGordon Ross# In some places we also need to create fake lintlibs for 32b 495*bbbed746SGordon Ross# dirs so global linting works 496*bbbed746SGordon Ross# 497*bbbed746SGordon Rosslint32: 498*bbbed746SGordon Ross @$(ECHO) $(MODULE) fake lints 499*bbbed746SGordon Ross @for dir in $(LINT32_DIRS); do \ 500*bbbed746SGordon Ross if [ ! -d $$dir ]; then mkdir $$dir; fi \ 501*bbbed746SGordon Ross done 502*bbbed746SGordon Ross @for file in $(LINT32_FILES); do \ 503*bbbed746SGordon Ross if [ ! -f $$file ]; then touch $$file; fi \ 504*bbbed746SGordon Ross done 505*bbbed746SGordon Ross 5067c478bd9Sstevel@tonic-gateFRC: 507