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.
24 # include global definitions
25 include ..
/Makefile.master
28 # List of architectures to build as part of the standard build.
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.
36 sparc_ARCHITECTURES
= sun4v sun4u sparc
38 i386_ARCHITECTURES
= i86pc i86xpv intel
41 # For i386 all architectures can be compiled in parallel.
43 # intel/Makefile knows how to build prerequisites needed for parallel build.
46 i386_PARALLEL
= $(i386_ARCHITECTURES
)
49 # For sparc all architectures can be compiled in parallel.
51 # sun4/Makefile knows how to build prerequisites needed for parallel build.
55 sparc_PARALLEL
= $(sparc_ARCHITECTURES
)
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
62 .PARALLEL
: $($(MACH
)_PARALLEL
) DUMMY
65 # For build prerequisites we use a special target which is constructed by adding
66 # '.prereq' suffix to the $(MACH)_PREREQ.
68 PREREQ_TARGET
= $($(MACH
)_PREREQ
:%=%.prereq
)
73 install := TARGET
= install
74 install_h
:= TARGET
= install_h
75 clean := TARGET
= clean
76 clobber := TARGET
= clobber
78 clean.lint
:= TARGET
= clean.lint
79 check := TARGET
= check
80 modlist
:= TARGET
= modlist
81 modlist
:= NO_STATE
= -K
$$MODSTATE$$$$
85 def
all lint
: all_h
$(PMTMO_FILE
) $($(MACH
)_ARCHITECTURES
)
87 install: all_h install_dirs
$(PMTMO_FILE
) $($(MACH
)_ARCHITECTURES
)
90 @cd ..
; pwd
; $(MAKE
) rootdirs
94 # Rule to build prerequisites. The left part of the pattern will match
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.
103 @cd
$(@
:%.prereq
=%); pwd
; $(MAKE
) $(NO_STATE
) $(TARGET
).prereq
106 # Rule to build architecture files. Build all required prerequisites and then
107 # build the rest (potentially in parallel).
109 $($(MACH
)_ARCHITECTURES
): $(PREREQ_TARGET
) FRC
110 @cd
$@
; pwd
; $(MAKE
) $(NO_STATE
) $(TARGET
)
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 ; \
118 RELEASE
="$(RELEASE)" MACH
="$(MACH)" \
119 $(CTFCVTPTBL
) -o
$(PMTMO_FILE
) $(PATCH_MAKEUP_TABLE
)
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.
132 COMMON_HDRDIRS
= common
/avs \
139 common
/inet
/ipf
/netinet \
142 common
/inet
/sockmods
/netpacket \
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
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.)
168 DYNHDRDIRS
= common
/rpcsvc common
/idmap common
/sys
170 sparc_HDRDIRS
= sun
/sys
171 i386_HDRDIRS
= i86pc
/vm i86xpv
/vm
173 HDRDIRS
= $(COMMON_HDRDIRS
) $($(MACH
)_HDRDIRS
)
174 install_h
check: $(HDRDIRS
) $($(MACH
)_ARCHITECTURES
)
177 @cd
$@
; pwd
; $(MAKE
) $(TARGET
)
179 # ensures that headers made by rpcgen and others are available in uts source
180 # for kernel builds to reference without building install_h
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
) $@
189 clean clobber: $($(MACH
)_ARCHITECTURES
) $(DYNHDRDIRS
)
190 @if
[ '$(PATCH_BUILD)' != '#' ] ; then \
191 echo
$(RM
) $(PMTMO_FILE
) ; \
192 $(RM
) $(PMTMO_FILE
) ; \
195 EXTRA_CLOBBER_TARGETS
= common
/avs
/ns
/rdc
196 clobber: $(EXTRA_CLOBBER_TARGETS
)
199 clean.lint modlist
: $($(MACH
)_ARCHITECTURES
)
201 ONC_FILES
= common
/io
/timod.c \
205 common
/os
/swapgeneric.c \
206 common
/syscall
/fcntl.c
208 # edit onc plus source files.
209 ONC_PLUS
: $(ONC_FILES
:%=%_onc_plus
)
212 # Cross-reference customization: build a cross-reference over all of
213 # the supported architectures. Although there's no correct way to set
214 # the include path (since we don't know what architecture is the one
215 # the user will be interested in), it's historically been set to
216 # mirror the $(XRDIRS) list, and that works kinda sorta okay.
218 # We need to manually prune usr/closed/uts/{i86xpv|sfmmu|i86pc} since
219 # none of them exist.
221 SHARED_XRDIRS
= $(sparc_ARCHITECTURES
) $(i386_ARCHITECTURES
) sun4 sfmmu \
223 CLOSED_XRDIRS
= $(SHARED_XRDIRS
:%=% ..
/..
/closed
/uts
/%)
224 XRDIRS
= $(SHARED_XRDIRS
)
225 CLOSED_XRDIRS_XEN
= $(CLOSED_XRDIRS
:..
/..
/closed
/uts
/i86xpv
=)
226 CLOSED_XRDIRS_1
= $(CLOSED_XRDIRS_XEN
:..
/..
/closed
/uts
/i86pc
=)
227 $(CLOSED_BUILD
)XRDIRS
= $(CLOSED_XRDIRS_1
:..
/..
/closed
/uts
/sfmmu
=)
229 XRINCDIRS
= $(XRDIRS
)