xref: /titanic_50/usr/src/uts/i86pc/Makefile.rules (revision d2670fc40c4567a1426992012f9a8666e3fa1098)
17c478bd9Sstevel@tonic-gate#
27c478bd9Sstevel@tonic-gate# CDDL HEADER START
37c478bd9Sstevel@tonic-gate#
47c478bd9Sstevel@tonic-gate# The contents of this file are subject to the terms of the
54ab75253Smrj# Common Development and Distribution License (the "License").
64ab75253Smrj# You may not use this file except in compliance with the License.
77c478bd9Sstevel@tonic-gate#
87c478bd9Sstevel@tonic-gate# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
97c478bd9Sstevel@tonic-gate# or http://www.opensolaris.org/os/licensing.
107c478bd9Sstevel@tonic-gate# See the License for the specific language governing permissions
117c478bd9Sstevel@tonic-gate# and limitations under the License.
127c478bd9Sstevel@tonic-gate#
137c478bd9Sstevel@tonic-gate# When distributing Covered Code, include this CDDL HEADER in each
147c478bd9Sstevel@tonic-gate# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
157c478bd9Sstevel@tonic-gate# If applicable, add the following below this CDDL HEADER, with the
167c478bd9Sstevel@tonic-gate# fields enclosed by brackets "[]" replaced with your own identifying
177c478bd9Sstevel@tonic-gate# information: Portions Copyright [yyyy] [name of copyright owner]
187c478bd9Sstevel@tonic-gate#
197c478bd9Sstevel@tonic-gate# CDDL HEADER END
207c478bd9Sstevel@tonic-gate#
214ab75253Smrj
227c478bd9Sstevel@tonic-gate#
235cd376e8SJimmy Vetayases# Copyright (c) 1992, 2010, Oracle and/or its affiliates. All rights reserved.
247b07063dSIgor Kozhukhov# Copyright 2015 Igor Kozhukhov <ikozhukhov@gmail.com>
257c478bd9Sstevel@tonic-gate#
267c478bd9Sstevel@tonic-gate
277c478bd9Sstevel@tonic-gate#	This Makefile defines the build rules for the directory uts/i86pc
287c478bd9Sstevel@tonic-gate#	and its children. These are the source files which are i86pc
297c478bd9Sstevel@tonic-gate#	"implementation architecture" dependent.
307c478bd9Sstevel@tonic-gate#
317c478bd9Sstevel@tonic-gate#	The following two-level ordering must be maintained in this file.
327c478bd9Sstevel@tonic-gate#	  Lines are sorted first in order of decreasing specificity based on
33eb0cc229Sedp#	  the first directory component.  That is, i86pc rules come before
34eb0cc229Sedp#	  intel rules come before common rules.
357c478bd9Sstevel@tonic-gate#
367c478bd9Sstevel@tonic-gate#	  Lines whose initial directory components are equal are sorted
377c478bd9Sstevel@tonic-gate#	  alphabetically by the remaining components.
387c478bd9Sstevel@tonic-gate
397c478bd9Sstevel@tonic-gate#
407c478bd9Sstevel@tonic-gate#	Section 1a: C object build rules
417c478bd9Sstevel@tonic-gate#
427c478bd9Sstevel@tonic-gate$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/conf/%.c
437c478bd9Sstevel@tonic-gate	$(COMPILE.c) -o $@ $<
447c478bd9Sstevel@tonic-gate	$(CTFCONVERT_O)
457c478bd9Sstevel@tonic-gate
467aec1d6eScindi$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/cpu/amd_opteron/%.c
477aec1d6eScindi	$(COMPILE.c) -o $@ $<
487aec1d6eScindi	$(CTFCONVERT_O)
497aec1d6eScindi
5020c794b3Sgavinm$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/cpu/authenticamd/%.c
5120c794b3Sgavinm	$(COMPILE.c) -o $@ $<
5220c794b3Sgavinm	$(CTFCONVERT_O)
537aec1d6eScindi
547aec1d6eScindi$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/cpu/generic_cpu/%.c
557aec1d6eScindi	$(COMPILE.c) -o $@ $<
567aec1d6eScindi	$(CTFCONVERT_O)
577aec1d6eScindi
5820c794b3Sgavinm$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/cpu/genuineintel/%.c
5920c794b3Sgavinm	$(COMPILE.c) -o $@ $<
6020c794b3Sgavinm	$(CTFCONVERT_O)
6120c794b3Sgavinm
627c478bd9Sstevel@tonic-gate$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/%.c
637c478bd9Sstevel@tonic-gate	$(COMPILE.c) -o $@ $<
647c478bd9Sstevel@tonic-gate	$(CTFCONVERT_O)
657c478bd9Sstevel@tonic-gate
66d2ec54f7Sphitran$(OBJS_DIR)/%.o:                $(UTSBASE)/i86pc/io/acpi_drv/%.c
677b840e52Sphitran	$(COMPILE.c) -o $@ $<
687b840e52Sphitran	$(CTFCONVERT_O)
697b840e52Sphitran
70eca2601cSRandy Fishel$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/fipe/%.c
71eca2601cSRandy Fishel	$(COMPILE.c) -o $@ $<
72eca2601cSRandy Fishel	$(CTFCONVERT_O)
73eca2601cSRandy Fishel
74b72d5b75SMichael Corcoran$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/acpi/acpidev/%.c
75b72d5b75SMichael Corcoran	$(COMPILE.c) -o $@ $<
76b72d5b75SMichael Corcoran	$(CTFCONVERT_O)
77b72d5b75SMichael Corcoran
78b72d5b75SMichael Corcoran$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/acpi/acpinex/%.c
79b72d5b75SMichael Corcoran	$(COMPILE.c) -o $@ $<
80b72d5b75SMichael Corcoran	$(CTFCONVERT_O)
81b72d5b75SMichael Corcoran
82a3114836SGerry LiuSBD_IOCTL	= $(UTSBASE)/i86pc/sys/sbd_ioctl.h
83a3114836SGerry LiuDRMACH_IO	= $(UTSBASE)/i86pc/io/acpi/drmach_acpi
84a3114836SGerry LiuDRMACH_GENERR	= $(DRMACH_IO)/sbdgenerr
85a3114836SGerry LiuDR_IO		= $(UTSBASE)/i86pc/io/dr
86a3114836SGerry LiuDR_GENERR	= $(DR_IO)/sbdgenerr
87a3114836SGerry Liu
88a3114836SGerry Liu$(DRMACH_GENERR):	$(DR_IO)/sbdgenerr.pl
89a3114836SGerry Liu	$(RM) $@
90a3114836SGerry Liu	$(CAT) $(DR_IO)/sbdgenerr.pl > $@
91a3114836SGerry Liu	$(CHMOD) +x $@
92a3114836SGerry Liu
93a3114836SGerry Liu$(DRMACH_IO)/drmach_err.c:	$(DRMACH_GENERR) $(SBD_IOCTL)
94a3114836SGerry Liu	$(RM) $@
95a3114836SGerry Liu	$(DRMACH_GENERR) EX86 < $(SBD_IOCTL) > $(DRMACH_IO)/drmach_err.c
96a3114836SGerry Liu
97a3114836SGerry Liu$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/acpi/drmach_acpi/%.c
98a3114836SGerry Liu	$(COMPILE.c) -o $@ $<
99a3114836SGerry Liu	$(CTFCONVERT_O)
100a3114836SGerry Liu
1016732dbb3SVikram Hegde$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/amd_iommu/%.c
1026732dbb3SVikram Hegde	$(COMPILE.c) -o $@ $<
1036732dbb3SVikram Hegde	$(CTFCONVERT_O)
1046732dbb3SVikram Hegde
105a3114836SGerry Liu$(DR_GENERR):			$(DR_IO)/sbdgenerr.pl
106a3114836SGerry Liu	$(RM) $@
107a3114836SGerry Liu	$(CAT) $(DR_IO)/sbdgenerr.pl > $@
108a3114836SGerry Liu	$(CHMOD) +x $@
109a3114836SGerry Liu
110a3114836SGerry Liu$(DR_IO)/dr_err.c:		$(DR_GENERR) $(SBD_IOCTL)
111a3114836SGerry Liu	$(RM) $@
112a3114836SGerry Liu	$(DR_GENERR) ESBD < $(SBD_IOCTL) > $(DR_IO)/dr_err.c
113a3114836SGerry Liu
114a3114836SGerry Liu$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/dr/%.c
115a3114836SGerry Liu	$(COMPILE.c) -o $@ $<
116a3114836SGerry Liu	$(CTFCONVERT_O)
117a3114836SGerry Liu
11817169044Sbrutus$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/ioat/%.c
11917169044Sbrutus	$(COMPILE.c) -o $@ $<
12017169044Sbrutus	$(CTFCONVERT_O)
12117169044Sbrutus
1227c478bd9Sstevel@tonic-gate$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/pci/%.c
1237c478bd9Sstevel@tonic-gate	$(COMPILE.c) -o $@ $<
1247c478bd9Sstevel@tonic-gate	$(CTFCONVERT_O)
1257c478bd9Sstevel@tonic-gate
12670025d76Sjohnny$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/pciex/%.c
12770025d76Sjohnny	$(COMPILE.c) -o $@ $<
12870025d76Sjohnny	$(CTFCONVERT_O)
12970025d76Sjohnny
13026947304SEvan Yan$(OBJS_DIR)/%.o:		$(UTSBASE)/intel/io/pciex/hotplug/%.c
13126947304SEvan Yan	$(COMPILE.c) -o $@ $<
13226947304SEvan Yan	$(CTFCONVERT_O)
13326947304SEvan Yan
1347c478bd9Sstevel@tonic-gate$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/pcplusmp/%.c
1357c478bd9Sstevel@tonic-gate	$(COMPILE.c) -o $@ $<
1367c478bd9Sstevel@tonic-gate	$(CTFCONVERT_O)
1377c478bd9Sstevel@tonic-gate
1387c478bd9Sstevel@tonic-gate$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/pcplusmp/%.s
1397c478bd9Sstevel@tonic-gate	$(COMPILE.s) -o $@ $<
1407c478bd9Sstevel@tonic-gate
1417ff178cdSJimmy Vetayases$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/apix/%.c
1427ff178cdSJimmy Vetayases	$(COMPILE.c) -o $@ $<
1437ff178cdSJimmy Vetayases	$(CTFCONVERT_O)
1447ff178cdSJimmy Vetayases
1452df1fe9cSrandyf$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/ppm/%.c
1462df1fe9cSrandyf	$(COMPILE.c) -o $@ $<
1472df1fe9cSrandyf	$(CTFCONVERT_O)
1482df1fe9cSrandyf
1492df1fe9cSrandyf$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/ppm/%.s
1502df1fe9cSrandyf	$(COMPILE.s) -o $@ $<
1512df1fe9cSrandyf
1527c478bd9Sstevel@tonic-gate$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/psm/%.c
1537c478bd9Sstevel@tonic-gate	$(COMPILE.c) -o $@ $<
1547c478bd9Sstevel@tonic-gate	$(CTFCONVERT_O)
1557c478bd9Sstevel@tonic-gate
1567c478bd9Sstevel@tonic-gate$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/psm/%.s
1577c478bd9Sstevel@tonic-gate	$(COMPILE.s) -o $@ $<
1587c478bd9Sstevel@tonic-gate
1592bda830bSap25164$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/tzmon/%.c
1602bda830bSap25164	$(COMPILE.c) -o $@ $<
1612bda830bSap25164	$(CTFCONVERT_O)
1622bda830bSap25164
1637c478bd9Sstevel@tonic-gate$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/ml/%.s
1647c478bd9Sstevel@tonic-gate	$(COMPILE.s) -o $@ $<
1657c478bd9Sstevel@tonic-gate
1667c478bd9Sstevel@tonic-gate$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/os/%.c
1676a59053bSAlex Wilson	$(COMPILE.c) -_gcc=-fno-stack-protector -o $@ $<
1687c478bd9Sstevel@tonic-gate	$(CTFCONVERT_O)
1697c478bd9Sstevel@tonic-gate
1700e751525SEric Saxe$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/os/cpupm/%.c
1710e751525SEric Saxe	$(COMPILE.c) -o $@ $<
1720e751525SEric Saxe	$(CTFCONVERT_O)
1730e751525SEric Saxe
174ae115bc7Smrj$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/boot/%.c
175ae115bc7Smrj	$(COMPILE.c) -o $@ $<
176ae115bc7Smrj	$(CTFCONVERT_O)
177ae115bc7Smrj
1787c478bd9Sstevel@tonic-gate$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/vm/%.c
1797c478bd9Sstevel@tonic-gate	$(COMPILE.c) -o $@ $<
1807c478bd9Sstevel@tonic-gate	$(CTFCONVERT_O)
1817c478bd9Sstevel@tonic-gate
1827c478bd9Sstevel@tonic-gate$(OBJS_DIR)/%.o:		$(UTSBASE)/common/io/%.c
1837c478bd9Sstevel@tonic-gate	$(COMPILE.c) -o $@ $<
1847c478bd9Sstevel@tonic-gate	$(CTFCONVERT_O)
1857c478bd9Sstevel@tonic-gate
1865cff7825Smh27603$(OBJS_DIR)/%.o:		$(UTSBASE)/common/io/ppm/%.c
1875cff7825Smh27603	$(COMPILE.c) -o $@ $<
1885cff7825Smh27603	$(CTFCONVERT_O)
1895cff7825Smh27603
190c0da6274SZhi-Jun Robin Fu$(OBJS_DIR)/%.o:		$(UTSBASE)/common/io/pciex/%.c
191c0da6274SZhi-Jun Robin Fu	$(COMPILE.c) -o $@ $<
192c0da6274SZhi-Jun Robin Fu	$(CTFCONVERT_O)
193c0da6274SZhi-Jun Robin Fu
1947c478bd9Sstevel@tonic-gate$(OBJS_DIR)/%.o:		$(UTSBASE)/common/os/%.c
1957c478bd9Sstevel@tonic-gate	$(COMPILE.c) -o $@ $<
1967c478bd9Sstevel@tonic-gate	$(CTFCONVERT_O)
1977c478bd9Sstevel@tonic-gate
1987c478bd9Sstevel@tonic-gate$(OBJS_DIR)/%.o:		$(SRC)/common/dis/i386/%.c
1997c478bd9Sstevel@tonic-gate	$(COMPILE.c) -o $@ $<
2007c478bd9Sstevel@tonic-gate	$(CTFCONVERT_O)
2017c478bd9Sstevel@tonic-gate
202fc1821feSrugrat$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/gfx_private/%.c
203fc1821feSrugrat	$(COMPILE.c) -o $@ $<
204fc1821feSrugrat	$(CTFCONVERT_O)
205fc1821feSrugrat
206ae115bc7Smrj$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/io/xsvc/%.c
20760405de4Skz151634	$(COMPILE.c) -o $@ $<
20860405de4Skz151634	$(CTFCONVERT_O)
20960405de4Skz151634
210349b53ddSStuart Maybee$(OBJS_DIR)/%.o:		$(UTSBASE)/common/xen/os/%.c
211349b53ddSStuart Maybee	$(COMPILE.c) -o $@ $<
212349b53ddSStuart Maybee	$(CTFCONVERT_O)
213349b53ddSStuart Maybee
214*d2670fc4SToomas Soome$(OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/dboot/%.c
215*d2670fc4SToomas Soome	$(COMPILE.c) -o $@ $<
216*d2670fc4SToomas Soome	$(CTFCONVERT_O)
217*d2670fc4SToomas Soome
218ae115bc7Smrj#
219ae115bc7Smrj# dboot stuff is always 32 bit, linked to run with phys_addr == virt_addr
220ae115bc7Smrj#
221ae115bc7SmrjDBOOT_OBJS_DIR	= dboot/$(OBJS_DIR)
222ae115bc7SmrjDBOOT_MACH_32	= -D_BOOT_TARGET_i386
223ae115bc7SmrjDBOOT_MACH_64	= -D_BOOT_TARGET_amd64
224ae115bc7SmrjDBOOT_DEFS	= -D_BOOT $(DBOOT_MACH_$(CLASS))
225ae115bc7SmrjDBOOT_DEFS	+= -D_MACHDEP -D_KMEMUSER -U_KERNEL -D_I32LPx
2267f11fd00SRichard LoweDBOOT_FLAGS	= $(CCVERBOSE) $(C99MODE) $(CERRWARN) $(CCNOAUTOINLINE)
22760405de4Skz151634
2280181461bSKeith M WesolowskiDBOOT_CC_INCL	= -I$(SRC)/common -I$(SRC)/common/util $(INCLUDE_PATH)
229ae115bc7SmrjDBOOT_AS_INCL	= $(AS_INC_PATH)
230ae115bc7Smrj
231ae115bc7SmrjDBOOT_AS	= $(ONBLD_TOOLS)/bin/$(MACH)/aw
232ae115bc7Smrj
233ae115bc7SmrjDBOOT_LINTS_DIR	= $(DBOOT_OBJS_DIR)
234ae115bc7SmrjDBOOT_LINTFLAGS_i86pc	= $(LINTFLAGS_i386_32) $(LINTTAGS_i386_32)
235ae115bc7Smrj
236843e1988SjohnlevDBOOT_LINTFLAGS = $(DBOOT_LINTFLAGS_$(PLATFORM)) $(LINTTAGS) $(C99LMODE) \
237843e1988Sjohnlev	$(CPPFLAGS) $(DBOOT_DEFS)
238ae115bc7SmrjDBOOT_LOCAL_LINTFLAGS   = -c -dirout=$(DBOOT_LINTS_DIR) -I$(SRC)/common \
239adb91f47Srscott	$(DBOOT_LINTFLAGS) $(DBOOT_LINTTAGS)
240ae115bc7Smrj
241ae115bc7Smrj$(DBOOT_OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/boot/%.c
2426a3e8e86SRichard Lowe	$(i386_CC) $(DBOOT_FLAGS) -O $(DBOOT_DEFS) $(DBOOT_CC_INCL) -c -o $@ $<
243ae115bc7Smrj
244ae115bc7Smrj$(DBOOT_OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/dboot/%.c
2456a3e8e86SRichard Lowe	$(i386_CC) $(DBOOT_FLAGS) -O $(DBOOT_DEFS) $(DBOOT_CC_INCL) -c -o $@ $<
246ae115bc7Smrj
247551bc2a6Smrj$(DBOOT_OBJS_DIR)/%.o:		$(UTSBASE)/intel/ia32/%.s
248551bc2a6Smrj	$(DBOOT_AS) -P -D_ASM $(DBOOT_DEFS) $(DBOOT_AS_INCL) -o $@ $<
249551bc2a6Smrj
250e65d07eeSKeith Wesolowski$(DBOOT_OBJS_DIR)/%.o:		$(COMMONBASE)/crypto/sha1/%.c
2517f11fd00SRichard Lowe	$(i386_CC) $(DBOOT_FLAGS) -O $(DBOOT_DEFS) $(DBOOT_CC_INCL) -c -o $@ $<
252e65d07eeSKeith Wesolowski
253ae115bc7Smrj$(DBOOT_OBJS_DIR)/%.o:		$(COMMONBASE)/util/%.c
2546a3e8e86SRichard Lowe	$(i386_CC) $(DBOOT_FLAGS) -O $(DBOOT_DEFS) $(DBOOT_CC_INCL) -c -o $@ $<
255ae115bc7Smrj
256ae115bc7Smrj$(DBOOT_OBJS_DIR)/%.o:		$(COMMONBASE)/util/i386/%.s
257ae115bc7Smrj	$(DBOOT_AS) -P -D_ASM $(DBOOT_DEFS) $(DBOOT_AS_INCL) -o $@ $<
258ae115bc7Smrj
259ae115bc7Smrj$(DBOOT_OBJS_DIR)/%.o:		$(UTSBASE)/i86pc/dboot/%.s
260ae115bc7Smrj	$(DBOOT_AS) -P -D_ASM $(DBOOT_DEFS) $(DBOOT_AS_INCL) -o $@ $<
261ae115bc7Smrj
262ae115bc7Smrj#
263ae115bc7Smrj# Stuff to build bios_call.o for the kernel.
264ae115bc7Smrj#
265ae115bc7SmrjMAPFILE_BIOS	= $(UTSBASE)/i86pc/conf/Mapfile.bios
266ae115bc7Smrj$(OBJS_DIR)/bios_call.o:    $(UTSBASE)/i86pc/ml/bios_call_src.s
267ae115bc7Smrj	$(COMPILE.s) -o $(OBJS_DIR)/bios_call_src.o \
268ae115bc7Smrj		$(UTSBASE)/i86pc/ml/bios_call_src.s
269ae115bc7Smrj	$(LD) -dn -M $(MAPFILE_BIOS)  \
270ae115bc7Smrj		-o $(OBJS_DIR)/bios_call_src $(OBJS_DIR)/bios_call_src.o
271ae115bc7Smrj	@echo "  .data"				> $(OBJS_DIR)/bios_call.s
272ae115bc7Smrj	@echo "  .globl bios_image"		>> $(OBJS_DIR)/bios_call.s
273ae115bc7Smrj	@echo "bios_image:"			>> $(OBJS_DIR)/bios_call.s
274ae115bc7Smrj	$(ELFEXTRACT) $(OBJS_DIR)/bios_call_src	>> $(OBJS_DIR)/bios_call.s
275ae115bc7Smrj	@echo "  .align 4"			>> $(OBJS_DIR)/bios_call.s
276ae115bc7Smrj	@echo "  .globl bios_size"		>> $(OBJS_DIR)/bios_call.s
277ae115bc7Smrj	@echo "bios_size:"			>> $(OBJS_DIR)/bios_call.s
278ae115bc7Smrj	@echo "  .long . - bios_image"		>> $(OBJS_DIR)/bios_call.s
279ae115bc7Smrj	$(COMPILE.s) -o $@ $(OBJS_DIR)/bios_call.s
28060405de4Skz151634
28119397407SSherry Moore#
28219397407SSherry Moore# Stuff to build fb_swtch.o for the kernel.
28319397407SSherry Moore#
28419397407SSherry MooreMAPFILE_FBSWTCH	= $(UTSBASE)/i86pc/conf/Mapfile.fb_swtch
28519397407SSherry Moore$(OBJS_DIR)/fb_swtch.o:    $(UTSBASE)/i86pc/ml/fb_swtch_src.s
28619397407SSherry Moore	$(COMPILE.s) -o $(OBJS_DIR)/fb_swtch_src.o \
28719397407SSherry Moore		$(UTSBASE)/i86pc/ml/fb_swtch_src.s
28819397407SSherry Moore	$(LD) -dn -M $(MAPFILE_FBSWTCH)  \
28919397407SSherry Moore		-o $(OBJS_DIR)/fb_swtch_src $(OBJS_DIR)/fb_swtch_src.o
29019397407SSherry Moore	@echo "  .data"				> $(OBJS_DIR)/fb_swtch.s
29119397407SSherry Moore	@echo "  .globl fb_swtch_image"		>> $(OBJS_DIR)/fb_swtch.s
29219397407SSherry Moore	@echo "fb_swtch_image:"			>> $(OBJS_DIR)/fb_swtch.s
29319397407SSherry Moore	$(ELFEXTRACT) $(OBJS_DIR)/fb_swtch_src	>> $(OBJS_DIR)/fb_swtch.s
29419397407SSherry Moore	@echo "  .align 4"			>> $(OBJS_DIR)/fb_swtch.s
29519397407SSherry Moore	@echo "  .globl fb_swtch_size"		>> $(OBJS_DIR)/fb_swtch.s
29619397407SSherry Moore	@echo "fb_swtch_size:"			>> $(OBJS_DIR)/fb_swtch.s
29719397407SSherry Moore	@echo "  .long . - fb_swtch_image"	>> $(OBJS_DIR)/fb_swtch.s
29819397407SSherry Moore	$(COMPILE.s) -o $@ $(OBJS_DIR)/fb_swtch.s
29919397407SSherry Moore
3007c478bd9Sstevel@tonic-gate# ridiculous contortions ---
3017c478bd9Sstevel@tonic-gateATOMIC_SUBDIR_32	= i386
3027c478bd9Sstevel@tonic-gateATOMIC_SUBDIR_64	= amd64
3037c478bd9Sstevel@tonic-gateATOMIC_SUBDIR		= $(ATOMIC_SUBDIR_$(CLASS))
3047c478bd9Sstevel@tonic-gate
3057c478bd9Sstevel@tonic-gate$(OBJS_DIR)/%.o:		$(SRC)/common/atomic/$(ATOMIC_SUBDIR)/%.s
3067c478bd9Sstevel@tonic-gate	$(COMPILE.s) -o $@ $<
3077c478bd9Sstevel@tonic-gate
308ae115bc7Smrj#
309ae115bc7Smrj# dtrace stubs
310ae115bc7Smrj#
31130082d0cSmyers
3127c478bd9Sstevel@tonic-gate$(OBJS_DIR)/dtracestubs.s:	$(UNIX_O) $(LIBS)
313620753d0Sjmcp	$(NM) -u $(UNIX_O) $(LIBS) | $(GREP) __dtrace_probe_ | $(SORT) | \
3147b07063dSIgor Kozhukhov	    $(UNIQ) | $(AWK) '{ \
3157c478bd9Sstevel@tonic-gate	    printf("\t.globl %s\n\t.type %s,@function\n%s:\n", \
3167c478bd9Sstevel@tonic-gate	    $$1, $$1, $$1); }' > $(OBJS_DIR)/dtracestubs.s
3177c478bd9Sstevel@tonic-gate
3187c478bd9Sstevel@tonic-gate$(DTRACESTUBS):	$(DTRACESTUBS_O)
31902e56f3fSwesolows	$(BUILD.SO) $(DTRACESTUBS_O)
3207c478bd9Sstevel@tonic-gate
3217c478bd9Sstevel@tonic-gate#
3227c478bd9Sstevel@tonic-gate#	Section 1b: Lint `object' build rules
3237c478bd9Sstevel@tonic-gate#
3247c478bd9Sstevel@tonic-gate$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/conf/%.c
3257c478bd9Sstevel@tonic-gate	@($(LHEAD) $(LINT.c) $< $(LTAIL))
3267c478bd9Sstevel@tonic-gate
3277aec1d6eScindi$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/cpu/amd_opteron/%.c
3287aec1d6eScindi	@($(LHEAD) $(LINT.c) $< $(LTAIL))
3297aec1d6eScindi
33020c794b3Sgavinm$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/cpu/authenticamd/%.c
33120c794b3Sgavinm	@($(LHEAD) $(LINT.c) $< $(LTAIL))
3327aec1d6eScindi
3337aec1d6eScindi$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/cpu/generic_cpu/%.c
3347aec1d6eScindi	@($(LHEAD) $(LINT.c) $< $(LTAIL))
3357aec1d6eScindi
33620c794b3Sgavinm$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/cpu/genuineintel/%.c
33720c794b3Sgavinm	@($(LHEAD) $(LINT.c) $< $(LTAIL))
33820c794b3Sgavinm
3397c478bd9Sstevel@tonic-gate$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/%.c
3407c478bd9Sstevel@tonic-gate	@($(LHEAD) $(LINT.c) $< $(LTAIL))
3417c478bd9Sstevel@tonic-gate
342d2ec54f7Sphitran$(LINTS_DIR)/%.ln:              $(UTSBASE)/i86pc/io/acpi_drv/%.c
3437b840e52Sphitran	@($(LHEAD) $(LINT.c) $< $(LTAIL))
3447b840e52Sphitran
345eca2601cSRandy Fishel$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/fipe/%.c
346eca2601cSRandy Fishel	@($(LHEAD) $(LINT.c) $< $(LTAIL))
347eca2601cSRandy Fishel
348b72d5b75SMichael Corcoran$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/acpi/acpidev/%.c
349b72d5b75SMichael Corcoran	@($(LHEAD) $(LINT.c) $< $(LTAIL))
350b72d5b75SMichael Corcoran
351b72d5b75SMichael Corcoran$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/acpi/acpinex/%.c
352b72d5b75SMichael Corcoran	@($(LHEAD) $(LINT.c) $< $(LTAIL))
353b72d5b75SMichael Corcoran
354a3114836SGerry Liu$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/acpi/drmach_acpi/%.c
355a3114836SGerry Liu	@($(LHEAD) $(LINT.c) $< $(LTAIL))
356a3114836SGerry Liu
3576732dbb3SVikram Hegde$(LINTS_DIR)/%.ln:              $(UTSBASE)/i86pc/io/amd_iommu/%.c
3586732dbb3SVikram Hegde	@($(LHEAD) $(LINT.c) $< $(LTAIL))
3596732dbb3SVikram Hegde
360a3114836SGerry Liu$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/dr/%.c
361a3114836SGerry Liu	@($(LHEAD) $(LINT.c) $< $(LTAIL))
362a3114836SGerry Liu
36317169044Sbrutus$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/ioat/%.c
36417169044Sbrutus	@($(LHEAD) $(LINT.c) $< $(LTAIL))
36517169044Sbrutus
3667c478bd9Sstevel@tonic-gate$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/pci/%.c
3677c478bd9Sstevel@tonic-gate	@($(LHEAD) $(LINT.c) $< $(LTAIL))
3687c478bd9Sstevel@tonic-gate
36970025d76Sjohnny$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/pciex/%.c
37070025d76Sjohnny	@($(LHEAD) $(LINT.c) $< $(LTAIL))
37170025d76Sjohnny
37226947304SEvan Yan$(LINTS_DIR)/%.ln:		$(UTSBASE)/intel/io/pciex/hotplug/%.c
37326947304SEvan Yan	@($(LHEAD) $(LINT.c) $< $(LTAIL))
37426947304SEvan Yan
3757c478bd9Sstevel@tonic-gate$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/pcplusmp/%.c
3767c478bd9Sstevel@tonic-gate	@($(LHEAD) $(LINT.c) $< $(LTAIL))
3777c478bd9Sstevel@tonic-gate
3787c478bd9Sstevel@tonic-gate$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/pcplusmp/%.s
3797c478bd9Sstevel@tonic-gate	@($(LHEAD) $(LINT.s) $< $(LTAIL))
3807c478bd9Sstevel@tonic-gate
3817ff178cdSJimmy Vetayases$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/apix/%.c
3827ff178cdSJimmy Vetayases	@($(LHEAD) $(LINT.c) $< $(LTAIL))
3837ff178cdSJimmy Vetayases
3847ff178cdSJimmy Vetayases$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/apix/%.s
3857ff178cdSJimmy Vetayases	@($(LHEAD) $(LINT.s) $< $(LTAIL))
3867ff178cdSJimmy Vetayases
3872df1fe9cSrandyf$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/ppm/%.c
3882df1fe9cSrandyf	@($(LHEAD) $(LINT.c) $< $(LTAIL))
3892df1fe9cSrandyf
3902df1fe9cSrandyf$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/ppm/%.s
3912df1fe9cSrandyf	@($(LHEAD) $(LINT.s) $< $(LTAIL))
3922df1fe9cSrandyf
3937c478bd9Sstevel@tonic-gate$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/psm/%.c
3947c478bd9Sstevel@tonic-gate	@($(LHEAD) $(LINT.c) $< $(LTAIL))
3957c478bd9Sstevel@tonic-gate
3967c478bd9Sstevel@tonic-gate$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/psm/%.s
3977c478bd9Sstevel@tonic-gate	@($(LHEAD) $(LINT.s) $< $(LTAIL))
3987c478bd9Sstevel@tonic-gate
3992bda830bSap25164$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/tzmon/%.c
4002bda830bSap25164	@($(LHEAD) $(LINT.c) $< $(LTAIL))
4012bda830bSap25164
4027c478bd9Sstevel@tonic-gate$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/ml/%.s
4037c478bd9Sstevel@tonic-gate	@($(LHEAD) $(LINT.s) $< $(LTAIL))
4047c478bd9Sstevel@tonic-gate
4057c478bd9Sstevel@tonic-gate$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/os/%.c
4067c478bd9Sstevel@tonic-gate	@($(LHEAD) $(LINT.c) $< $(LTAIL))
4077c478bd9Sstevel@tonic-gate
4080e751525SEric Saxe$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/os/cpupm/%.c
4090e751525SEric Saxe	@($(LHEAD) $(LINT.c) $< $(LTAIL))
4100e751525SEric Saxe
411ae115bc7Smrj$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/boot/%.c
412ae115bc7Smrj	@($(LHEAD) $(LINT.c) $< $(LTAIL))
413ae115bc7Smrj
414*d2670fc4SToomas Soome$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/dboot/%.c
415*d2670fc4SToomas Soome	@($(LHEAD) $(LINT.c) $< $(LTAIL))
416*d2670fc4SToomas Soome
4177c478bd9Sstevel@tonic-gate$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/vm/%.c
4187c478bd9Sstevel@tonic-gate	@($(LHEAD) $(LINT.c) $< $(LTAIL))
4197c478bd9Sstevel@tonic-gate
4207c478bd9Sstevel@tonic-gate$(LINTS_DIR)/%.ln:		$(UTSBASE)/common/io/%.c
4217c478bd9Sstevel@tonic-gate	@($(LHEAD) $(LINT.c) $< $(LTAIL))
4227c478bd9Sstevel@tonic-gate
4235cff7825Smh27603$(LINTS_DIR)/%.ln:		$(UTSBASE)/common/io/ppm/%.c
4245cff7825Smh27603	@($(LHEAD) $(LINT.c) $< $(LTAIL))
4255cff7825Smh27603
426c0da6274SZhi-Jun Robin Fu$(LINTS_DIR)/%.ln:		$(UTSBASE)/common/io/pciex/%.c
427c0da6274SZhi-Jun Robin Fu	@($(LHEAD) $(LINT.c) $< $(LTAIL))
428c0da6274SZhi-Jun Robin Fu
4297c478bd9Sstevel@tonic-gate$(LINTS_DIR)/%.ln:		$(UTSBASE)/common/os/%.c
4307c478bd9Sstevel@tonic-gate	@($(LHEAD) $(LINT.c) $< $(LTAIL))
4317c478bd9Sstevel@tonic-gate
4327c478bd9Sstevel@tonic-gate$(LINTS_DIR)/%.ln:		$(SRC)/common/dis/i386/%.c
4337c478bd9Sstevel@tonic-gate	@($(LHEAD) $(LINT.c) $< $(LTAIL))
4347c478bd9Sstevel@tonic-gate
4357c478bd9Sstevel@tonic-gate$(LINTS_DIR)/%.ln:		$(SRC)/common/atomic/%.c
4367c478bd9Sstevel@tonic-gate	@($(LHEAD) $(LINT.c) $< $(LTAIL))
4377c478bd9Sstevel@tonic-gate
438fc1821feSrugrat$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/gfx_private/%.c
439fc1821feSrugrat	@($(LHEAD) $(LINT.c) $< $(LTAIL))
440fc1821feSrugrat
441ae115bc7Smrj$(LINTS_DIR)/%.ln:		$(UTSBASE)/i86pc/io/xsvc/%.c
44260405de4Skz151634	@($(LHEAD) $(LINT.c) $< $(LTAIL))
44360405de4Skz151634
444349b53ddSStuart Maybee$(LINTS_DIR)/%.ln:		$(UTSBASE)/common/xen/os/%.c
445349b53ddSStuart Maybee	@($(LHEAD) $(LINT.c) $< $(LTAIL))
446349b53ddSStuart Maybee
447ae115bc7Smrj#
448ae115bc7Smrj# bios call has a funky name change while building
449ae115bc7Smrj#
450ae115bc7Smrj$(LINTS_DIR)/bios_call.ln:	$(UTSBASE)/i86pc/ml/bios_call_src.s
451ae115bc7Smrj	@($(LHEAD) $(LINT.s) $(UTSBASE)/i86pc/ml/bios_call_src.s  $(LTAIL))
452ae115bc7Smrj	@mv $(LINTS_DIR)/bios_call_src.ln $(LINTS_DIR)/bios_call.ln
45360405de4Skz151634
454ae115bc7Smrj#
45519397407SSherry Moore# So does fb_swtch
45619397407SSherry Moore#
45719397407SSherry Moore$(LINTS_DIR)/fb_swtch.ln:	$(UTSBASE)/i86pc/ml/fb_swtch_src.s
45819397407SSherry Moore	@($(LHEAD) $(LINT.s) $(UTSBASE)/i86pc/ml/fb_swtch_src.s  $(LTAIL))
45919397407SSherry Moore	@mv $(LINTS_DIR)/fb_swtch_src.ln $(LINTS_DIR)/fb_swtch.ln
46019397407SSherry Moore
46119397407SSherry Moore#
462ae115bc7Smrj# dboot always compiles in 32-bit mode, so force lint to be 32-bit mode too.
463ae115bc7Smrj#
464ae115bc7Smrj$(DBOOT_LINTS_DIR)/%.ln: $(UTSBASE)/i86pc/dboot/%.c
465ae115bc7Smrj	@($(LHEAD) $(DBOOT_LINT) $(DBOOT_LOCAL_LINTFLAGS) $< $(LTAIL))
466ae115bc7Smrj
467ae115bc7Smrj$(DBOOT_LINTS_DIR)/%.ln: $(UTSBASE)/i86pc/dboot/%.s
468ae115bc7Smrj	@($(LHEAD) $(DBOOT_LINT) $(DBOOT_LOCAL_LINTFLAGS) $< $(LTAIL))
469ae115bc7Smrj
470e65d07eeSKeith Wesolowski$(DBOOT_LINTS_DIR)/%.ln: $(COMMONBASE)/crypto/sha1/%.c
471e65d07eeSKeith Wesolowski	@($(LHEAD) $(DBOOT_LINT) $(DBOOT_LOCAL_LINTFLAGS) $< $(LTAIL))
472e65d07eeSKeith Wesolowski
473ae115bc7Smrj$(DBOOT_LINTS_DIR)/%.ln: $(UTSBASE)/i86pc/boot/%.c
474ae115bc7Smrj	@($(LHEAD) $(DBOOT_LINT) $(DBOOT_LOCAL_LINTFLAGS) $< $(LTAIL))
475ae115bc7Smrj
476ae115bc7Smrj$(DBOOT_LINTS_DIR)/%.ln: $(COMMONBASE)/util/%.c
477ae115bc7Smrj	@($(LHEAD) $(DBOOT_LINT) $(DBOOT_LOCAL_LINTFLAGS) $< $(LTAIL))
478ae115bc7Smrj
479ae115bc7Smrj$(DBOOT_LINTS_DIR)/%.ln: $(COMMONBASE)/util/i386/%.s
480ae115bc7Smrj	@($(LHEAD) $(DBOOT_LINT) $(DBOOT_LOCAL_LINTFLAGS) $< $(LTAIL))
481