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 5dc0093f4Seschrock# Common Development and Distribution License (the "License"). 6dc0093f4Seschrock# 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# 2224fe0b3bSjmcp# Copyright 2009 Sun Microsystems, Inc. All rights reserved. 237c478bd9Sstevel@tonic-gate# Use is subject to license terms. 247c478bd9Sstevel@tonic-gate# 25*2a12f85aSJeremy Jones# Copyright (c) 2013 by Delphix. All rights reserved. 26*2a12f85aSJeremy Jones# 277c478bd9Sstevel@tonic-gate 287c478bd9Sstevel@tonic-gate.KEEP_STATE: 297c478bd9Sstevel@tonic-gate.SUFFIXES: 307c478bd9Sstevel@tonic-gate 317c478bd9Sstevel@tonic-gateinclude $(SRC)/cmd/mdb/Makefile.tools 327c478bd9Sstevel@tonic-gate 337c478bd9Sstevel@tonic-gate$(KMOD_SOURCES_DIFFERENT)KMODSRCS = $(MODSRCS) 347c478bd9Sstevel@tonic-gate 357c478bd9Sstevel@tonic-gateMODOBJS = $(MODSRCS:%.c=dmod/%.o) 367c478bd9Sstevel@tonic-gateKMODOBJS = $(KMODSRCS:%.c=kmod/%.o) 377c478bd9Sstevel@tonic-gate 387c478bd9Sstevel@tonic-gateMODNAME = $(MODULE:%.so=%) 397c478bd9Sstevel@tonic-gateKMODULE = $(MODNAME) 407c478bd9Sstevel@tonic-gate 417c478bd9Sstevel@tonic-gateMODFILE = dmod/$(MODULE) 427c478bd9Sstevel@tonic-gateKMODFILE = kmod/$(KMODULE) 437c478bd9Sstevel@tonic-gate 447c478bd9Sstevel@tonic-gate# 457c478bd9Sstevel@tonic-gate# The mess below is designed to pick the right set of objects to build and/or 467c478bd9Sstevel@tonic-gate# lint. We have three flavors: 477c478bd9Sstevel@tonic-gate# 481a7c1b72Smws# 1. proc and raw modules. Only $(MODOBJS) are built. 497c478bd9Sstevel@tonic-gate# 2. kvm modules for systems without kmdb. Only $(MODOBJS) are built. 507c478bd9Sstevel@tonic-gate# 3. kvm modules for systems with kmdb. $(MODOBJS) and $(KMODOBJS) are built. 517c478bd9Sstevel@tonic-gate# 527c478bd9Sstevel@tonic-gate# Complicating matters, we'd like to make the distinction between 2 and 3 before 537c478bd9Sstevel@tonic-gate# this Makefile is loaded. By default, we'll assume that all kvm modules should 547c478bd9Sstevel@tonic-gate# be built for kmdb. If, however, the user sets $(MODULE_BUILD_TYPE) to `mdb', 557c478bd9Sstevel@tonic-gate# the kmdb variant of the module won't be built. 567c478bd9Sstevel@tonic-gate# 577c478bd9Sstevel@tonic-gate 587c478bd9Sstevel@tonic-gate# Which flavors are to be built? 597c478bd9Sstevel@tonic-gateTARGETS_kvm_type_ = both # Build both if $(MODULE_BUILD_TYPE) is unset 607c478bd9Sstevel@tonic-gateTARGETS_kvm_type_kmdb = both 617c478bd9Sstevel@tonic-gateTARGETS_kvm_type_mdb = mdb 627c478bd9Sstevel@tonic-gateTARGETS_kvm_type = $(TARGETS_kvm_type_$(MODULE_BUILD_TYPE)) 637c478bd9Sstevel@tonic-gate 647c478bd9Sstevel@tonic-gate# What should we build? 657c478bd9Sstevel@tonic-gateTARGETS_kvm_kmdb = $(KMODFILE) 667c478bd9Sstevel@tonic-gateTARGETS_kvm_mdb = $(MODFILE) 677c478bd9Sstevel@tonic-gateTARGETS_kvm_both = $(TARGETS_kvm_mdb) $(TARGETS_kvm_kmdb) 687c478bd9Sstevel@tonic-gateTARGETS_kvm = $(TARGETS_kvm_$(TARGETS_kvm_type)) 697c478bd9Sstevel@tonic-gateTARGETS_proc = $(MODFILE) 701a7c1b72SmwsTARGETS_raw = $(MODFILE) 717c478bd9Sstevel@tonic-gateTARGETS = $(TARGETS_$(MDBTGT)) 727c478bd9Sstevel@tonic-gate 737c478bd9Sstevel@tonic-gate# Where should we install that which we've built? 747c478bd9Sstevel@tonic-gateROOTTGTS_kvm_type = $(TARGETS_kvm_type) # overridden by mdb_ks 757c478bd9Sstevel@tonic-gateROOTTGTS_kvm_kmdb = $(ROOTKMOD)/$(KMODULE) 767c478bd9Sstevel@tonic-gateROOTTGTS_kvm_mdb = $(ROOTMOD)/$(MODULE) 777c478bd9Sstevel@tonic-gateROOTTGTS_kvm_both = $(ROOTTGTS_kvm_mdb) $(ROOTTGTS_kvm_kmdb) 787c478bd9Sstevel@tonic-gateROOTTGTS_kvm = $(ROOTTGTS_kvm_$(ROOTTGTS_kvm_type)) 797c478bd9Sstevel@tonic-gateROOTTGTS_proc = $(ROOTMOD)/$(MODULE) 801a7c1b72SmwsROOTTGTS_raw = $(ROOTMOD)/$(MODULE) 817c478bd9Sstevel@tonic-gateROOTTGTS = $(ROOTTGTS_$(MDBTGT)) 827c478bd9Sstevel@tonic-gate 837c478bd9Sstevel@tonic-gate# What should we lint? 847c478bd9Sstevel@tonic-gateKLINTOBJS = $(KMODOBJS:%.o=%.ln) 857c478bd9Sstevel@tonic-gateLINTOBJS = $(MODOBJS:%.o=%.ln) 867c478bd9Sstevel@tonic-gate 877c478bd9Sstevel@tonic-gateLINTFILES_kvm_type = $(TARGETS_kvm_type) 887c478bd9Sstevel@tonic-gateLINTFILES_kvm_both = $(KLINTOBJS) $(LINTOBJS) 897c478bd9Sstevel@tonic-gateLINTFILES_kvm_mdb = $(LINTOBJS) 907c478bd9Sstevel@tonic-gateLINTFILES_kvm = $(LINTFILES_kvm_$(LINTFILES_kvm_type)) 917c478bd9Sstevel@tonic-gateLINTFILES_proc = $(LINTOBJS) 921a7c1b72SmwsLINTFILES_raw = $(LINTOBJS) 937c478bd9Sstevel@tonic-gateLINTFILES = $(LINTFILES_$(MDBTGT)) 947c478bd9Sstevel@tonic-gate 957c478bd9Sstevel@tonic-gatekvm_TGTFLAGS = -D_KERNEL 967c478bd9Sstevel@tonic-gateproc_TGTFLAGS = -D_USER 977c478bd9Sstevel@tonic-gate 98*2a12f85aSJeremy JonesC99MODE = $(C99_ENABLE) 99*2a12f85aSJeremy Jones 1007c478bd9Sstevel@tonic-gateCFLAGS += $(CCVERBOSE) 1017c478bd9Sstevel@tonic-gateCFLAGS64 += $(CCVERBOSE) 1027c478bd9Sstevel@tonic-gateCPPFLAGS += $($(MDBTGT)_TGTFLAGS) -I../../../common 10367e3a03eSrieLDFLAGS += $(ZTEXT) 10467e3a03eSrieLDFLAGS64 += $(ZTEXT) 1057c478bd9Sstevel@tonic-gate 1067c478bd9Sstevel@tonic-gate# Module type-specific compiler flags 1077c478bd9Sstevel@tonic-gate$(MODOBJS) := CFLAGS += $(C_BIGPICFLAGS) $(XREGSFLAG) 1087c478bd9Sstevel@tonic-gate$(MODOBJS) := CFLAGS64 += $(C_BIGPICFLAGS) $(XREGSFLAG) 1097c478bd9Sstevel@tonic-gate$(KMODOBJS) $(KLINTOBJS) := CPPFLAGS += -D_KMDB 1107c478bd9Sstevel@tonic-gate$(KMODOBJS) := V9CODESIZE = $(CCABS32) 1117c478bd9Sstevel@tonic-gate$(KMODOBJS) := DTS_ERRNO = 1127c478bd9Sstevel@tonic-gate 1137c478bd9Sstevel@tonic-gate# Modules aren't allowed to export symbols 1147c478bd9Sstevel@tonic-gateMAPFILE = $(SRC)/cmd/mdb/common/modules/conf/mapfile 1157c478bd9Sstevel@tonic-gate 11667e3a03eSrie# Modules typically make external references. To provide for -zdefs use 11767e3a03eSrie# and clean ldd(1) processing, explicitly define all external references. 11867e3a03eSrieMAPFILE-EXT = $(SRC)/cmd/mdb/common/modules/conf/mapfile-extern 11967e3a03eSrie 1207c478bd9Sstevel@tonic-gate# 1217c478bd9Sstevel@tonic-gate# kmdb is a kernel module, so we'll use the kernel's build flags. 1227c478bd9Sstevel@tonic-gate$(KMODOBJS) := CFLAGS += $(STAND_FLAGS_32) 1237c478bd9Sstevel@tonic-gate$(KMODOBJS) := CFLAGS64 += $(STAND_FLAGS_64) 1247c478bd9Sstevel@tonic-gate 1257c478bd9Sstevel@tonic-gate# 1267c478bd9Sstevel@tonic-gate# Override this to pull source files from another directory 1277c478bd9Sstevel@tonic-gate# 1287c478bd9Sstevel@tonic-gateMODSRCS_DIR = ../../../common/modules/genunix 1297c478bd9Sstevel@tonic-gate 1307c478bd9Sstevel@tonic-gateall: $$(TARGETS) 1317c478bd9Sstevel@tonic-gate 1327c478bd9Sstevel@tonic-gateinstall: all $$(ROOTTGTS) 1337c478bd9Sstevel@tonic-gate 1347c478bd9Sstevel@tonic-gatedmods: install 1357c478bd9Sstevel@tonic-gate 1367c478bd9Sstevel@tonic-gateclean.lint: 1377c478bd9Sstevel@tonic-gate $(RM) $(LINTFILES) 1387c478bd9Sstevel@tonic-gate 1397c478bd9Sstevel@tonic-gateclean: 1401a7c1b72Smws $(RM) $(MODOBJS) $(KMODOBJS) $(CLEANFILES) 1417c478bd9Sstevel@tonic-gate 1427c478bd9Sstevel@tonic-gateclobber: clean clean.lint 1431a7c1b72Smws $(RM) $(MODFILE) $(KMODFILE) $(CLOBBERFILES) 1447c478bd9Sstevel@tonic-gate 1457c478bd9Sstevel@tonic-gatelint: $$(LINTFILES) 1467c478bd9Sstevel@tonic-gate 1477c478bd9Sstevel@tonic-gate.NO_PARALLEL: 1487c478bd9Sstevel@tonic-gate.PARALLEL: $(MODOBJS) $(KMODOBJS) mdb_tgt kmdb_tgt dmod kmod \ 1497c478bd9Sstevel@tonic-gate $(TARGETS) $(LINTFILES) 1507c478bd9Sstevel@tonic-gate 15167e3a03eSrie$(MODFILE): dmod .WAIT $(MODOBJS) $$(MAPFILE-EXT) 15267e3a03eSrie $(LINK.c) $(ZDEFS) $(ZIGNORE) $(MAPFILE-EXT:%=-M%) $(GSHARED) \ 15367e3a03eSrie $(MODOBJS) -o $@ $(LDLIBS) -lc 1547c478bd9Sstevel@tonic-gate $(CTFMERGE) -L VERSION -o $@ $(MODOBJS) 1557c478bd9Sstevel@tonic-gate $(POST_PROCESS_SO) 1567c478bd9Sstevel@tonic-gate 1577c478bd9Sstevel@tonic-gate# 1587c478bd9Sstevel@tonic-gate# kmdb dmods must *not* stray from the module API. To ensure that they don't, 1597c478bd9Sstevel@tonic-gate# we try to link them, at build time, against an object that exports the symbols 1607c478bd9Sstevel@tonic-gate# that they can legally use. The link test object is, however, only built when 1617c478bd9Sstevel@tonic-gate# kmdb itself is built. Requiring module developers to build kmdb first would 1627c478bd9Sstevel@tonic-gate# be painful, so by default, module-level builds don't do the link test (the 1637c478bd9Sstevel@tonic-gate# $(POUND_SIGN) assignment below takes care of that). Builds of the entire 1647c478bd9Sstevel@tonic-gate# tree can, however, guarantee the construction of kmdb first, and as such can 1657c478bd9Sstevel@tonic-gate# override the setting of $(KMDB_LINKTEST_ENABLE). This override causes the 1667c478bd9Sstevel@tonic-gate# link test to be run. 1677c478bd9Sstevel@tonic-gate# 1687c478bd9Sstevel@tonic-gate# Developers wanting to force a link test for a single module can use the 1697c478bd9Sstevel@tonic-gate# `linktest' target from within a module directory. 1707c478bd9Sstevel@tonic-gate# 1717c478bd9Sstevel@tonic-gateLINKTESTOBJ = $(KMDBDIR)/kmdb_modlinktest.o 1727c478bd9Sstevel@tonic-gate 1737c478bd9Sstevel@tonic-gateKMDB_LINKTEST = \ 174dc0093f4Seschrock $(LD) $(ZDEFS) -dy -r -o $@.linktest $(KMODOBJS) \ 175dc0093f4Seschrock $(STANDOBJS) $(LINKTESTOBJ) && \ 1767c478bd9Sstevel@tonic-gate $(RM) $@.linktest 1777c478bd9Sstevel@tonic-gate 1787c478bd9Sstevel@tonic-gateKMDB_LINKTEST_ENABLE=$(POUND_SIGN) 1797c478bd9Sstevel@tonic-gate$(KMDB_LINKTEST_ENABLE)KMDB_LINKTEST_CMD = $(KMDB_LINKTEST) 1807c478bd9Sstevel@tonic-gate 1817c478bd9Sstevel@tonic-gate# 1827c478bd9Sstevel@tonic-gate# Ensure that dmods don't use floating point 1837c478bd9Sstevel@tonic-gate# 1847c478bd9Sstevel@tonic-gateKMDB_FPTEST_CMD = $(KMDB_FPTEST) 1857c478bd9Sstevel@tonic-gate 1867c478bd9Sstevel@tonic-gate$(KMODFILE): kmod .WAIT $(KMODOBJS) $(MAPFILE) 187dc0093f4Seschrock $(LD) -dy -r $(MAPFILE:%=-M%) -Nmisc/kmdbmod -o $@ $(KMODOBJS) \ 188dc0093f4Seschrock $(STANDOBJS) 1897c478bd9Sstevel@tonic-gate $(KMDB_LINKTEST_CMD) 1907c478bd9Sstevel@tonic-gate $(KMDB_FPTEST_CMD) 1915ae68c69Sjohnlev $(CTFMERGE) -f -L VERSION -o $@ $(KMODOBJS) 1927c478bd9Sstevel@tonic-gate $(SETDYNFLAG) -f DF_1_NOKSYMS $@ 1937c478bd9Sstevel@tonic-gate 1947c478bd9Sstevel@tonic-gatelinktest: linktest_check .WAIT kmod .WAIT $(KMODOBJS) 1957c478bd9Sstevel@tonic-gate $(KMDB_LINKTEST) 1967c478bd9Sstevel@tonic-gate 1977c478bd9Sstevel@tonic-gatelinktest_check: 198dc0093f4Seschrock @if [ "$(MDBTGT)" != "kvm" ] ; then \ 1997c478bd9Sstevel@tonic-gate echo "ERROR: linktest is not supported non-kvm/disasm dmods" \ 2007c478bd9Sstevel@tonic-gate >&2 ; \ 2017c478bd9Sstevel@tonic-gate exit 1 ; \ 2027c478bd9Sstevel@tonic-gate fi 2037c478bd9Sstevel@tonic-gate 2047c478bd9Sstevel@tonic-gate# 2057c478bd9Sstevel@tonic-gate# Dynamic rules for object construction 2067c478bd9Sstevel@tonic-gate# 2077c478bd9Sstevel@tonic-gatedmod/%.o kmod/%.o: %.c 2087c478bd9Sstevel@tonic-gate $(COMPILE.c) -o $@ $< 2097c478bd9Sstevel@tonic-gate $(CTFCONVERT_O) 2107c478bd9Sstevel@tonic-gate 2117c478bd9Sstevel@tonic-gatedmod/%.o kmod/%.o: ../%.c 2127c478bd9Sstevel@tonic-gate $(COMPILE.c) -o $@ $< 2137c478bd9Sstevel@tonic-gate $(CTFCONVERT_O) 2147c478bd9Sstevel@tonic-gate 2157c478bd9Sstevel@tonic-gatedmod/%.o kmod/%.o: ../../../common/modules/$(MODNAME)/%.c 2167c478bd9Sstevel@tonic-gate $(COMPILE.c) -o $@ $< 2177c478bd9Sstevel@tonic-gate $(CTFCONVERT_O) 2187c478bd9Sstevel@tonic-gate 2197c478bd9Sstevel@tonic-gatedmod/%.o kmod/%.o: $$(MODSRCS_DIR)/%.c 2207c478bd9Sstevel@tonic-gate $(COMPILE.c) -o $@ $< 2217c478bd9Sstevel@tonic-gate $(CTFCONVERT_O) 2227c478bd9Sstevel@tonic-gate 2237c478bd9Sstevel@tonic-gate# 2247c478bd9Sstevel@tonic-gate# Lint 2257c478bd9Sstevel@tonic-gate# 2267c478bd9Sstevel@tonic-gatedmod/%.ln kmod/%.ln: %.c 2277c478bd9Sstevel@tonic-gate $(LINT.c) -dirout=$(@D) -c $< 2287c478bd9Sstevel@tonic-gate 2297c478bd9Sstevel@tonic-gatedmod/%.ln kmod/%.ln: ../%.c 2307c478bd9Sstevel@tonic-gate $(LINT.c) -dirout=$(@D) -c $< 2317c478bd9Sstevel@tonic-gate 2327c478bd9Sstevel@tonic-gatedmod/%.ln kmod/%.ln: ../../../common/modules/$(MODNAME)/%.c 2337c478bd9Sstevel@tonic-gate $(LINT.c) -dirout=$(@D) -c $< 2347c478bd9Sstevel@tonic-gate 2357c478bd9Sstevel@tonic-gatedmod/%.ln kmod/%.ln: $$(MODSRCS_DIR)/%.c 2367c478bd9Sstevel@tonic-gate $(LINT.c) -dirout=$(@D) -c $< 2377c478bd9Sstevel@tonic-gate 2387c478bd9Sstevel@tonic-gate# 2397c478bd9Sstevel@tonic-gate# Installation targets 2407c478bd9Sstevel@tonic-gate# 2417c478bd9Sstevel@tonic-gate 2427c478bd9Sstevel@tonic-gate$(ROOT)/usr/lib/mdb/$(MDBTGT): $(ROOT)/usr/lib/mdb 2437c478bd9Sstevel@tonic-gate $(INS.dir) 2447c478bd9Sstevel@tonic-gate 2457c478bd9Sstevel@tonic-gate$(ROOT)/usr/lib/mdb: 2467c478bd9Sstevel@tonic-gate $(INS.dir) 2477c478bd9Sstevel@tonic-gate 2487c478bd9Sstevel@tonic-gate$(ROOT)/kernel/kmdb: 2497c478bd9Sstevel@tonic-gate $(INS.dir) 2507c478bd9Sstevel@tonic-gate 2517c478bd9Sstevel@tonic-gate$(ROOTMOD)/$(MODULE): $(ROOTMOD) 2527c478bd9Sstevel@tonic-gate 2537c478bd9Sstevel@tonic-gate$(ROOTKMOD)/$(KMODULE): $(ROOTKMOD) 2547c478bd9Sstevel@tonic-gate 2557c478bd9Sstevel@tonic-gatekmod dmod: 2567c478bd9Sstevel@tonic-gate -@mkdir -p $@ 257