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 (c) 1989, 2010, Oracle and/or its affiliates. All rights reserved.
  23 #
  24 # include global definitions
  25 include ../Makefile.master
  26 
  27 #
  28 # List of architectures to build as part of the standard build.
  29 #
  30 # Some of these architectures are built in parallel (see i386_PARALLEL and
  31 # sparc_PARALLEL). This requires building some parts first before parallel build
  32 # can start. Platform make files know what should be built as a prerequisite for
  33 # the parallel build to work. The i386_PREREQ and sparc_PREREQ variables tell
  34 # which platform directory to enter to start making prerequisite dependencies.
  35 #
  36 sparc_ARCHITECTURES = sun4v sun4u sparc
  37 
  38 i386_ARCHITECTURES = i86pc i86xpv intel
  39 
  40 #
  41 # For i386 all architectures can be compiled in parallel.
  42 #
  43 # intel/Makefile knows how to build prerequisites needed for parallel build.
  44 #
  45 i386_PREREQ = intel
  46 i386_PARALLEL = $(i386_ARCHITECTURES)
  47 
  48 #
  49 # For sparc all architectures can be compiled in parallel.
  50 #
  51 # sun4/Makefile knows how to build prerequisites needed for parallel build.
  52 # can start.
  53 #
  54 sparc_PREREQ = sun4
  55 sparc_PARALLEL = $(sparc_ARCHITECTURES)
  56 
  57 #
  58 # Platforms defined in $(MACH)_PARALLEL are built in parallel. DUMMY is placed
  59 # at the end in case $(MACH)_PARALLEL is empty to prevent everything going in
  60 # parallel.
  61 #
  62 .PARALLEL: $($(MACH)_PARALLEL) DUMMY
  63 
  64 #
  65 # For build prerequisites we use a special target which is constructed by adding
  66 # '.prereq' suffix to the $(MACH)_PREREQ.
  67 #
  68 PREREQ_TARGET = $($(MACH)_PREREQ:%=%.prereq)
  69 
  70 
  71 def             :=      TARGET= def
  72 all             :=      TARGET= all
  73 install         :=      TARGET= install
  74 install_h       :=      TARGET= install_h
  75 clean           :=      TARGET= clean
  76 clobber         :=      TARGET= clobber
  77 lint            :=      TARGET= lint
  78 clean.lint      :=      TARGET= clean.lint
  79 check           :=      TARGET= check
  80 modlist         :=      TARGET= modlist
  81 modlist         :=      NO_STATE= -K $$MODSTATE$$$$
  82 
  83 .KEEP_STATE:
  84 
  85 def all lint: all_h $(PMTMO_FILE) $($(MACH)_ARCHITECTURES)
  86 
  87 install: all_h install_dirs $(PMTMO_FILE) $($(MACH)_ARCHITECTURES)
  88 
  89 install_dirs:
  90         @cd ..; pwd; $(MAKE) rootdirs
  91         @pwd
  92 
  93 #
  94 # Rule to build prerequisites. The left part of the pattern will match
  95 # PREREQ_TARGET.
  96 #
  97 # The location of the Makefile is determined by strippinng '.prereq' suffix from
  98 # the target name. We add '.prereq' suffix to the target passed to the child
  99 # Makefile so that it can distinguish prerequisite build from the regular one.
 100 #
 101 #
 102 %.prereq:
 103         @cd $(@:%.prereq=%); pwd; $(MAKE) $(NO_STATE) $(TARGET).prereq
 104 
 105 #
 106 # Rule to build architecture files. Build all required prerequisites and then
 107 # build the rest (potentially in parallel).
 108 #
 109 $($(MACH)_ARCHITECTURES): $(PREREQ_TARGET) FRC
 110         @cd $@; pwd; $(MAKE) $(NO_STATE) $(TARGET)
 111 
 112 $(PMTMO_FILE) pmtmo_file: $(PATCH_MAKEUP_TABLE)
 113         @if [ -z "$(PATCH_MAKEUP_TABLE)" ] ; then \
 114                 echo 'ERROR: $$(PATCH_MAKEUP_TABLE) not set' \
 115                     'in environment' >&2 ; \
 116                 exit 1 ; \
 117         fi
 118         RELEASE="$(RELEASE)" MACH="$(MACH)" \
 119             $(CTFCVTPTBL) -o $(PMTMO_FILE) $(PATCH_MAKEUP_TABLE)
 120 
 121 #
 122 # The following is the list of directories which contain Makefiles with
 123 # targets to install header file. The machine independent headers are
 124 # installed by invoking the Makefile in the directory containing the
 125 # header files. Machine and architecture dependent headers are installed
 126 # by invoking the main makefile for that architecture/machine which,
 127 # in turn, is responsible for invoking the Makefiles which install headers.
 128 # It is done this way so as not to assume that all of the header files in
 129 # the architecture/machine dependent subdirectories are in completely
 130 # isomorphic locations.
 131 #
 132 COMMON_HDRDIRS= common/avs \
 133                 common/c2 \
 134                 common/des \
 135                 common/fs \
 136                 common/gssapi \
 137                 common/idmap \
 138                 common/inet \
 139                 common/inet/ipf/netinet \
 140                 common/inet/kssl \
 141                 common/inet/nca \
 142                 common/inet/sockmods/netpacket \
 143                 common/io/bpf/net \
 144                 common/ipp \
 145                 common/net \
 146                 common/netinet \
 147                 common/nfs \
 148                 common/pcmcia/sys \
 149                 common/rpc \
 150                 common/rpcsvc \
 151                 common/sharefs \
 152                 common/smb \
 153                 common/smbsrv \
 154                 common/sys \
 155                 common/vm
 156 
 157 
 158 # These aren't the only headers in closed.  But the other directories
 159 # are simple enough that they can be driven from the src tree.
 160 $(CLOSED_BUILD)COMMON_HDRDIRS += $(CLOSED)/uts/common/sys
 161 
 162 #
 163 # Subset of COMMON_HDRDIRS in which at least one header is generated
 164 # at runtime (e.g., rpcgen).  (This is a partial list; there are
 165 # other directories that should be included and do not yet have the
 166 # necessary Makefile support.  See 6414855.)
 167 #
 168 DYNHDRDIRS = common/rpcsvc common/idmap common/sys
 169 
 170 sparc_HDRDIRS= sun/sys
 171 i386_HDRDIRS= i86pc/vm i86xpv/vm
 172 
 173 HDRDIRS= $(COMMON_HDRDIRS) $($(MACH)_HDRDIRS)
 174 install_h check: $(HDRDIRS) $($(MACH)_ARCHITECTURES)
 175 
 176 $(HDRDIRS): FRC
 177         @cd $@; pwd; $(MAKE) $(TARGET)
 178 
 179 # ensures that headers made by rpcgen and others are available in uts source
 180 # for kernel builds to reference without building install_h
 181 #
 182 all_h: FRC
 183         @cd common/sys; pwd; $(MAKE) $@
 184         @cd common/rpc; pwd; $(MAKE) $@
 185         @cd common/rpcsvc; pwd; $(MAKE) $@
 186         @cd common/gssapi; pwd; $(MAKE) $@
 187         @cd common/idmap; pwd; $(MAKE) $@
 188 
 189 clean clobber: $($(MACH)_ARCHITECTURES) $(DYNHDRDIRS)
 190         @if [ '$(PATCH_BUILD)' != '#' ] ; then \
 191                 echo $(RM) $(PMTMO_FILE) ; \
 192                 $(RM) $(PMTMO_FILE) ; \
 193         fi
 194 
 195 EXTRA_CLOBBER_TARGETS= common/avs/ns/rdc
 196 clobber: $(EXTRA_CLOBBER_TARGETS)
 197 
 198 
 199 clean.lint modlist: $($(MACH)_ARCHITECTURES)
 200 
 201 #
 202 # Cross-reference customization: build a cross-reference over all of
 203 # the supported architectures.  Although there's no correct way to set
 204 # the include path (since we don't know what architecture is the one
 205 # the user will be interested in), it's historically been set to
 206 # mirror the $(XRDIRS) list, and that works kinda sorta okay.
 207 #
 208 # We need to manually prune usr/closed/uts/{i86xpv|sfmmu|i86pc} since
 209 # none of them exist.
 210 #
 211 SHARED_XRDIRS = $(sparc_ARCHITECTURES) $(i386_ARCHITECTURES) sun4 sfmmu \
 212         sun common
 213 CLOSED_XRDIRS = $(SHARED_XRDIRS:%=% ../../closed/uts/%)
 214 XRDIRS = $(SHARED_XRDIRS)
 215 CLOSED_XRDIRS_XEN = $(CLOSED_XRDIRS:../../closed/uts/i86xpv=)
 216 CLOSED_XRDIRS_1 = $(CLOSED_XRDIRS_XEN:../../closed/uts/i86pc=)
 217 $(CLOSED_BUILD)XRDIRS = $(CLOSED_XRDIRS_1:../../closed/uts/sfmmu=)
 218 
 219 XRINCDIRS = $(XRDIRS)
 220 
 221 cscope.out tags: FRC
 222         $(XREF) -x $@
 223 
 224 FRC: