xref: /titanic_50/usr/src/uts/intel/Makefile.intel (revision 9d7041eec59fd2059033c58e9e5427468f4446e8)
1#
2# CDDL HEADER START
3#
4# The contents of this file are subject to the terms of the
5# Common Development and Distribution License, Version 1.0 only
6# (the "License").  You may not use this file except in compliance
7# with the License.
8#
9# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10# or http://www.opensolaris.org/os/licensing.
11# See the License for the specific language governing permissions
12# and limitations under the License.
13#
14# When distributing Covered Code, include this CDDL HEADER in each
15# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16# If applicable, add the following below this CDDL HEADER, with the
17# fields enclosed by brackets "[]" replaced with your own identifying
18# information: Portions Copyright [yyyy] [name of copyright owner]
19#
20# CDDL HEADER END
21#
22#
23# Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
24# Use is subject to license terms.
25#
26# ident	"%Z%%M%	%I%	%E% SMI"
27#
28#
29#	This makefile contains the common definitions for all intel
30#	implementation architecture independent modules.
31
32#
33#	Machine type (implementation architecture):
34#
35PLATFORM	 = i86pc
36
37#
38#	Everybody needs to know how to build modstubs.o and to locate unix.o.
39#	Note that unix.o must currently be selected from among the possible
40#	"implementation architectures". Note further, that unix.o is only
41#	used as an optional error check for undefines so (theoretically)
42#	any "implementation architectures" could be used. We choose i86pc
43#	because it is the reference port.
44#
45UNIX_DIR	 = $(UTSBASE)/i86pc/unix
46GENLIB_DIR	 = $(UTSBASE)/intel/genunix
47IPDRV_DIR	 = $(UTSBASE)/intel/ip
48MODSTUBS_DIR	 = $(UNIX_DIR)
49DSF_DIR		 = $(UTSBASE)/$(PLATFORM)/genassym
50LINTS_DIR	 = $(OBJS_DIR)
51LINT_LIB_DIR	 = $(UTSBASE)/intel/lint-libs/$(OBJS_DIR)
52
53UNIX_O		 = $(UNIX_DIR)/$(OBJS_DIR)/unix.o
54GENLIB		 = $(GENLIB_DIR)/$(OBJS_DIR)/libgenunix.so
55MODSTUBS_O	 = $(MODSTUBS_DIR)/$(OBJS_DIR)/modstubs.o
56LINT_LIB	 = $(UTSBASE)/i86pc/lint-libs/$(OBJS_DIR)/llib-lunix.ln
57GEN_LINT_LIB	 = $(UTSBASE)/intel/lint-libs/$(OBJS_DIR)/llib-lgenunix.ln
58
59#
60#	Include the makefiles which define build rule templates, the
61#	collection of files per module, and a few specific flags. Note
62#	that order is significant, just as with an include path. The
63#	first build rule template which matches the files name will be
64#	used. By including these in order from most machine dependent
65#	to most machine independent, we allow a machine dependent file
66#	to be used in preference over a machine independent version
67#	(Such as a machine specific optimization, which preserves the
68#	interfaces.)
69#
70include $(UTSBASE)/intel/Makefile.files
71include $(UTSBASE)/common/Makefile.files
72
73#
74#	Include machine independent rules. Note that this does not imply
75#	that the resulting module from rules in Makefile.uts is	machine
76#	independent. Only that the build rules are machine independent.
77#
78include $(UTSBASE)/Makefile.uts
79
80#
81#	The following must be defined for all implementations:
82#
83MODSTUBS		= $(UTSBASE)/intel/ia32/ml/modstubs.s
84
85#
86#	Define supported builds
87#
88DEF_BUILDS		= $(DEF_BUILDS64) $(DEF_BUILDS32)
89ALL_BUILDS		= $(ALL_BUILDS64) $(ALL_BUILDS32)
90
91#
92#	x86 or amd64 inline templates
93#
94INLINES_32		= $(UTSBASE)/intel/ia32/ml/ia32.il
95INLINES_64		= $(UTSBASE)/intel/amd64/ml/amd64.il
96INLINES			+= $(INLINES_$(CLASS))
97
98#
99#	kernel-specific optimizations; override default in Makefile.master
100#
101
102CFLAGS_XARCH_32		= $(i386_CFLAGS)
103CFLAGS_XARCH_64		= $(amd64_CFLAGS)
104CFLAGS_XARCH		= $(CFLAGS_XARCH_$(CLASS))
105
106COPTFLAG_32		= $(COPTFLAG)
107COPTFLAG_64		= $(COPTFLAG64)
108COPTIMIZE		= $(COPTFLAG_$(CLASS))
109
110CFLAGS			= $(CFLAGS_XARCH)
111CFLAGS			+= $(COPTIMIZE)
112CFLAGS			+= $(INLINES) -D_ASM_INLINES
113CFLAGS			+= $(CCMODE)
114CFLAGS			+= $(SPACEFLAG)
115CFLAGS			+= $(CCUNBOUND)
116CFLAGS			+= $(CFLAGS_uts)
117
118ASFLAGS_XARCH_32	= $(i386_ASFLAGS)
119ASFLAGS_XARCH_64	= $(amd64_ASFLAGS)
120ASFLAGS_XARCH		= $(ASFLAGS_XARCH_$(CLASS))
121
122ASFLAGS			+= $(ASFLAGS_XARCH)
123
124#
125#	Define the base directory for installation.
126#
127BASE_INS_DIR	= $(ROOT)
128
129#
130#
131# Simulator flag
132#
133i386_SIMULATOR		= -D_SIMULATOR_SUPPORT
134amd64_SIMULATOR		= -D_SIMULATOR_SUPPORT
135
136SIMULATOR		= $($(MACH)_SIMULATOR)
137
138
139#
140#	Debugging level
141#
142#	Special knowledge of which special debugging options affect which
143#	file is used to optimize the build if these flags are changed.
144#
145DEBUG_DEFS_OBJ32	=
146DEBUG_DEFS_DBG32	= -DDEBUG
147DEBUG_DEFS_DBG32	+= $(SIMULATOR)
148DEBUG_DEFS_OBJ64	=
149DEBUG_DEFS_DBG64	= -DDEBUG
150DEBUG_DEFS_DBG64	+= $(SIMULATOR)
151DEBUG_DEFS		= $(DEBUG_DEFS_$(BUILD_TYPE))
152
153DEBUG_COND_OBJ32	:sh = echo \\043
154DEBUG_COND_DBG32	=
155DEBUG_COND_OBJ64	:sh = echo \\043
156DEBUG_COND_DBG64	=
157IF_DEBUG_OBJ		= $(DEBUG_COND_$(BUILD_TYPE))$(OBJS_DIR)/
158
159$(IF_DEBUG_OBJ)syscall.o	:=	DEBUG_DEFS	+= -DSYSCALLTRACE
160$(IF_DEBUG_OBJ)clock.o		:=	DEBUG_DEFS	+= -DKSLICE=1
161
162#
163# This rather strange collection of definitions ensures that lint sees
164# 'struct cpu' containing a fully declared embedded 'struct machcpu'
165#
166# There's something deeply dissatisfying about this.
167#
168LINTMACHFLAGS = -D_MACHDEP -I../../i86pc
169$(LINTS_DIR)/kcpc.ln	:=	LINTFLAGS += $(LINTMACHFLAGS)
170$(LINTS_DIR)/kdi.ln	:=	LINTFLAGS += $(LINTMACHFLAGS)
171$(LINTS_DIR)/msacct.ln	:=	LINTFLAGS += $(LINTMACHFLAGS)
172$(LINTS_DIR)/thread.ln	:=	LINTFLAGS += $(LINTMACHFLAGS)
173
174#
175#	Build `options'. These are entirely historical and the need for these
176#	is completely removed by the module technology.
177#
178OPTION_DEFS	 = -DC2_AUDIT
179
180#
181#	Collect the preprocessor definitions to be associated with *all*
182#	files.
183#
184ALL_DEFS	 = $(DEBUG_DEFS) $(OPTION_DEFS)
185
186#
187# ----- TRANSITIONAL SECTION --------------------------------------------------
188#
189
190#
191#	Not everything which *should* be a module is a module yet. The
192#	following is a list of such objects which are currently part of
193#	the base kernel but should soon become kmods.
194#
195NOT_YET_KMODS	 = $(OLDPTY_OBJS) $(PTY_OBJS) $(MOD_OBJS)
196
197#
198# ----- END OF TRANSITIONAL SECTION -------------------------------------------
199
200#
201#	The kernels modules which are "implementation architecture"
202#	specific for this machine are enumerated below. Note that most
203#	of these modules must exist (in one form or another) for each
204#	architecture.
205#
206#	Common Drivers (usually pseudo drivers) (/kernel/drv)
207#	DRV_KMODS are built both 32-bit and 64-bit
208#	DRV_KMODS_32 are built only 32-bit
209#	DRV_KMODS_64 are built only 64-bit
210#
211DRV_KMODS	+= aac
212DRV_KMODS	+= aggr
213DRV_KMODS	+= amr
214DRV_KMODS	+= arp
215DRV_KMODS	+= asy
216DRV_KMODS	+= bl
217DRV_KMODS	+= bge
218DRV_KMODS	+= bofi
219DRV_KMODS	+= clone
220DRV_KMODS	+= cmdk
221DRV_KMODS	+= cn
222DRV_KMODS	+= conskbd
223DRV_KMODS	+= consms
224DRV_KMODS	+= cpuid
225DRV_KMODS	+= crypto
226DRV_KMODS	+= cryptoadm
227DRV_KMODS	+= devinfo
228DRV_KMODS	+= dld
229DRV_KMODS	+= dump
230DRV_KMODS	+= ecpp
231DRV_KMODS	+= fssnap
232DRV_KMODS	+= glm
233DRV_KMODS	+= i8042
234DRV_KMODS	+= icmp
235DRV_KMODS	+= icmp6
236DRV_KMODS	+= ip
237DRV_KMODS	+= ip6
238DRV_KMODS	+= ipf
239DRV_KMODS	+= ippctl
240DRV_KMODS	+= ipsecah
241DRV_KMODS	+= ipsecesp
242DRV_KMODS	+= iwscn
243DRV_KMODS	+= keysock
244DRV_KMODS	+= kstat
245DRV_KMODS	+= ksyms
246DRV_KMODS	+= kmdb
247DRV_KMODS	+= llc1
248DRV_KMODS	+= llc2
249DRV_KMODS	+= lofi
250DRV_KMODS	+= log
251DRV_KMODS	+= logindmux
252DRV_KMODS	+= mm
253DRV_KMODS	+= mouse8042
254DRV_KMODS	+= mpt
255DRV_KMODS	+= nca
256DRV_KMODS	+= openeepr
257DRV_KMODS	+= pfil
258DRV_KMODS	+= pm
259DRV_KMODS	+= poll
260DRV_KMODS	+= pool
261DRV_KMODS	+= pseudo
262DRV_KMODS	+= ptc
263DRV_KMODS	+= ptm
264DRV_KMODS	+= pts
265DRV_KMODS	+= ptsl
266DRV_KMODS	+= ramdisk
267DRV_KMODS	+= random
268DRV_KMODS	+= rpcib
269DRV_KMODS	+= rsm
270DRV_KMODS	+= rts
271DRV_KMODS	+= sad
272DRV_KMODS	+= sctp
273DRV_KMODS	+= sctp6
274DRV_KMODS	+= sd
275DRV_KMODS	+= sgen
276DRV_KMODS	+= smbios
277DRV_KMODS	+= spdsock
278DRV_KMODS	+= sppp
279DRV_KMODS	+= sppptun
280DRV_KMODS	+= st
281DRV_KMODS	+= sy
282DRV_KMODS	+= sysevent
283DRV_KMODS	+= sysmsg
284DRV_KMODS	+= tcp
285DRV_KMODS	+= tcp6
286DRV_KMODS	+= tl
287DRV_KMODS	+= tnf
288DRV_KMODS	+= udp
289DRV_KMODS	+= udp6
290DRV_KMODS	+= vgatext
291DRV_KMODS	+= vni
292DRV_KMODS	+= vol
293DRV_KMODS	+= wc
294DRV_KMODS	+= winlock
295DRV_KMODS	+= xge
296DRV_KMODS	+= chxge
297DRV_KMODS	+= zcons
298
299#
300# Common code drivers
301#
302DRV_KMODS	+= ixgb
303DRV_KMODS	+= rge
304
305#
306#	DTrace and DTrace Providers
307#
308DRV_KMODS	+= dtrace
309DRV_KMODS	+= fbt
310DRV_KMODS	+= lockstat
311DRV_KMODS	+= profile
312DRV_KMODS	+= sdt
313DRV_KMODS	+= systrace
314DRV_KMODS	+= fasttrap
315
316#
317#	I/O framework test drivers
318#
319DRV_KMODS	+= pshot
320DRV_KMODS	+= gen_drv
321DRV_KMODS	+= tvhci tphci tclient
322DRV_KMODS	+= emul64
323
324#
325#	Machine Specific Driver Modules (/kernel/drv):
326#
327DRV_KMODS	+= pci_pci
328DRV_KMODS	+= options
329DRV_KMODS	+= scsi_vhci
330
331#
332#	PCMCIA specific module(s)
333#
334DRV_KMODS	+= pem pcs
335DRV_KMODS	+= pcata pcelx pcmem pcram pcser
336
337#
338#	I2O specific module(s)
339#
340DRV_KMODS_32	+= pci_to_i2o i2o_bs i2o_scsi
341
342#
343#	SCSI Enclosure Services driver
344#
345DRV_KMODS	+= ses
346
347#
348#	USB specific modules
349#
350DRV_KMODS	+= hid
351DRV_KMODS	+= hubd
352DRV_KMODS	+= uhci
353DRV_KMODS	+= ehci
354DRV_KMODS	+= ohci
355DRV_KMODS	+= usb_mid
356DRV_KMODS	+= scsa2usb
357DRV_KMODS	+= usbprn
358DRV_KMODS	+= ugen
359DRV_KMODS	+= usbser
360DRV_KMODS	+= usbser_edge
361DRV_KMODS	+= usb_ac
362DRV_KMODS	+= usb_as
363DRV_KMODS	+= usbskel
364
365#
366#	1394 modules
367#
368MISC_KMODS	+= s1394 sbp2
369DRV_KMODS	+= hci1394 scsa1394
370DRV_KMODS	+= av1394
371DRV_KMODS	+= dcam1394
372
373#
374#	InfiniBand pseudo drivers
375#
376DRV_KMODS	+= ib ibd
377
378#
379#	LVM modules
380#
381DRV_KMODS	+= md
382MISC_KMODS	+= md_stripe md_hotspares md_mirror md_raid md_trans md_notify
383MISC_KMODS	+= md_sp
384
385#
386#	Exec Class Modules (/kernel/exec):
387#
388EXEC_KMODS	+= elfexec intpexec javaexec
389
390#
391#	Scheduling Class Modules (/kernel/sched):
392#
393SCHED_KMODS	+= IA RT TS RT_DPTBL TS_DPTBL FSS FX FX_DPTBL
394
395#
396#	File System Modules (/kernel/fs):
397#
398FS_KMODS	+= autofs cachefs ctfs devfs fdfs fifofs hsfs lofs
399FS_KMODS	+= mntfs namefs nfs objfs zfs
400FS_KMODS	+= pcfs procfs sockfs specfs tmpfs udfs ufs xmemfs
401
402#
403#	Streams Modules (/kernel/strmod):
404#
405STRMOD_KMODS	+= 6to4tun atun bufmod connld dedump ldterm pckt pfmod pipemod
406STRMOD_KMODS	+= ptem redirmod rpcmod rlmod telmod timod
407STRMOD_KMODS	+= spppasyn spppcomp
408STRMOD_KMODS	+= tirdwr ttcompat tun
409STRMOD_KMODS	+= usbkbm
410STRMOD_KMODS	+= usbms
411STRMOD_KMODS	+= usb_ah
412STRMOD_KMODS	+= drcompat
413STRMOD_KMODS	+= nattymod
414STRMOD_KMODS	+= cryptmod
415
416#
417#	'System' Modules (/kernel/sys):
418#
419SYS_KMODS	+= c2audit
420SYS_KMODS	+= doorfs
421SYS_KMODS	+= exacctsys
422SYS_KMODS	+= inst_sync
423SYS_KMODS	+= kaio
424SYS_KMODS	+= msgsys
425SYS_KMODS	+= pipe
426SYS_KMODS	+= portfs
427SYS_KMODS	+= pset
428SYS_KMODS	+= semsys
429SYS_KMODS	+= shmsys
430SYS_KMODS	+= sysacct
431SYS_KMODS	+= acctctl
432
433#
434#	'Misc' Modules (/kernel/misc)
435#	MISC_KMODS are built both 32-bit and 64-bit
436#	MISC_KMODS_32 are built only 32-bit
437#	MISC_KMODS_64 are built only 64-bit
438#
439MISC_KMODS	+= amsrc1 amsrc2
440MISC_KMODS	+= audiosup
441MISC_KMODS	+= busra
442MISC_KMODS	+= cmlb
443MISC_KMODS	+= consconfig
444MISC_KMODS	+= ctf
445MISC_KMODS	+= dadk
446MISC_KMODS	+= diaudio
447MISC_KMODS	+= dls
448MISC_KMODS	+= fssnap_if
449MISC_KMODS	+= gda
450MISC_KMODS	+= gld
451MISC_KMODS	+= hidparser
452MISC_KMODS	+= hpcsvc
453MISC_KMODS_32	+= i2o_msg
454MISC_KMODS	+= ibcm
455MISC_KMODS	+= ibdm
456MISC_KMODS	+= ibmf
457MISC_KMODS	+= ibtl
458MISC_KMODS	+= ipc
459MISC_KMODS	+= kbtrans
460MISC_KMODS	+= kcf
461MISC_KMODS	+= kgssapi
462MISC_KMODS	+= klmmod klmops
463MISC_KMODS	+= kmech_dummy
464MISC_KMODS	+= kmech_krb5
465MISC_KMODS	+= krtld
466MISC_KMODS	+= mac
467MISC_KMODS	+= mixer
468MISC_KMODS	+= nfs_dlboot
469MISC_KMODS	+= nfssrv
470MISC_KMODS	+= pcicfg
471MISC_KMODS	+= pcihp
472MISC_KMODS	+= pcmcia
473MISC_KMODS	+= phx
474MISC_KMODS	+= rpcsec
475MISC_KMODS	+= rpcsec_gss
476MISC_KMODS	+= rsmops
477MISC_KMODS	+= scsi
478MISC_KMODS	+= strategy
479MISC_KMODS	+= strplumb
480MISC_KMODS	+= sysinit
481MISC_KMODS	+= terminal-emulator
482MISC_KMODS	+= tlimod
483MISC_KMODS	+= usba usba10
484MISC_KMODS	+= zmod
485
486#
487#	Software Cryptographic Providers (/kernel/crypto):
488#
489CRYPTO_KMODS	+= aes
490CRYPTO_KMODS	+= arcfour
491CRYPTO_KMODS	+= blowfish
492CRYPTO_KMODS	+= des
493CRYPTO_KMODS	+= md5
494CRYPTO_KMODS	+= rsa
495CRYPTO_KMODS	+= sha1
496CRYPTO_KMODS	+= sha2
497CRYPTO_KMODS	+= swrand
498
499#
500#	IP Policy Modules (/kernel/ipp)
501#
502IPP_KMODS	+= dlcosmk
503IPP_KMODS	+= flowacct
504IPP_KMODS	+= ipgpc
505IPP_KMODS	+= dscpmk
506IPP_KMODS	+= tokenmt
507IPP_KMODS	+= tswtclmt
508
509#
510#	'Dacf' modules (/kernel/dacf)
511#
512DACF_KMODS	+= consconfig_dacf
513
514#
515#	generic-unix module (/kernel/genunix):
516#
517GENUNIX_KMODS	+= genunix
518
519#
520#	SVVS Testing Modules (/kernel/strmod):
521#
522#	These are streams and driver modules which are not to be
523#	delivered with a released system. However, during development
524#	it is convenient to build and install the SVVS kernel modules.
525#
526SVVS_KMODS	+= lmodb lmode lmodr lmodt lo tidg tivc tmux
527
528SVVS		+= svvs
529
530#
531#	Modules eXcluded from the product:
532#
533XMODS		+= e1000g adpu320 nge lsimega
534XMODS		+= tavor daplt
535
536
537#
538#	'Dacf' Modules (/kernel/dacf):
539#
540DACF_KMODS	+= usb_ac_dacf
541
542#
543#	Performance Counter BackEnd modules (/usr/kernel/pcbe)
544#
545PCBE_KMODS	+= p123_pcbe p4_pcbe opteron_pcbe
546