xref: /illumos-gate/usr/src/uts/i86xpv/unix/Makefile (revision b6b206fc7fb36f7b13b01acf70ed6e676e405998)
1843e1988Sjohnlev#
2843e1988Sjohnlev# CDDL HEADER START
3843e1988Sjohnlev#
4843e1988Sjohnlev# The contents of this file are subject to the terms of the
5843e1988Sjohnlev# Common Development and Distribution License (the "License").
6843e1988Sjohnlev# You may not use this file except in compliance with the License.
7843e1988Sjohnlev#
8843e1988Sjohnlev# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9843e1988Sjohnlev# or http://www.opensolaris.org/os/licensing.
10843e1988Sjohnlev# See the License for the specific language governing permissions
11843e1988Sjohnlev# and limitations under the License.
12843e1988Sjohnlev#
13843e1988Sjohnlev# When distributing Covered Code, include this CDDL HEADER in each
14843e1988Sjohnlev# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15843e1988Sjohnlev# If applicable, add the following below this CDDL HEADER, with the
16843e1988Sjohnlev# fields enclosed by brackets "[]" replaced with your own identifying
17843e1988Sjohnlev# information: Portions Copyright [yyyy] [name of copyright owner]
18843e1988Sjohnlev#
19843e1988Sjohnlev# CDDL HEADER END
20843e1988Sjohnlev#
21843e1988Sjohnlev
22843e1988Sjohnlev#
2398157a70Sakolb# Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
24843e1988Sjohnlev# Use is subject to license terms.
25843e1988Sjohnlev#
26*b6b206fcSJohn Levon# Copyright (c) 2018, Joyent, Inc.
27*b6b206fcSJohn Levon#
28843e1988Sjohnlev#	This makefile drives the production of unix (and unix.o).
29843e1988Sjohnlev#
30843e1988Sjohnlev#	i86xpv implementation architecture dependent
31843e1988Sjohnlev#
32843e1988Sjohnlev
33843e1988Sjohnlev#
34843e1988Sjohnlev#	Path to the base of the uts directory tree (usually /usr/src/uts).
35843e1988Sjohnlev#
36843e1988SjohnlevUTSBASE	= ../..
37843e1988Sjohnlev
38843e1988Sjohnlev#
39843e1988Sjohnlev#	Define the module and object file sets.
40843e1988Sjohnlev#
41843e1988SjohnlevUNIX		= unix
42843e1988SjohnlevDBOOT		= dboot
43843e1988Sjohnlev
44843e1988SjohnlevOBJECTS		= $(SPECIAL_OBJS:%=$(OBJS_DIR)/%) \
45843e1988Sjohnlev		  $(CORE_OBJS:%=$(OBJS_DIR)/%) \
46843e1988Sjohnlev		  $(KRTLD_OBJS:%=$(OBJS_DIR)/%) \
47843e1988Sjohnlev		  $(MACH_NOT_YET_KMODS:%=$(OBJS_DIR)/%)
48843e1988Sjohnlev
49843e1988SjohnlevLINTS		= $(SPECIAL_OBJS:%.o=$(LINTS_DIR)/%.ln) \
50843e1988Sjohnlev		  $(CORE_OBJS:%.o=$(LINTS_DIR)/%.ln) \
51843e1988Sjohnlev		  $(KRTLD_OBJS:%.o=$(LINTS_DIR)/%.ln) \
52843e1988Sjohnlev		  $(MACH_NOT_YET_KMODS:%.o=$(LINTS_DIR)/%.ln) \
53843e1988Sjohnlev		  $(LINTS_DIR)/vers.ln \
54843e1988Sjohnlev		  $(LINTS_DIR)/modstubs.ln
55843e1988Sjohnlev
56843e1988SjohnlevROOTMODULE	= $(ROOT_PSM_KERN_DIR)/$(UNIX)
57843e1988Sjohnlev
58843e1988SjohnlevUNIX_BIN	= $(OBJS_DIR)/$(UNIX)
59843e1988Sjohnlev
60843e1988SjohnlevLIBS		= $(GENLIB)
61843e1988Sjohnlev
62843e1988SjohnlevGENUNIX		= genunix
63843e1988SjohnlevGENUNIX_DIR	= ../../intel/$(GENUNIX)
64843e1988Sjohnlev
65843e1988SjohnlevLIBOPTS		= -L $(GENUNIX_DIR)/$(OBJS_DIR) -l $(GENUNIX)
66843e1988Sjohnlev
67843e1988SjohnlevCTFEXTRAOBJS	= $(OBJS_DIR)/vers.o
68843e1988Sjohnlev
69843e1988SjohnlevDBOOT_OBJS_DIR	= dboot/$(OBJS_DIR)
70843e1988SjohnlevDBOOT_OBJECTS	= $(DBOOT_OBJS:%=$(DBOOT_OBJS_DIR)/%)
71843e1988SjohnlevDBOOT_BIN	= $(DBOOT_OBJS_DIR)/$(DBOOT)
72843e1988SjohnlevDBOOT_O		= $(OBJS_DIR)/$(DBOOT).o
73843e1988SjohnlevDBOOT_S		= $(DBOOT_O:%.o=%.s)
74843e1988SjohnlevDBOOT_LINTS	= $(DBOOT_OBJS:%.o=$(DBOOT_OBJS_DIR)/%.ln)
75843e1988SjohnlevDBOOT_LINT	= $(LINT_$(MACH)_$(CLASS))
76843e1988Sjohnlev
77843e1988Sjohnlev#
78843e1988Sjohnlev#	Include common rules.
79843e1988Sjohnlev#
80843e1988Sjohnlevinclude $(UTSBASE)/i86xpv/Makefile.i86xpv
81843e1988Sjohnlev
82843e1988Sjohnlev#
83843e1988Sjohnlev#	Define targets
84843e1988Sjohnlev#
85843e1988SjohnlevALL_TARGET	= $(UNIX_BIN)
86843e1988SjohnlevLINT_TARGET	= $(LINT_LIB) $(DBOOT_LINT_LIB)
87843e1988SjohnlevINSTALL_TARGET	= $(UNIX_BIN) $(ROOTMODULE)
88843e1988Sjohnlev
89843e1988Sjohnlev#
90843e1988Sjohnlev#	This is UNIX_DIR. Use a short path.
91843e1988Sjohnlev#
92843e1988SjohnlevUNIX_DIR	= .
93843e1988Sjohnlev
94843e1988Sjohnlev#
95843e1988Sjohnlev#	Overrides
96843e1988Sjohnlev#
97843e1988SjohnlevCLEANFILES	+=		\
98843e1988Sjohnlev	$(UNIX_O) $(MODSTUBS_O)	\
99843e1988Sjohnlev	$(OBJS_DIR)/vers.c $(OBJS_DIR)/vers.o \
100b6805bf7SGordon Ross	$(OBJS_DIR)/dtracestubs.s \
101843e1988Sjohnlev	$(DTRACESTUBS_O) $(DTRACESTUBS)
102843e1988Sjohnlev
103843e1988SjohnlevCLEANFILES	+=		\
104843e1988Sjohnlev	$(DBOOT_O) $(DBOOT_S)	\
105843e1988Sjohnlev	$(DBOOT_OBJECTS)	\
106843e1988Sjohnlev	$(DBOOT_BIN)
107843e1988Sjohnlev
108b6805bf7SGordon RossCLEANFILES	+=		\
109898c3fecSToomas Soome	$(DBOOT_OBJS_DIR)/$(VGATEXT_FONT).c \
110898c3fecSToomas Soome	$(OBJS_DIR)/$(VGATEXT_FONT).c
111898c3fecSToomas Soome
112898c3fecSToomas SoomeCLEANFILES	+=		\
113b6805bf7SGordon Ross	$(OBJS_DIR)/fb_swtch_src.o \
114b6805bf7SGordon Ross	$(OBJS_DIR)/fb_swtch_src \
115b6805bf7SGordon Ross	$(OBJS_DIR)/fb_swtch.s
116b6805bf7SGordon Ross
117b6805bf7SGordon RossCLEANFILES	+= \
118b6805bf7SGordon Ross	$(ZLIB_OBJS:%.o=$(OBJS_DIR)/%.o) \
119b6805bf7SGordon Ross	$(ZLIB_OBJS:%.o=$(OBJS_DIR)/%.ln)
120b6805bf7SGordon Ross
121843e1988SjohnlevCLOBBERFILES	= $(CLEANFILES) $(UNIX_BIN)
122843e1988SjohnlevCLEANLINTFILES	+= $(LINT_LIB) $(DBOOT_LINT_LIB) $(DBOOT_LINTS)
123843e1988Sjohnlev
124843e1988Sjohnlev# instr_size needs a special header
125843e1988Sjohnlev$(OBJS_DIR)/instr_size.o :=	EXTRA_OPTIONS	= -I$(SRC)/common/dis/i386
126843e1988Sjohnlev$(OBJS_DIR)/instr_size.ln :=	EXTRA_OPTIONS	= -I$(SRC)/common/dis/i386
127843e1988Sjohnlev
128843e1988SjohnlevCFLAGS += -DDIS_MEM
129843e1988Sjohnlev
130843e1988Sjohnlev#
131843e1988Sjohnlev# For now, disable these lint checks; maintainers should endeavor
132843e1988Sjohnlev# to investigate and remove these for maximum lint coverage.
133843e1988Sjohnlev# Please do not carry these forward to new Makefiles.
134843e1988Sjohnlev#
135843e1988SjohnlevLINTTAGS	+= -erroff=E_BAD_PTR_CAST_ALIGN
136843e1988SjohnlevLINTTAGS	+= -erroff=E_SUSPICIOUS_COMPARISON
137843e1988SjohnlevLINTTAGS	+= -erroff=E_SUPPRESSION_DIRECTIVE_UNUSED
138843e1988SjohnlevLINTTAGS	+= -erroff=E_STATIC_UNUSED
139843e1988SjohnlevLINTTAGS	+= -erroff=E_PTRDIFF_OVERFLOW
140843e1988SjohnlevLINTTAGS	+= -erroff=E_ASSIGN_NARROW_CONV
141843e1988Sjohnlev
1427014882cSRichard LoweCERRWARN	+= -_gcc=-Wno-parentheses
1437014882cSRichard LoweCERRWARN	+= -_gcc=-Wno-uninitialized
1447014882cSRichard LoweCERRWARN	+= -_gcc=-Wno-char-subscripts
1457014882cSRichard LoweCERRWARN	+= -_gcc=-Wno-unused-variable
1467014882cSRichard LoweCERRWARN	+= -_gcc=-Wno-unused-function
1477014882cSRichard LoweCERRWARN	+= -_gcc=-Wno-unused-label
1487014882cSRichard LoweCERRWARN	+= -_gcc=-Wno-type-limits
1497014882cSRichard LoweCERRWARN	+= -_gcc=-Wno-clobbered
1507014882cSRichard LoweCERRWARN	+= -_gcc=-Wno-unused-value
1517014882cSRichard LoweCERRWARN	+= -_gcc=-Wno-empty-body
1527014882cSRichard Lowe
153*b6b206fcSJohn Levon# needs work
154*b6b206fcSJohn LevonSMATCH=off
155*b6b206fcSJohn Levon
1568793b36bSNick Todd# Ensure that lint sees 'struct cpu' containing a fully declared
1578793b36bSNick Todd# embedded 'struct machcpu'
1588793b36bSNick Todd#
1598793b36bSNick ToddLINTFLAGS	+= -D_MACHDEP -I../../i86pc
1608793b36bSNick Todd
161843e1988Sjohnlev#
162843e1988Sjohnlev#	Default build targets.
163843e1988Sjohnlev#
164843e1988Sjohnlev.KEEP_STATE:
165843e1988Sjohnlev
166843e1988Sjohnlevdef: $(DEF_DEPS)
167843e1988Sjohnlev
168843e1988Sjohnlevall: $(ALL_DEPS)
169843e1988Sjohnlev
170843e1988Sjohnlevclean: $(CLEAN_DEPS)
171843e1988Sjohnlev
172843e1988Sjohnlevclobber: $(CLOBBER_DEPS)
173843e1988Sjohnlev
174843e1988Sjohnlevlint: $(LINT_DEPS)
175843e1988Sjohnlev
176843e1988Sjohnlevclean.lint: $(CLEAN_LINT_DEPS)
177843e1988Sjohnlev
178843e1988Sjohnlevinstall: $(INSTALL_DEPS)
179843e1988Sjohnlev
180843e1988SjohnlevMAPFILE_32 = $(MAPFILE)
181843e1988SjohnlevMAPFILE_64 = $(MAPFILE).amd64
182843e1988Sjohnlev
183843e1988SjohnlevMAPFILE_NAME = $(MAPFILE_$(CLASS))
184843e1988Sjohnlev
185843e1988Sjohnlev$(UNIX_BIN):	$(UNIX_O) $(MODSTUBS_O) $(MAPFILE_NAME) \
186843e1988Sjohnlev		$(GENLIB) $(DTRACESTUBS) $(DBOOT_O)
187843e1988Sjohnlev	$(LD) -dy -b -o $@ -e dboot_image -znointerp -M $(MAPFILE_NAME) \
188843e1988Sjohnlev	    $(UNIX_O) $(DBOOT_O) $(MODSTUBS_O) $(LIBOPTS) \
189843e1988Sjohnlev	    $(DTRACESTUBS)
190843e1988Sjohnlev	$(CTFMERGE_UNIQUIFY_AGAINST_GENUNIX)
191843e1988Sjohnlev	$(POST_PROCESS)
192843e1988Sjohnlev
193843e1988Sjohnlev$(UNIX_O):	$(OBJECTS) $(OBJS_DIR)/vers.o
194843e1988Sjohnlev	$(LD) -r -o $@ $(OBJECTS) $(OBJS_DIR)/vers.o
195843e1988Sjohnlev
196843e1988Sjohnlev$(DBOOT_BIN):	$(DBOOT_OBJS_DIR) $(DBOOT_OBJECTS) dboot/Mapfile.dboot
197843e1988Sjohnlev	$(LD) -dn -e _start -M dboot/Mapfile.dboot \
198843e1988Sjohnlev		-o $(DBOOT_BIN) $(DBOOT_OBJECTS)
199843e1988Sjohnlev
200843e1988Sjohnlev$(DBOOT_O):	$(DBOOT_BIN)
201843e1988Sjohnlev	@echo "	.data"					> $(DBOOT_S)
202843e1988Sjohnlev	@echo "	.globl	dboot_image"			>> $(DBOOT_S)
203843e1988Sjohnlev	@echo "dboot_image:"				>> $(DBOOT_S)
204843e1988Sjohnlev	$(ELFEXTRACT) $(DBOOT_BIN)			>> $(DBOOT_S)
205843e1988Sjohnlev	$(COMPILE.s) -o $(DBOOT_O) $(DBOOT_S)
206843e1988Sjohnlev
207843e1988Sjohnlev$(DBOOT_OBJS_DIR):
208843e1988Sjohnlev	-@mkdir -p $@ 2> /dev/null
209843e1988Sjohnlev
210843e1988Sjohnlev#
211843e1988Sjohnlev#	Special rules for generating assym.h for inclusion in assembly files.
212843e1988Sjohnlev#
213843e1988Sjohnlev$(DSF_DIR)/$(OBJS_DIR)/assym.h $(DSF_DIR)/$(OBJS_DIR)/kdi_assym.h:	FRC
214843e1988Sjohnlev	@cd $(DSF_DIR); $(MAKE) all.targ
215843e1988Sjohnlev
216843e1988Sjohnlev#
217843e1988Sjohnlev#	The global lint target builds the kernel lint library (llib-lunix.ln)
218843e1988Sjohnlev#	which is equivalent to a lint of /unix.o. Then all kernel modules for
219843e1988Sjohnlev#	this architecture are linted against the kernel lint library.
220843e1988Sjohnlev#
221843e1988Sjohnlev#	Note:	lint errors in the kernel lint library will be repeated for
222843e1988Sjohnlev#		each module. It is important that the kernel lint library
223843e1988Sjohnlev#		be clean to keep the textual output to a reasonable level.
224843e1988Sjohnlev#
225843e1988Sjohnlev
226843e1988Sjohnlev$(LINT_LIB):	$(LINT_LIB_DIR) $(LINTS)
22798157a70Sakolb	@pwd
228843e1988Sjohnlev	@-$(ECHO) "\n$(UNIX): (library construction):"
229843e1988Sjohnlev	@$(LINT) -o$(UNIX) $(LINTFLAGS) $(LINTS)
230843e1988Sjohnlev	@$(MV) $(@F) $@
231843e1988Sjohnlev
232843e1988Sjohnlev$(DBOOT_LINT_LIB):	$(LINT_LIB_DIR) $(DBOOT_LINTS)
23398157a70Sakolb	@pwd
234843e1988Sjohnlev	@-$(ECHO) "\n$(DBOOT): (library construction):"
235843e1988Sjohnlev	@$(LINT) -o$(DBOOT) $(DBOOT_LINTFLAGS) $(DBOOT_LINTS)
236843e1988Sjohnlev	@$(MV) $(@F) $@
237843e1988Sjohnlev
238843e1988Sjohnlevlintlib:	$(LINT_DEPS)
239843e1988Sjohnlev
240843e1988Sjohnlev#
241843e1988Sjohnlev#	Include common targets.
242843e1988Sjohnlev#
243843e1988Sjohnlevinclude $(UTSBASE)/i86xpv/Makefile.targ
244