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]
23 # Copyright (c) 1989, 2010, Oracle and/or its affiliates. All rights reserved.
24 # Copyright 2018 Nexenta Systems, Inc.
27 include ..
/Makefile.master
30 # List of architectures to build as part of the standard build.
32 # Some of these architectures are built in parallel (see i386_PARALLEL and
33 # sparc_PARALLEL). This requires building some parts first before parallel build
34 # can start. Platform make files know what should be built as a prerequisite for
35 # the parallel build to work. The i386_PREREQ and sparc_PREREQ variables tell
36 # which platform directory to enter to start making prerequisite dependencies.
38 sparc_ARCHITECTURES
= sun4v sun4u sparc
40 i386_ARCHITECTURES
= i86pc i86xpv intel
43 # For i386 all architectures can be compiled in parallel.
45 # intel/Makefile knows how to build prerequisites needed for parallel build.
48 i386_PARALLEL
= $(i386_ARCHITECTURES
)
51 # For sparc all architectures can be compiled in parallel.
53 # sun4/Makefile knows how to build prerequisites needed for parallel build.
57 sparc_PARALLEL
= $(sparc_ARCHITECTURES
)
60 # Platforms defined in $(MACH)_PARALLEL are built in parallel. DUMMY is placed
61 # at the end in case $(MACH)_PARALLEL is empty to prevent everything going in
64 .PARALLEL
: $($(MACH
)_PARALLEL
) DUMMY
67 # For build prerequisites we use a special target which is constructed by adding
68 # '.prereq' suffix to the $(MACH)_PREREQ.
70 PREREQ_TARGET
= $($(MACH
)_PREREQ
:%=%.prereq
)
75 install := TARGET
= install
76 install_h
:= TARGET
= install_h
77 clean := TARGET
= clean
78 clobber := TARGET
= clobber
79 clobber_h
:= TARGET
= clobber
81 clean.lint
:= TARGET
= clean.lint
82 check := TARGET
= check
83 modlist
:= TARGET
= modlist
84 modlist
:= NO_STATE
= -K
$$MODSTATE$$$$
88 def
all lint
: all_h
$(PMTMO_FILE
) $($(MACH
)_ARCHITECTURES
)
90 install: all_h install_dirs
$(PMTMO_FILE
) $($(MACH
)_ARCHITECTURES
)
93 @cd ..
; pwd
; $(MAKE
) rootdirs
97 # Rule to build prerequisites. The left part of the pattern will match
100 # The location of the Makefile is determined by strippinng '.prereq' suffix from
101 # the target name. We add '.prereq' suffix to the target passed to the child
102 # Makefile so that it can distinguish prerequisite build from the regular one.
106 @cd
$(@
:%.prereq
=%); pwd
; $(MAKE
) $(NO_STATE
) $(TARGET
).prereq
109 # Rule to build architecture files. Build all required prerequisites and then
110 # build the rest (potentially in parallel).
112 $($(MACH
)_ARCHITECTURES
): $(PREREQ_TARGET
) FRC
113 @cd
$@
; pwd
; $(MAKE
) $(NO_STATE
) $(TARGET
)
115 $(PMTMO_FILE
) pmtmo_file
: $(PATCH_MAKEUP_TABLE
)
116 @if
[ -z
"$(PATCH_MAKEUP_TABLE)" ] ; then \
117 echo
'ERROR: $$(PATCH_MAKEUP_TABLE) not set' \
118 'in environment' >&2 ; \
121 RELEASE
="$(RELEASE)" MACH
="$(MACH)" \
122 $(CTFCVTPTBL
) -o
$(PMTMO_FILE
) $(PATCH_MAKEUP_TABLE
)
125 # The following is the list of directories which contain Makefiles with
126 # targets to install header file. The machine independent headers are
127 # installed by invoking the Makefile in the directory containing the
128 # header files. Machine and architecture dependent headers are installed
129 # by invoking the main makefile for that architecture/machine which,
130 # in turn, is responsible for invoking the Makefiles which install headers.
131 # It is done this way so as not to assume that all of the header files in
132 # the architecture/machine dependent subdirectories are in completely
133 # isomorphic locations.
135 COMMON_HDRDIRS
= common
/c2 \
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).
168 DYNHDRDIRS
= common
/gssapi \
170 common
/io
/fibre-channel
/fca
/qlc \
176 sparc_HDRDIRS
= sun
/sys
177 i386_HDRDIRS
= i86pc
/vm i86xpv
/vm
179 HDRDIRS
= $(COMMON_HDRDIRS
) $($(MACH
)_HDRDIRS
)
180 install_h
check: $(HDRDIRS
) $($(MACH
)_ARCHITECTURES
)
183 @cd
$@
; pwd
; $(MAKE
) $(TARGET
)
185 # ensures that headers made by rpcgen and others are available in uts source
186 # for kernel builds to reference without building install_h
189 @cd common
/sys
; pwd
; $(MAKE
) $@
190 @cd common
/rpc
; pwd
; $(MAKE
) $@
191 @cd common
/rpcsvc
; pwd
; $(MAKE
) $@
192 @cd common
/gssapi
; pwd
; $(MAKE
) $@
193 @cd common
/idmap
; pwd
; $(MAKE
) $@
194 @cd common
/klm
; pwd
; $(MAKE
) $@
196 clean clobber: $($(MACH
)_ARCHITECTURES
) $(DYNHDRDIRS
)
197 @if
[ '$(PATCH_BUILD)' != '#' ] ; then \
198 echo
$(RM
) $(PMTMO_FILE
) ; \
199 $(RM
) $(PMTMO_FILE
) ; \
202 # testing convenience
203 clobber_h
: $(DYNHDRDIRS
)
205 clean.lint modlist
: $($(MACH
)_ARCHITECTURES
)
208 # Cross-reference customization: build a cross-reference over all of
209 # the supported architectures. Although there's no correct way to set
210 # the include path (since we don't know what architecture is the one
211 # the user will be interested in), it's historically been set to
212 # mirror the $(XRDIRS) list, and that works kinda sorta okay.
214 XRDIRS
= $(sparc_ARCHITECTURES
) $(i386_ARCHITECTURES
) sun4 sfmmu \
217 XRINCDIRS
= $(XRDIRS
)