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 #
  27 
  28 .KEEP_STATE:
  29 .SUFFIXES:
  30 
  31 include $(SRC)/cmd/mdb/Makefile.tools
  32 
  33 $(KMOD_SOURCES_DIFFERENT)KMODSRCS = $(MODSRCS)
  34 
  35 MODOBJS = $(MODSRCS:%.c=dmod/%.o)
  36 KMODOBJS = $(KMODSRCS:%.c=kmod/%.o)
  37 
  38 MODNAME = $(MODULE:%.so=%)
  39 KMODULE = $(MODNAME)
  40 
  41 MODFILE = dmod/$(MODULE)
  42 KMODFILE = kmod/$(KMODULE)
  43 
  44 #
  45 # The mess below is designed to pick the right set of objects to build and/or
  46 # lint.  We have three flavors:
  47 #
  48 #  1. proc and raw modules.  Only $(MODOBJS) are built.
  49 #  2. kvm modules for systems without kmdb.  Only $(MODOBJS) are built.
  50 #  3. kvm modules for systems with kmdb.  $(MODOBJS) and $(KMODOBJS) are built.
  51 #
  52 # Complicating matters, we'd like to make the distinction between 2 and 3 before
  53 # this Makefile is loaded.  By default, we'll assume that all kvm modules should
  54 # be built for kmdb.  If, however, the user sets $(MODULE_BUILD_TYPE) to `mdb',
  55 # the kmdb variant of the module won't be built.
  56 #
  57 
  58 # Which flavors are to be built?
  59 TARGETS_kvm_type_       = both  # Build both if $(MODULE_BUILD_TYPE) is unset
  60 TARGETS_kvm_type_kmdb   = both
  61 TARGETS_kvm_type_mdb    = mdb
  62 TARGETS_kvm_type        = $(TARGETS_kvm_type_$(MODULE_BUILD_TYPE))
  63 
  64 # What should we build?
  65 TARGETS_kvm_kmdb        = $(KMODFILE)
  66 TARGETS_kvm_mdb         = $(MODFILE)
  67 TARGETS_kvm_both        = $(TARGETS_kvm_mdb) $(TARGETS_kvm_kmdb)
  68 TARGETS_kvm             = $(TARGETS_kvm_$(TARGETS_kvm_type))
  69 TARGETS_proc            = $(MODFILE)
  70 TARGETS_raw             = $(MODFILE)
  71 TARGETS                 = $(TARGETS_$(MDBTGT))
  72 
  73 # Where should we install that which we've built?
  74 ROOTTGTS_kvm_type       = $(TARGETS_kvm_type)   # overridden by mdb_ks
  75 ROOTTGTS_kvm_kmdb       = $(ROOTKMOD)/$(KMODULE)
  76 ROOTTGTS_kvm_mdb        = $(ROOTMOD)/$(MODULE)
  77 ROOTTGTS_kvm_both       = $(ROOTTGTS_kvm_mdb) $(ROOTTGTS_kvm_kmdb)
  78 ROOTTGTS_kvm            = $(ROOTTGTS_kvm_$(ROOTTGTS_kvm_type))
  79 ROOTTGTS_proc           = $(ROOTMOD)/$(MODULE)
  80 ROOTTGTS_raw            = $(ROOTMOD)/$(MODULE)
  81 ROOTTGTS                = $(ROOTTGTS_$(MDBTGT))
  82 
  83 # What should we lint?
  84 KLINTOBJS               = $(KMODOBJS:%.o=%.ln)
  85 LINTOBJS                = $(MODOBJS:%.o=%.ln)
  86 
  87 LINTFILES_kvm_type      = $(TARGETS_kvm_type)
  88 LINTFILES_kvm_both      = $(KLINTOBJS) $(LINTOBJS)
  89 LINTFILES_kvm_mdb       = $(LINTOBJS)
  90 LINTFILES_kvm           = $(LINTFILES_kvm_$(LINTFILES_kvm_type))
  91 LINTFILES_proc          = $(LINTOBJS)
  92 LINTFILES_raw           = $(LINTOBJS)
  93 LINTFILES               = $(LINTFILES_$(MDBTGT))
  94 
  95 kvm_TGTFLAGS            = -D_KERNEL
  96 proc_TGTFLAGS           = -D_USER
  97 
  98 C99MODE                 = $(C99_ENABLE)
  99 
 100 CFLAGS                  += $(CCVERBOSE)
 101 CFLAGS64                += $(CCVERBOSE)
 102 CPPFLAGS                += $($(MDBTGT)_TGTFLAGS) -I../../../common
 103 LDFLAGS                 += $(ZTEXT)
 104 LDFLAGS64               += $(ZTEXT)
 105 
 106 # Module type-specific compiler flags
 107 $(MODOBJS) :=                   CFLAGS += $(C_BIGPICFLAGS) $(XREGSFLAG)
 108 $(MODOBJS) :=                   CFLAGS64 += $(C_BIGPICFLAGS) $(XREGSFLAG)
 109 $(KMODOBJS) $(KLINTOBJS) :=     CPPFLAGS += -D_KMDB
 110 $(KMODOBJS) :=                  V9CODESIZE = $(CCABS32)
 111 $(KMODOBJS) :=                  DTS_ERRNO =
 112 
 113 # Modules aren't allowed to export symbols
 114 MAPFILE         = $(SRC)/cmd/mdb/common/modules/conf/mapfile
 115 
 116 # Modules typically make external references.  To provide for -zdefs use
 117 # and clean ldd(1) processing, explicitly define all external references.
 118 MAPFILE-EXT     = $(SRC)/cmd/mdb/common/modules/conf/mapfile-extern
 119 
 120 #
 121 # kmdb is a kernel module, so we'll use the kernel's build flags.
 122 $(KMODOBJS) := CFLAGS += $(STAND_FLAGS_32)
 123 $(KMODOBJS) := CFLAGS64 += $(STAND_FLAGS_64)
 124 
 125 #
 126 # Override this to pull source files from another directory
 127 #
 128 MODSRCS_DIR = ../../../common/modules/genunix
 129 
 130 all: $$(TARGETS)
 131 
 132 install: all $$(ROOTTGTS)
 133 
 134 dmods: install
 135 
 136 clean.lint:
 137         $(RM) $(LINTFILES) $(MODSRCS:.c=.ln)
 138 
 139 clean:
 140         $(RM) $(MODOBJS) $(KMODOBJS) $(CLEANFILES)
 141 
 142 clobber: clean clean.lint
 143         $(RM) $(MODFILE) $(KMODFILE) $(CLOBBERFILES)
 144 
 145 lint: $$(LINTFILES)
 146 
 147 .NO_PARALLEL:
 148 .PARALLEL: $(MODOBJS) $(KMODOBJS) mdb_tgt kmdb_tgt dmod kmod \
 149         $(TARGETS) $(LINTFILES)
 150 
 151 $(MODFILE): dmod .WAIT $(MODOBJS) $$(MAPFILE-EXT)
 152         $(LINK.c) $(ZDEFS) $(ZIGNORE) $(MAPFILE-EXT:%=-M%) $(GSHARED) \
 153             $(MODOBJS) -o $@ $(LDLIBS) -lc
 154         $(CTFMERGE) -L VERSION -o $@ $(MODOBJS)
 155         $(POST_PROCESS_SO)
 156 
 157 #
 158 # kmdb dmods must *not* stray from the module API.  To ensure that they don't,
 159 # we try to link them, at build time, against an object that exports the symbols
 160 # that they can legally use.  The link test object is, however, only built when
 161 # kmdb itself is built.  Requiring module developers to build kmdb first would
 162 # be painful, so by default, module-level builds don't do the link test (the
 163 # $(POUND_SIGN) assignment below takes care of that).  Builds of the entire
 164 # tree can, however, guarantee the construction of kmdb first, and as such can
 165 # override the setting of $(KMDB_LINKTEST_ENABLE).  This override causes the
 166 # link test to be run.
 167 #
 168 # Developers wanting to force a link test for a single module can use the
 169 # `linktest' target from within a module directory.
 170 #
 171 LINKTESTOBJ = $(KMDBDIR)/kmdb_modlinktest.o
 172 
 173 KMDB_LINKTEST = \
 174         $(LD) $(ZDEFS) -dy -r -o $@.linktest $(KMODOBJS) \
 175         $(STANDOBJS) $(LINKTESTOBJ) && \
 176         $(RM) $@.linktest
 177 
 178 KMDB_LINKTEST_ENABLE=$(POUND_SIGN)
 179 $(KMDB_LINKTEST_ENABLE)KMDB_LINKTEST_CMD = $(KMDB_LINKTEST)
 180 
 181 #
 182 # Ensure that dmods don't use floating point
 183 #
 184 KMDB_FPTEST_CMD = $(KMDB_FPTEST)
 185 
 186 $(KMODFILE): kmod .WAIT $(KMODOBJS) $(MAPFILE)
 187         $(LD) -dy -r $(MAPFILE:%=-M%) -Nmisc/kmdbmod -o $@ $(KMODOBJS) \
 188         $(STANDOBJS)
 189         $(KMDB_LINKTEST_CMD)
 190         $(KMDB_FPTEST_CMD)
 191         $(CTFMERGE) -f -L VERSION -o $@ $(KMODOBJS)
 192         $(POST_PROCESS)
 193         $(SETDYNFLAG) -f DF_1_NOKSYMS $@
 194 
 195 linktest: linktest_check .WAIT kmod .WAIT $(KMODOBJS)
 196         $(KMDB_LINKTEST)
 197 
 198 linktest_check:
 199         @if [ "$(MDBTGT)" != "kvm" ] ; then \
 200                 echo "ERROR: linktest is not supported non-kvm/disasm dmods" \
 201                     >&2 ; \
 202                 exit 1 ; \
 203         fi
 204 
 205 #
 206 # Dynamic rules for object construction
 207 #
 208 dmod/%.o kmod/%.o: %.c
 209         $(COMPILE.c) -o $@ $<
 210         $(CTFCONVERT_O)
 211 
 212 dmod/%.o kmod/%.o: ../%.c
 213         $(COMPILE.c) -o $@ $<
 214         $(CTFCONVERT_O)
 215 
 216 dmod/%.o kmod/%.o: ../../../common/modules/$(MODNAME)/%.c
 217         $(COMPILE.c) -o $@ $<
 218         $(CTFCONVERT_O)
 219 
 220 dmod/%.o kmod/%.o: $$(MODSRCS_DIR)/%.c
 221         $(COMPILE.c) -o $@ $<
 222         $(CTFCONVERT_O)
 223 
 224 #
 225 # Lint
 226 #
 227 dmod/%.ln kmod/%.ln: %.c
 228         $(LINT.c) -dirout=$(@D) -c $<
 229 
 230 dmod/%.ln kmod/%.ln: ../%.c
 231         $(LINT.c) -dirout=$(@D) -c $<
 232 
 233 dmod/%.ln kmod/%.ln: ../../../common/modules/$(MODNAME)/%.c
 234         $(LINT.c) -dirout=$(@D) -c $<
 235 
 236 dmod/%.ln kmod/%.ln: $$(MODSRCS_DIR)/%.c
 237         $(LINT.c) -dirout=$(@D) -c $<
 238 
 239 #
 240 # Installation targets
 241 #
 242 
 243 $(ROOT)/usr/lib/mdb/$(MDBTGT): $(ROOT)/usr/lib/mdb
 244         $(INS.dir)
 245 
 246 $(ROOT)/usr/lib/mdb:
 247         $(INS.dir)
 248 
 249 $(ROOT)/kernel/kmdb:
 250         $(INS.dir)
 251 
 252 $(ROOTMOD)/$(MODULE): $(ROOTMOD)
 253 
 254 $(ROOTKMOD)/$(KMODULE): $(ROOTKMOD)
 255 
 256 kmod dmod:
 257         -@mkdir -p $@