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# 252a12f85aSJeremy Jones# Copyright (c) 2013 by Delphix. All rights reserved. 26*799823bbSRobert Mustacchi# Copyright 2015, Joyent, Inc. 272a12f85aSJeremy Jones# 287c478bd9Sstevel@tonic-gate 297c478bd9Sstevel@tonic-gate.KEEP_STATE: 307c478bd9Sstevel@tonic-gate.SUFFIXES: 317c478bd9Sstevel@tonic-gate 327c478bd9Sstevel@tonic-gateinclude $(SRC)/cmd/mdb/Makefile.tools 337c478bd9Sstevel@tonic-gate 347c478bd9Sstevel@tonic-gate$(KMOD_SOURCES_DIFFERENT)KMODSRCS = $(MODSRCS) 35*799823bbSRobert Mustacchi$(KMOD_SOURCES_DIFFERENT)KMODASMSRCS = $(MODASMSRCS) 367c478bd9Sstevel@tonic-gate 37*799823bbSRobert MustacchiMODOBJS = $(MODSRCS:%.c=dmod/%.o) $(MODASMSRCS:%.s=dmod/%.o) 38*799823bbSRobert MustacchiKMODOBJS = $(KMODSRCS:%.c=kmod/%.o) $(KMODASMSRCS:%.s=kmod/%.o) 397c478bd9Sstevel@tonic-gate 407c478bd9Sstevel@tonic-gateMODNAME = $(MODULE:%.so=%) 417c478bd9Sstevel@tonic-gateKMODULE = $(MODNAME) 427c478bd9Sstevel@tonic-gate 437c478bd9Sstevel@tonic-gateMODFILE = dmod/$(MODULE) 447c478bd9Sstevel@tonic-gateKMODFILE = kmod/$(KMODULE) 457c478bd9Sstevel@tonic-gate 467c478bd9Sstevel@tonic-gate# 477c478bd9Sstevel@tonic-gate# The mess below is designed to pick the right set of objects to build and/or 487c478bd9Sstevel@tonic-gate# lint. We have three flavors: 497c478bd9Sstevel@tonic-gate# 501a7c1b72Smws# 1. proc and raw modules. Only $(MODOBJS) are built. 517c478bd9Sstevel@tonic-gate# 2. kvm modules for systems without kmdb. Only $(MODOBJS) are built. 527c478bd9Sstevel@tonic-gate# 3. kvm modules for systems with kmdb. $(MODOBJS) and $(KMODOBJS) are built. 537c478bd9Sstevel@tonic-gate# 547c478bd9Sstevel@tonic-gate# Complicating matters, we'd like to make the distinction between 2 and 3 before 557c478bd9Sstevel@tonic-gate# this Makefile is loaded. By default, we'll assume that all kvm modules should 567c478bd9Sstevel@tonic-gate# be built for kmdb. If, however, the user sets $(MODULE_BUILD_TYPE) to `mdb', 577c478bd9Sstevel@tonic-gate# the kmdb variant of the module won't be built. 587c478bd9Sstevel@tonic-gate# 597c478bd9Sstevel@tonic-gate 607c478bd9Sstevel@tonic-gate# Which flavors are to be built? 617c478bd9Sstevel@tonic-gateTARGETS_kvm_type_ = both # Build both if $(MODULE_BUILD_TYPE) is unset 627c478bd9Sstevel@tonic-gateTARGETS_kvm_type_kmdb = both 637c478bd9Sstevel@tonic-gateTARGETS_kvm_type_mdb = mdb 647c478bd9Sstevel@tonic-gateTARGETS_kvm_type = $(TARGETS_kvm_type_$(MODULE_BUILD_TYPE)) 657c478bd9Sstevel@tonic-gate 667c478bd9Sstevel@tonic-gate# What should we build? 677c478bd9Sstevel@tonic-gateTARGETS_kvm_kmdb = $(KMODFILE) 687c478bd9Sstevel@tonic-gateTARGETS_kvm_mdb = $(MODFILE) 697c478bd9Sstevel@tonic-gateTARGETS_kvm_both = $(TARGETS_kvm_mdb) $(TARGETS_kvm_kmdb) 707c478bd9Sstevel@tonic-gateTARGETS_kvm = $(TARGETS_kvm_$(TARGETS_kvm_type)) 717c478bd9Sstevel@tonic-gateTARGETS_proc = $(MODFILE) 721a7c1b72SmwsTARGETS_raw = $(MODFILE) 737c478bd9Sstevel@tonic-gateTARGETS = $(TARGETS_$(MDBTGT)) 747c478bd9Sstevel@tonic-gate 757c478bd9Sstevel@tonic-gate# Where should we install that which we've built? 767c478bd9Sstevel@tonic-gateROOTTGTS_kvm_type = $(TARGETS_kvm_type) # overridden by mdb_ks 777c478bd9Sstevel@tonic-gateROOTTGTS_kvm_kmdb = $(ROOTKMOD)/$(KMODULE) 787c478bd9Sstevel@tonic-gateROOTTGTS_kvm_mdb = $(ROOTMOD)/$(MODULE) 797c478bd9Sstevel@tonic-gateROOTTGTS_kvm_both = $(ROOTTGTS_kvm_mdb) $(ROOTTGTS_kvm_kmdb) 807c478bd9Sstevel@tonic-gateROOTTGTS_kvm = $(ROOTTGTS_kvm_$(ROOTTGTS_kvm_type)) 817c478bd9Sstevel@tonic-gateROOTTGTS_proc = $(ROOTMOD)/$(MODULE) 821a7c1b72SmwsROOTTGTS_raw = $(ROOTMOD)/$(MODULE) 837c478bd9Sstevel@tonic-gateROOTTGTS = $(ROOTTGTS_$(MDBTGT)) 847c478bd9Sstevel@tonic-gate 857c478bd9Sstevel@tonic-gate# What should we lint? 867c478bd9Sstevel@tonic-gateKLINTOBJS = $(KMODOBJS:%.o=%.ln) 877c478bd9Sstevel@tonic-gateLINTOBJS = $(MODOBJS:%.o=%.ln) 887c478bd9Sstevel@tonic-gate 897c478bd9Sstevel@tonic-gateLINTFILES_kvm_type = $(TARGETS_kvm_type) 907c478bd9Sstevel@tonic-gateLINTFILES_kvm_both = $(KLINTOBJS) $(LINTOBJS) 917c478bd9Sstevel@tonic-gateLINTFILES_kvm_mdb = $(LINTOBJS) 927c478bd9Sstevel@tonic-gateLINTFILES_kvm = $(LINTFILES_kvm_$(LINTFILES_kvm_type)) 937c478bd9Sstevel@tonic-gateLINTFILES_proc = $(LINTOBJS) 941a7c1b72SmwsLINTFILES_raw = $(LINTOBJS) 957c478bd9Sstevel@tonic-gateLINTFILES = $(LINTFILES_$(MDBTGT)) 967c478bd9Sstevel@tonic-gate 977c478bd9Sstevel@tonic-gatekvm_TGTFLAGS = -D_KERNEL 987c478bd9Sstevel@tonic-gateproc_TGTFLAGS = -D_USER 997c478bd9Sstevel@tonic-gate 1002a12f85aSJeremy JonesC99MODE = $(C99_ENABLE) 1012a12f85aSJeremy Jones 1027c478bd9Sstevel@tonic-gateCFLAGS += $(CCVERBOSE) 1037c478bd9Sstevel@tonic-gateCFLAGS64 += $(CCVERBOSE) 1047c478bd9Sstevel@tonic-gateCPPFLAGS += $($(MDBTGT)_TGTFLAGS) -I../../../common 10567e3a03eSrieLDFLAGS += $(ZTEXT) 10667e3a03eSrieLDFLAGS64 += $(ZTEXT) 107*799823bbSRobert MustacchiASFLAGS += -P 108*799823bbSRobert MustacchiAS_CPPFLAGS += -D_ASM 1097c478bd9Sstevel@tonic-gate 1107c478bd9Sstevel@tonic-gate# Module type-specific compiler flags 1117c478bd9Sstevel@tonic-gate$(MODOBJS) := CFLAGS += $(C_BIGPICFLAGS) $(XREGSFLAG) 1127c478bd9Sstevel@tonic-gate$(MODOBJS) := CFLAGS64 += $(C_BIGPICFLAGS) $(XREGSFLAG) 1137c478bd9Sstevel@tonic-gate$(KMODOBJS) $(KLINTOBJS) := CPPFLAGS += -D_KMDB 1147c478bd9Sstevel@tonic-gate$(KMODOBJS) := V9CODESIZE = $(CCABS32) 1157c478bd9Sstevel@tonic-gate$(KMODOBJS) := DTS_ERRNO = 1167c478bd9Sstevel@tonic-gate 1177c478bd9Sstevel@tonic-gate# Modules aren't allowed to export symbols 1187c478bd9Sstevel@tonic-gateMAPFILE = $(SRC)/cmd/mdb/common/modules/conf/mapfile 1197c478bd9Sstevel@tonic-gate 12067e3a03eSrie# Modules typically make external references. To provide for -zdefs use 12167e3a03eSrie# and clean ldd(1) processing, explicitly define all external references. 12267e3a03eSrieMAPFILE-EXT = $(SRC)/cmd/mdb/common/modules/conf/mapfile-extern 12367e3a03eSrie 1247c478bd9Sstevel@tonic-gate# 1257c478bd9Sstevel@tonic-gate# kmdb is a kernel module, so we'll use the kernel's build flags. 1267c478bd9Sstevel@tonic-gate$(KMODOBJS) := CFLAGS += $(STAND_FLAGS_32) 1277c478bd9Sstevel@tonic-gate$(KMODOBJS) := CFLAGS64 += $(STAND_FLAGS_64) 1287c478bd9Sstevel@tonic-gate 1297c478bd9Sstevel@tonic-gate# 1307c478bd9Sstevel@tonic-gate# Override this to pull source files from another directory 1317c478bd9Sstevel@tonic-gate# 1327c478bd9Sstevel@tonic-gateMODSRCS_DIR = ../../../common/modules/genunix 1337c478bd9Sstevel@tonic-gate 1347c478bd9Sstevel@tonic-gateall: $$(TARGETS) 1357c478bd9Sstevel@tonic-gate 1367c478bd9Sstevel@tonic-gateinstall: all $$(ROOTTGTS) 1377c478bd9Sstevel@tonic-gate 1387c478bd9Sstevel@tonic-gatedmods: install 1397c478bd9Sstevel@tonic-gate 1407c478bd9Sstevel@tonic-gateclean.lint: 141b6805bf7SGordon Ross $(RM) $(LINTFILES) $(MODSRCS:.c=.ln) 1427c478bd9Sstevel@tonic-gate 1437c478bd9Sstevel@tonic-gateclean: 1441a7c1b72Smws $(RM) $(MODOBJS) $(KMODOBJS) $(CLEANFILES) 1457c478bd9Sstevel@tonic-gate 1467c478bd9Sstevel@tonic-gateclobber: clean clean.lint 1471a7c1b72Smws $(RM) $(MODFILE) $(KMODFILE) $(CLOBBERFILES) 1487c478bd9Sstevel@tonic-gate 1497c478bd9Sstevel@tonic-gatelint: $$(LINTFILES) 1507c478bd9Sstevel@tonic-gate 1517c478bd9Sstevel@tonic-gate.NO_PARALLEL: 1527c478bd9Sstevel@tonic-gate.PARALLEL: $(MODOBJS) $(KMODOBJS) mdb_tgt kmdb_tgt dmod kmod \ 1537c478bd9Sstevel@tonic-gate $(TARGETS) $(LINTFILES) 1547c478bd9Sstevel@tonic-gate 15567e3a03eSrie$(MODFILE): dmod .WAIT $(MODOBJS) $$(MAPFILE-EXT) 15667e3a03eSrie $(LINK.c) $(ZDEFS) $(ZIGNORE) $(MAPFILE-EXT:%=-M%) $(GSHARED) \ 15767e3a03eSrie $(MODOBJS) -o $@ $(LDLIBS) -lc 1587c478bd9Sstevel@tonic-gate $(CTFMERGE) -L VERSION -o $@ $(MODOBJS) 1597c478bd9Sstevel@tonic-gate $(POST_PROCESS_SO) 1607c478bd9Sstevel@tonic-gate 1617c478bd9Sstevel@tonic-gate# 1627c478bd9Sstevel@tonic-gate# kmdb dmods must *not* stray from the module API. To ensure that they don't, 1637c478bd9Sstevel@tonic-gate# we try to link them, at build time, against an object that exports the symbols 1647c478bd9Sstevel@tonic-gate# that they can legally use. The link test object is, however, only built when 1657c478bd9Sstevel@tonic-gate# kmdb itself is built. Requiring module developers to build kmdb first would 1667c478bd9Sstevel@tonic-gate# be painful, so by default, module-level builds don't do the link test (the 1677c478bd9Sstevel@tonic-gate# $(POUND_SIGN) assignment below takes care of that). Builds of the entire 1687c478bd9Sstevel@tonic-gate# tree can, however, guarantee the construction of kmdb first, and as such can 1697c478bd9Sstevel@tonic-gate# override the setting of $(KMDB_LINKTEST_ENABLE). This override causes the 1707c478bd9Sstevel@tonic-gate# link test to be run. 1717c478bd9Sstevel@tonic-gate# 1727c478bd9Sstevel@tonic-gate# Developers wanting to force a link test for a single module can use the 1737c478bd9Sstevel@tonic-gate# `linktest' target from within a module directory. 1747c478bd9Sstevel@tonic-gate# 1757c478bd9Sstevel@tonic-gateLINKTESTOBJ = $(KMDBDIR)/kmdb_modlinktest.o 1767c478bd9Sstevel@tonic-gate 1777c478bd9Sstevel@tonic-gateKMDB_LINKTEST = \ 178dc0093f4Seschrock $(LD) $(ZDEFS) -dy -r -o $@.linktest $(KMODOBJS) \ 179dc0093f4Seschrock $(STANDOBJS) $(LINKTESTOBJ) && \ 1807c478bd9Sstevel@tonic-gate $(RM) $@.linktest 1817c478bd9Sstevel@tonic-gate 1827c478bd9Sstevel@tonic-gateKMDB_LINKTEST_ENABLE=$(POUND_SIGN) 1837c478bd9Sstevel@tonic-gate$(KMDB_LINKTEST_ENABLE)KMDB_LINKTEST_CMD = $(KMDB_LINKTEST) 1847c478bd9Sstevel@tonic-gate 1857c478bd9Sstevel@tonic-gate# 1867c478bd9Sstevel@tonic-gate# Ensure that dmods don't use floating point 1877c478bd9Sstevel@tonic-gate# 1887c478bd9Sstevel@tonic-gateKMDB_FPTEST_CMD = $(KMDB_FPTEST) 1897c478bd9Sstevel@tonic-gate 1907c478bd9Sstevel@tonic-gate$(KMODFILE): kmod .WAIT $(KMODOBJS) $(MAPFILE) 191dc0093f4Seschrock $(LD) -dy -r $(MAPFILE:%=-M%) -Nmisc/kmdbmod -o $@ $(KMODOBJS) \ 192dc0093f4Seschrock $(STANDOBJS) 1937c478bd9Sstevel@tonic-gate $(KMDB_LINKTEST_CMD) 1947c478bd9Sstevel@tonic-gate $(KMDB_FPTEST_CMD) 1955ae68c69Sjohnlev $(CTFMERGE) -f -L VERSION -o $@ $(KMODOBJS) 1966ddb3373SRichard Lowe $(POST_PROCESS) 1977c478bd9Sstevel@tonic-gate $(SETDYNFLAG) -f DF_1_NOKSYMS $@ 1987c478bd9Sstevel@tonic-gate 1997c478bd9Sstevel@tonic-gatelinktest: linktest_check .WAIT kmod .WAIT $(KMODOBJS) 2007c478bd9Sstevel@tonic-gate $(KMDB_LINKTEST) 2017c478bd9Sstevel@tonic-gate 2027c478bd9Sstevel@tonic-gatelinktest_check: 203dc0093f4Seschrock @if [ "$(MDBTGT)" != "kvm" ] ; then \ 2047c478bd9Sstevel@tonic-gate echo "ERROR: linktest is not supported non-kvm/disasm dmods" \ 2057c478bd9Sstevel@tonic-gate >&2 ; \ 2067c478bd9Sstevel@tonic-gate exit 1 ; \ 2077c478bd9Sstevel@tonic-gate fi 2087c478bd9Sstevel@tonic-gate 2097c478bd9Sstevel@tonic-gate# 2107c478bd9Sstevel@tonic-gate# Dynamic rules for object construction 2117c478bd9Sstevel@tonic-gate# 2127c478bd9Sstevel@tonic-gatedmod/%.o kmod/%.o: %.c 2137c478bd9Sstevel@tonic-gate $(COMPILE.c) -o $@ $< 2147c478bd9Sstevel@tonic-gate $(CTFCONVERT_O) 2157c478bd9Sstevel@tonic-gate 216*799823bbSRobert Mustacchidmod/%.o kmod%.o: %.s 217*799823bbSRobert Mustacchi $(COMPILE.s) -o $@ $< 218*799823bbSRobert Mustacchi $(CTFCONVERT_O) 219*799823bbSRobert Mustacchi 2207c478bd9Sstevel@tonic-gatedmod/%.o kmod/%.o: ../%.c 2217c478bd9Sstevel@tonic-gate $(COMPILE.c) -o $@ $< 2227c478bd9Sstevel@tonic-gate $(CTFCONVERT_O) 2237c478bd9Sstevel@tonic-gate 224*799823bbSRobert Mustacchidmod/%.o kmod%.o: ../%.s 225*799823bbSRobert Mustacchi $(COMPILE.s) -o $@ $< 226*799823bbSRobert Mustacchi $(CTFCONVERT_O) 227*799823bbSRobert Mustacchi 2287c478bd9Sstevel@tonic-gatedmod/%.o kmod/%.o: ../../../common/modules/$(MODNAME)/%.c 2297c478bd9Sstevel@tonic-gate $(COMPILE.c) -o $@ $< 2307c478bd9Sstevel@tonic-gate $(CTFCONVERT_O) 2317c478bd9Sstevel@tonic-gate 232*799823bbSRobert Mustacchidmod/%.o kmod%.o: ../../../common/modules/$(MODNAME)/%.s 233*799823bbSRobert Mustacchi $(COMPILE.s) -o $@ $< 234*799823bbSRobert Mustacchi $(CTFCONVERT_O) 235*799823bbSRobert Mustacchi 2367c478bd9Sstevel@tonic-gatedmod/%.o kmod/%.o: $$(MODSRCS_DIR)/%.c 2377c478bd9Sstevel@tonic-gate $(COMPILE.c) -o $@ $< 2387c478bd9Sstevel@tonic-gate $(CTFCONVERT_O) 2397c478bd9Sstevel@tonic-gate 240*799823bbSRobert Mustacchidmod/%.o kmod%.o: $$(MODSRCS_DIR)/%.s 241*799823bbSRobert Mustacchi $(COMPILE.s) -o $@ $< 242*799823bbSRobert Mustacchi $(CTFCONVERT_O) 243*799823bbSRobert Mustacchi 2447c478bd9Sstevel@tonic-gate# 2457c478bd9Sstevel@tonic-gate# Lint 2467c478bd9Sstevel@tonic-gate# 2477c478bd9Sstevel@tonic-gatedmod/%.ln kmod/%.ln: %.c 2487c478bd9Sstevel@tonic-gate $(LINT.c) -dirout=$(@D) -c $< 2497c478bd9Sstevel@tonic-gate 250*799823bbSRobert Mustacchidmod/%.ln kmod/%.ln: %.s 251*799823bbSRobert Mustacchi $(LINT.s) -dirout=$(@D) -c $< 252*799823bbSRobert Mustacchi 2537c478bd9Sstevel@tonic-gatedmod/%.ln kmod/%.ln: ../%.c 2547c478bd9Sstevel@tonic-gate $(LINT.c) -dirout=$(@D) -c $< 2557c478bd9Sstevel@tonic-gate 256*799823bbSRobert Mustacchidmod/%.ln kmod/%.ln: ../%.s 257*799823bbSRobert Mustacchi $(LINT.s) -dirout=$(@D) -c $< 258*799823bbSRobert Mustacchi 2597c478bd9Sstevel@tonic-gatedmod/%.ln kmod/%.ln: ../../../common/modules/$(MODNAME)/%.c 2607c478bd9Sstevel@tonic-gate $(LINT.c) -dirout=$(@D) -c $< 2617c478bd9Sstevel@tonic-gate 262*799823bbSRobert Mustacchidmod/%.ln kmod/%.ln: ../../../common/modules/$(MODNAME)/%.s 263*799823bbSRobert Mustacchi $(LINT.s) -dirout=$(@D) -c $< 264*799823bbSRobert Mustacchi 2657c478bd9Sstevel@tonic-gatedmod/%.ln kmod/%.ln: $$(MODSRCS_DIR)/%.c 2667c478bd9Sstevel@tonic-gate $(LINT.c) -dirout=$(@D) -c $< 2677c478bd9Sstevel@tonic-gate 268*799823bbSRobert Mustacchidmod/%.ln kmod/%.ln: $$(MODSRCS_DIR)/%.s 269*799823bbSRobert Mustacchi $(LINT.s) -dirout=$(@D) -c $< 270*799823bbSRobert Mustacchi 2717c478bd9Sstevel@tonic-gate# 2727c478bd9Sstevel@tonic-gate# Installation targets 2737c478bd9Sstevel@tonic-gate# 2747c478bd9Sstevel@tonic-gate 2757c478bd9Sstevel@tonic-gate$(ROOT)/usr/lib/mdb/$(MDBTGT): $(ROOT)/usr/lib/mdb 2767c478bd9Sstevel@tonic-gate $(INS.dir) 2777c478bd9Sstevel@tonic-gate 2787c478bd9Sstevel@tonic-gate$(ROOT)/usr/lib/mdb: 2797c478bd9Sstevel@tonic-gate $(INS.dir) 2807c478bd9Sstevel@tonic-gate 2817c478bd9Sstevel@tonic-gate$(ROOT)/kernel/kmdb: 2827c478bd9Sstevel@tonic-gate $(INS.dir) 2837c478bd9Sstevel@tonic-gate 2847c478bd9Sstevel@tonic-gate$(ROOTMOD)/$(MODULE): $(ROOTMOD) 2857c478bd9Sstevel@tonic-gate 2867c478bd9Sstevel@tonic-gate$(ROOTKMOD)/$(KMODULE): $(ROOTKMOD) 2877c478bd9Sstevel@tonic-gate 2887c478bd9Sstevel@tonic-gatekmod dmod: 2897c478bd9Sstevel@tonic-gate -@mkdir -p $@ 290