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.
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.
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]
22 # Copyright (c) 1989, 2010, Oracle and/or its affiliates. All rights reserved.
23 # Copyright 2012 Nexenta Systems, Inc. All rights reserved.
25 # include global definitions
26 include ..
/Makefile.master
29 # List of architectures to build as part of the standard build.
31 # Some of these architectures are built in parallel (see i386_PARALLEL and
32 # sparc_PARALLEL). This requires building some parts first before parallel build
33 # can start. Platform make files know what should be built as a prerequisite for
34 # the parallel build to work. The i386_PREREQ and sparc_PREREQ variables tell
35 # which platform directory to enter to start making prerequisite dependencies.
37 sparc_ARCHITECTURES
= sun4v sun4u sparc
39 i386_ARCHITECTURES
= i86pc i86xpv intel
42 # For i386 all architectures can be compiled in parallel.
44 # intel/Makefile knows how to build prerequisites needed for parallel build.
47 i386_PARALLEL
= $(i386_ARCHITECTURES
)
50 # For sparc all architectures can be compiled in parallel.
52 # sun4/Makefile knows how to build prerequisites needed for parallel build.
56 sparc_PARALLEL
= $(sparc_ARCHITECTURES
)
59 # Platforms defined in $(MACH)_PARALLEL are built in parallel. DUMMY is placed
60 # at the end in case $(MACH)_PARALLEL is empty to prevent everything going in
63 .PARALLEL
: $($(MACH
)_PARALLEL
) DUMMY
66 # For build prerequisites we use a special target which is constructed by adding
67 # '.prereq' suffix to the $(MACH)_PREREQ.
69 PREREQ_TARGET
= $($(MACH
)_PREREQ
:%=%.prereq
)
74 install := TARGET
= install
75 install_h
:= TARGET
= install_h
76 clean := TARGET
= clean
77 clobber := TARGET
= clobber
78 clobber_h
:= TARGET
= clobber
80 clean.lint
:= TARGET
= clean.lint
81 check := TARGET
= check
82 modlist
:= TARGET
= modlist
83 modlist
:= NO_STATE
= -K
$$MODSTATE$$$$
87 def
all lint
: all_h
$(PMTMO_FILE
) $($(MACH
)_ARCHITECTURES
)
89 install: all_h install_dirs
$(PMTMO_FILE
) $($(MACH
)_ARCHITECTURES
)
92 @cd ..
; pwd
; $(MAKE
) rootdirs
96 # Rule to build prerequisites. The left part of the pattern will match
99 # The location of the Makefile is determined by strippinng '.prereq' suffix from
100 # the target name. We add '.prereq' suffix to the target passed to the child
101 # Makefile so that it can distinguish prerequisite build from the regular one.
105 @cd
$(@
:%.prereq
=%); pwd
; $(MAKE
) $(NO_STATE
) $(TARGET
).prereq
108 # Rule to build architecture files. Build all required prerequisites and then
109 # build the rest (potentially in parallel).
111 $($(MACH
)_ARCHITECTURES
): $(PREREQ_TARGET
) FRC
112 @cd
$@
; pwd
; $(MAKE
) $(NO_STATE
) $(TARGET
)
114 $(PMTMO_FILE
) pmtmo_file
: $(PATCH_MAKEUP_TABLE
)
115 @if
[ -z
"$(PATCH_MAKEUP_TABLE)" ] ; then \
116 echo
'ERROR: $$(PATCH_MAKEUP_TABLE) not set' \
117 'in environment' >&2 ; \
120 RELEASE
="$(RELEASE)" MACH
="$(MACH)" \
121 $(CTFCVTPTBL
) -o
$(PMTMO_FILE
) $(PATCH_MAKEUP_TABLE
)
124 # The following is the list of directories which contain Makefiles with
125 # targets to install header file. The machine independent headers are
126 # installed by invoking the Makefile in the directory containing the
127 # header files. Machine and architecture dependent headers are installed
128 # by invoking the main makefile for that architecture/machine which,
129 # in turn, is responsible for invoking the Makefiles which install headers.
130 # It is done this way so as not to assume that all of the header files in
131 # the architecture/machine dependent subdirectories are in completely
132 # isomorphic locations.
134 COMMON_HDRDIRS
= common
/avs \
142 common
/inet
/ipf
/netinet \
145 common
/inet
/sockmods
/netpacket \
147 common
/io
/fibre-channel
/fca
/qlc \
163 # Subset of COMMON_HDRDIRS in which at least one header is generated
164 # at runtime (e.g., rpcgen), and in which "make clean" should run.
165 # Other directories should be included here, but do not yet have the
166 # necessary Makefile support (make clean). See 6414855.
168 DYNHDRDIRS
= common
/avs \
171 common
/io
/fibre-channel
/fca
/qlc \
177 sparc_HDRDIRS
= sun
/sys
178 i386_HDRDIRS
= i86pc
/vm i86xpv
/vm
180 HDRDIRS
= $(COMMON_HDRDIRS
) $($(MACH
)_HDRDIRS
)
181 install_h
check: $(HDRDIRS
) $($(MACH
)_ARCHITECTURES
)
184 @cd
$@
; pwd
; $(MAKE
) $(TARGET
)
186 # ensures that headers made by rpcgen and others are available in uts source
187 # for kernel builds to reference without building install_h
190 @cd common
/sys
; pwd
; $(MAKE
) $@
191 @cd common
/rpc
; pwd
; $(MAKE
) $@
192 @cd common
/rpcsvc
; pwd
; $(MAKE
) $@
193 @cd common
/gssapi
; pwd
; $(MAKE
) $@
194 @cd common
/idmap
; pwd
; $(MAKE
) $@
195 @cd common
/klm
; pwd
; $(MAKE
) $@
197 clean clobber: $($(MACH
)_ARCHITECTURES
) $(DYNHDRDIRS
)
198 @if
[ '$(PATCH_BUILD)' != '#' ] ; then \
199 echo
$(RM
) $(PMTMO_FILE
) ; \
200 $(RM
) $(PMTMO_FILE
) ; \
203 # testing convenience
204 clobber_h
: $(DYNHDRDIRS
)
206 clean.lint modlist
: $($(MACH
)_ARCHITECTURES
)
209 # Cross-reference customization: build a cross-reference over all of
210 # the supported architectures. Although there's no correct way to set
211 # the include path (since we don't know what architecture is the one
212 # the user will be interested in), it's historically been set to
213 # mirror the $(XRDIRS) list, and that works kinda sorta okay.
215 XRDIRS
= $(sparc_ARCHITECTURES
) $(i386_ARCHITECTURES
) sun4 sfmmu \
218 XRINCDIRS
= $(XRDIRS
)