8354 sync regcomp(3C) with upstream (fix make catalog)
[unleashed/tickless.git] / usr / src / uts / Makefile
blobdbd7eeb94a6bbbfd3c6dea874fd76a8a18613f42
2 # CDDL HEADER START
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]
19 # CDDL HEADER END
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.
46 i386_PREREQ = intel
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.
53 # can start.
55 sparc_PREREQ = sun4
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
61 # parallel.
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)
72 def := TARGET= def
73 all := TARGET= all
74 install := TARGET= install
75 install_h := TARGET= install_h
76 clean := TARGET= clean
77 clobber := TARGET= clobber
78 clobber_h := TARGET= clobber
79 lint := TARGET= lint
80 clean.lint := TARGET= clean.lint
81 check := TARGET= check
82 modlist := TARGET= modlist
83 modlist := NO_STATE= -K $$MODSTATE$$$$
85 .KEEP_STATE:
87 def all lint: all_h $(PMTMO_FILE) $($(MACH)_ARCHITECTURES)
89 install: all_h install_dirs $(PMTMO_FILE) $($(MACH)_ARCHITECTURES)
91 install_dirs:
92 @cd ..; pwd; $(MAKE) rootdirs
93 @pwd
96 # Rule to build prerequisites. The left part of the pattern will match
97 # PREREQ_TARGET.
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.
104 %.prereq:
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 ; \
118 exit 1 ; \
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 \
135 common/c2 \
136 common/des \
137 common/fs \
138 common/gssapi \
139 common/idmap \
140 common/klm \
141 common/inet \
142 common/inet/ipf/netinet \
143 common/inet/kssl \
144 common/inet/nca \
145 common/inet/sockmods/netpacket \
146 common/io/bpf/net \
147 common/io/fibre-channel/fca/qlc \
148 common/ipp \
149 common/net \
150 common/netinet \
151 common/nfs \
152 common/pcmcia/sys \
153 common/rpc \
154 common/rpcsvc \
155 common/sharefs \
156 common/smb \
157 common/smbsrv \
158 common/sys \
159 common/vm
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 \
169 common/gssapi \
170 common/idmap \
171 common/io/fibre-channel/fca/qlc \
172 common/klm \
173 common/rpc \
174 common/rpcsvc \
175 common/sys
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)
183 $(HDRDIRS): FRC
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
189 all_h: FRC
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 \
216 sun common
218 XRINCDIRS = $(XRDIRS)
220 cscope.out tags: FRC
221 $(XREF) -x $@
223 FRC: