1# 2# CDDL HEADER START 3# 4# The contents of this file are subject to the terms of the 5# Common Development and Distribution License (the "License"). 6# You may not use this file except in compliance with the License. 7# 8# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9# or http://www.opensolaris.org/os/licensing. 10# See the License for the specific language governing permissions 11# and limitations under the License. 12# 13# When distributing Covered Code, include this CDDL HEADER in each 14# file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15# If applicable, add the following below this CDDL HEADER, with the 16# fields enclosed by brackets "[]" replaced with your own identifying 17# information: Portions Copyright [yyyy] [name of copyright owner] 18# 19# CDDL HEADER END 20# 21# 22# Copyright 2009 Sun Microsystems, Inc. All rights reserved. 23# Use is subject to license terms. 24# 25# Copyright (c) 2013 by Delphix. All rights reserved. 26# Copyright 2015, Joyent, Inc. 27# 28 29.KEEP_STATE: 30.SUFFIXES: 31 32include $(SRC)/cmd/mdb/Makefile.tools 33 34# 35# Make sure we're getting a consistent execution environment for the 36# embedded scripts. 37# 38SHELL= /usr/bin/ksh93 39 40$(KMOD_SOURCES_DIFFERENT)KMODSRCS = $(MODSRCS) 41$(KMOD_SOURCES_DIFFERENT)KMODASMSRCS = $(MODASMSRCS) 42 43MODOBJS = $(MODSRCS:%.c=dmod/%.o) $(MODASMSRCS:%.s=dmod/%.o) 44KMODOBJS = $(KMODSRCS:%.c=kmod/%.o) $(KMODASMSRCS:%.s=kmod/%.o) 45 46MODNAME_cmd = if [ -n "$(MODULE_NAME)" ]; then print $(MODULE_NAME); else print $(MODULE)| sed -e 's:\.so$$::'; fi 47MODNAME = $(MODNAME_cmd:sh) 48KMODULE = $(MODNAME) 49 50MODFILE = dmod/$(MODULE) 51KMODFILE = kmod/$(KMODULE) 52 53# 54# The mess below is designed to pick the right set of objects to build and/or 55# lint. We have three flavors: 56# 57# 1. proc and raw modules. Only $(MODOBJS) are built. 58# 2. kvm modules for systems without kmdb. Only $(MODOBJS) are built. 59# 3. kvm modules for systems with kmdb. $(MODOBJS) and $(KMODOBJS) are built. 60# 61# Complicating matters, we'd like to make the distinction between 2 and 3 before 62# this Makefile is loaded. By default, we'll assume that all kvm modules should 63# be built for kmdb. If, however, the user sets $(MODULE_BUILD_TYPE) to `mdb', 64# the kmdb variant of the module won't be built. 65# 66 67# Which flavors are to be built? 68TARGETS_kvm_type_ = both # Build both if $(MODULE_BUILD_TYPE) is unset 69TARGETS_kvm_type_kmdb = both 70TARGETS_kvm_type_mdb = mdb 71TARGETS_kvm_type = $(TARGETS_kvm_type_$(MODULE_BUILD_TYPE)) 72 73# What should we build? 74TARGETS_kvm_kmdb = $(KMODFILE) 75TARGETS_kvm_mdb = $(MODFILE) 76TARGETS_kvm_both = $(TARGETS_kvm_mdb) $(TARGETS_kvm_kmdb) 77TARGETS_kvm = $(TARGETS_kvm_$(TARGETS_kvm_type)) 78TARGETS_proc = $(MODFILE) 79TARGETS_raw = $(MODFILE) 80TARGETS = $(TARGETS_$(MDBTGT)) 81 82# Where should we install that which we've built? 83ROOTTGTS_kvm_type = $(TARGETS_kvm_type) # overridden by mdb_ks 84ROOTTGTS_kvm_kmdb = $(ROOTKMOD)/$(KMODULE) 85ROOTTGTS_kvm_mdb = $(ROOTMOD)/$(MODULE) 86ROOTTGTS_kvm_both = $(ROOTTGTS_kvm_mdb) $(ROOTTGTS_kvm_kmdb) 87ROOTTGTS_kvm = $(ROOTTGTS_kvm_$(ROOTTGTS_kvm_type)) 88ROOTTGTS_proc = $(ROOTMOD)/$(MODULE) 89ROOTTGTS_raw = $(ROOTMOD)/$(MODULE) 90ROOTTGTS = $(ROOTTGTS_$(MDBTGT)) 91 92# What should we lint? 93KLINTOBJS = $(KMODOBJS:%.o=%.ln) 94LINTOBJS = $(MODOBJS:%.o=%.ln) 95 96LINTFILES_kvm_type = $(TARGETS_kvm_type) 97LINTFILES_kvm_both = $(KLINTOBJS) $(LINTOBJS) 98LINTFILES_kvm_mdb = $(LINTOBJS) 99LINTFILES_kvm = $(LINTFILES_kvm_$(LINTFILES_kvm_type)) 100LINTFILES_proc = $(LINTOBJS) 101LINTFILES_raw = $(LINTOBJS) 102LINTFILES = $(LINTFILES_$(MDBTGT)) 103 104# 105# Python specific flags. To try and make life easier for folks how are 106# building with an LFS python, we attempt to use -isystem when it's 107# available. 108# 109PYCPPFLAGS = -_gcc=-isystem -_gcc=$(ADJUNCT_PROTO)/usr/include/python$(PYTHON_VERSION) 110PYCPPFLAGS += -_cc=-I$(ADJUNCT_PROTO)/usr/include/python$(PYTHON_VERSION) 111PYLNFLAGS = -I$(ADJUNCT_PROTO)/usr/include/python$(PYTHON_VERSION) 112 113kvm_TGTFLAGS = -D_KERNEL 114proc_TGTFLAGS = -D_USER 115 116C99MODE = $(C99_ENABLE) 117 118CFLAGS += $(CCVERBOSE) 119CFLAGS64 += $(CCVERBOSE) 120CPPFLAGS += $($(MDBTGT)_TGTFLAGS) -I../../../common 121LDFLAGS += $(ZTEXT) 122LDFLAGS64 += $(ZTEXT) 123ASFLAGS += -P 124AS_CPPFLAGS += -D_ASM 125 126# Module type-specific compiler flags 127$(MODOBJS) := CFLAGS += $(C_BIGPICFLAGS) $(XREGSFLAG) 128$(MODOBJS) := CFLAGS64 += $(C_BIGPICFLAGS) $(XREGSFLAG) 129$(KMODOBJS) $(KLINTOBJS) := CPPFLAGS += -D_KMDB 130$(KMODOBJS) := V9CODESIZE = $(CCABS32) 131$(KMODOBJS) := DTS_ERRNO = 132 133# Modules aren't allowed to export symbols 134MAPFILE = $(SRC)/cmd/mdb/common/modules/conf/mapfile 135 136# Modules typically make external references. To provide for -zdefs use 137# and clean ldd(1) processing, explicitly define all external references. 138MAPFILE-EXT = $(SRC)/cmd/mdb/common/modules/conf/mapfile-extern 139 140# 141# kmdb is a kernel module, so we'll use the kernel's build flags. 142$(KMODOBJS) := CFLAGS += $(STAND_FLAGS_32) 143$(KMODOBJS) := CFLAGS64 += $(STAND_FLAGS_64) 144 145# 146# Override this to pull source files from another directory 147# 148MODSRCS_DIR = ../../../common/modules/genunix 149 150all: $$(TARGETS) 151 152install: all $$(ROOTTGTS) 153 154dmods: install 155 156clean.lint: 157 $(RM) $(LINTFILES) $(MODSRCS:.c=.ln) 158 159clean: 160 $(RM) $(MODOBJS) $(KMODOBJS) $(CLEANFILES) 161 162clobber: clean clean.lint 163 $(RM) $(MODFILE) $(KMODFILE) $(CLOBBERFILES) 164 165lint: $$(LINTFILES) 166 167.NO_PARALLEL: 168.PARALLEL: $(MODOBJS) $(KMODOBJS) mdb_tgt kmdb_tgt dmod kmod \ 169 $(TARGETS) $(LINTFILES) 170 171$(MODFILE): dmod .WAIT $(MODOBJS) $$(MAPFILE-EXT) 172 $(LINK.c) $(ZDEFS) $(ZIGNORE) $(MAPFILE-EXT:%=-M%) $(GSHARED) \ 173 $(MODOBJS) -o $@ $(LDLIBS) -lc 174 $(CTFMERGE) -L VERSION -o $@ $(MODOBJS) 175 $(POST_PROCESS_SO) 176 177# 178# kmdb dmods must *not* stray from the module API. To ensure that they don't, 179# we try to link them, at build time, against an object that exports the symbols 180# that they can legally use. The link test object is, however, only built when 181# kmdb itself is built. Requiring module developers to build kmdb first would 182# be painful, so by default, module-level builds don't do the link test (the 183# $(POUND_SIGN) assignment below takes care of that). Builds of the entire 184# tree can, however, guarantee the construction of kmdb first, and as such can 185# override the setting of $(KMDB_LINKTEST_ENABLE). This override causes the 186# link test to be run. 187# 188# Developers wanting to force a link test for a single module can use the 189# `linktest' target from within a module directory. 190# 191LINKTESTOBJ = $(KMDBDIR)/kmdb_modlinktest.o 192 193KMDB_LINKTEST = \ 194 $(LD) $(ZDEFS) -dy -r -o $@.linktest $(KMODOBJS) \ 195 $(STANDOBJS) $(LINKTESTOBJ) && \ 196 $(RM) $@.linktest 197 198KMDB_LINKTEST_ENABLE=$(POUND_SIGN) 199$(KMDB_LINKTEST_ENABLE)KMDB_LINKTEST_CMD = $(KMDB_LINKTEST) 200 201# 202# Ensure that dmods don't use floating point 203# 204KMDB_FPTEST_CMD = $(KMDB_FPTEST) 205 206$(KMODFILE): kmod .WAIT $(KMODOBJS) $(MAPFILE) 207 $(LD) -dy -r $(MAPFILE:%=-M%) -Nmisc/kmdbmod -o $@ $(KMODOBJS) \ 208 $(STANDOBJS) 209 $(KMDB_LINKTEST_CMD) 210 $(KMDB_FPTEST_CMD) 211 $(CTFMERGE) -f -L VERSION -o $@ $(KMODOBJS) 212 $(POST_PROCESS) 213 $(SETDYNFLAG) -f DF_1_NOKSYMS $@ 214 215linktest: linktest_check .WAIT kmod .WAIT $(KMODOBJS) 216 $(KMDB_LINKTEST) 217 218linktest_check: 219 @if [ "$(MDBTGT)" != "kvm" ] ; then \ 220 echo "ERROR: linktest is not supported non-kvm/disasm dmods" \ 221 >&2 ; \ 222 exit 1 ; \ 223 fi 224 225# 226# Dynamic rules for object construction 227# 228dmod/%.o kmod/%.o: %.c 229 $(COMPILE.c) -o $@ $< 230 $(CTFCONVERT_O) 231 232dmod/%.o kmod%.o: %.s 233 $(COMPILE.s) -o $@ $< 234 $(CTFCONVERT_O) 235 236dmod/%.o kmod/%.o: ../%.c 237 $(COMPILE.c) -o $@ $< 238 $(CTFCONVERT_O) 239 240dmod/%.o kmod%.o: ../%.s 241 $(COMPILE.s) -o $@ $< 242 $(CTFCONVERT_O) 243 244dmod/%.o kmod/%.o: ../../../common/modules/$(MODNAME)/%.c 245 $(COMPILE.c) -o $@ $< 246 $(CTFCONVERT_O) 247 248dmod/%.o kmod%.o: ../../../common/modules/$(MODNAME)/%.s 249 $(COMPILE.s) -o $@ $< 250 $(CTFCONVERT_O) 251 252dmod/%.o kmod/%.o: $$(MODSRCS_DIR)/%.c 253 $(COMPILE.c) -o $@ $< 254 $(CTFCONVERT_O) 255 256dmod/%.o kmod%.o: $$(MODSRCS_DIR)/%.s 257 $(COMPILE.s) -o $@ $< 258 $(CTFCONVERT_O) 259 260# 261# Lint 262# 263dmod/%.ln kmod/%.ln: %.c 264 $(LINT.c) -dirout=$(@D) -c $< 265 266dmod/%.ln kmod/%.ln: %.s 267 $(LINT.s) -dirout=$(@D) -c $< 268 269dmod/%.ln kmod/%.ln: ../%.c 270 $(LINT.c) -dirout=$(@D) -c $< 271 272dmod/%.ln kmod/%.ln: ../%.s 273 $(LINT.s) -dirout=$(@D) -c $< 274 275dmod/%.ln kmod/%.ln: ../../../common/modules/$(MODNAME)/%.c 276 $(LINT.c) -dirout=$(@D) -c $< 277 278dmod/%.ln kmod/%.ln: ../../../common/modules/$(MODNAME)/%.s 279 $(LINT.s) -dirout=$(@D) -c $< 280 281dmod/%.ln kmod/%.ln: $$(MODSRCS_DIR)/%.c 282 $(LINT.c) -dirout=$(@D) -c $< 283 284dmod/%.ln kmod/%.ln: $$(MODSRCS_DIR)/%.s 285 $(LINT.s) -dirout=$(@D) -c $< 286 287# 288# Installation targets 289# 290 291$(ROOT)/usr/lib/mdb/$(MDBTGT): $(ROOT)/usr/lib/mdb 292 $(INS.dir) 293 294$(ROOT)/usr/lib/mdb: 295 $(INS.dir) 296 297$(ROOT)/kernel/kmdb: 298 $(INS.dir) 299 300$(ROOTMOD)/$(MODULE): $(ROOTMOD) 301 302$(ROOTKMOD)/$(KMODULE): $(ROOTKMOD) 303 304kmod dmod: 305 -@mkdir -p $@ 306