xref: /titanic_51/usr/src/uts/intel/Makefile.intel (revision cc7efc4fc1677c721670afcfbd54647b2269f394)
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	+= i8042
233DRV_KMODS	+= icmp
234DRV_KMODS	+= icmp6
235DRV_KMODS	+= ip
236DRV_KMODS	+= ip6
237DRV_KMODS	+= ipf
238DRV_KMODS	+= ippctl
239DRV_KMODS	+= ipsecah
240DRV_KMODS	+= ipsecesp
241DRV_KMODS	+= iwscn
242DRV_KMODS	+= keysock
243DRV_KMODS	+= kstat
244DRV_KMODS	+= ksyms
245DRV_KMODS	+= kmdb
246DRV_KMODS	+= llc1
247DRV_KMODS	+= llc2
248DRV_KMODS	+= lofi
249DRV_KMODS	+= log
250DRV_KMODS	+= logindmux
251DRV_KMODS	+= mm
252DRV_KMODS	+= mouse8042
253DRV_KMODS	+= mpt
254DRV_KMODS	+= nca
255DRV_KMODS	+= objmgr
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	+= spdsock
277DRV_KMODS	+= sppp
278DRV_KMODS	+= sppptun
279DRV_KMODS	+= st
280DRV_KMODS	+= sy
281DRV_KMODS	+= sysevent
282DRV_KMODS	+= sysmsg
283DRV_KMODS	+= tcp
284DRV_KMODS	+= tcp6
285DRV_KMODS	+= tl
286DRV_KMODS	+= tnf
287DRV_KMODS	+= udp
288DRV_KMODS	+= udp6
289DRV_KMODS	+= vgatext
290DRV_KMODS	+= vni
291DRV_KMODS	+= vol
292DRV_KMODS	+= wc
293DRV_KMODS	+= winlock
294DRV_KMODS	+= xge
295DRV_KMODS	+= chxge
296DRV_KMODS	+= zcons
297
298#
299# Common code drivers
300#
301DRV_KMODS	+= ixgb
302
303#
304#	DTrace and DTrace Providers
305#
306DRV_KMODS	+= dtrace
307DRV_KMODS	+= fbt
308DRV_KMODS	+= lockstat
309DRV_KMODS	+= profile
310DRV_KMODS	+= sdt
311DRV_KMODS	+= systrace
312DRV_KMODS	+= fasttrap
313
314#
315#	I/O framework test drivers
316#
317DRV_KMODS	+= pshot
318DRV_KMODS	+= gen_drv
319DRV_KMODS	+= tvhci tphci tclient
320
321#
322#	Machine Specific Driver Modules (/kernel/drv):
323#
324DRV_KMODS	+= pci_pci
325DRV_KMODS	+= options
326DRV_KMODS	+= scsi_vhci
327
328#
329#	PCMCIA specific module(s)
330#
331DRV_KMODS	+= pem pcs
332DRV_KMODS	+= pcata pcelx pcmem pcram pcser
333
334#
335#	I2O specific module(s)
336#
337DRV_KMODS_32	+= pci_to_i2o i2o_bs i2o_scsi
338
339#
340#	SCSI Enclosure Services driver
341#
342DRV_KMODS	+= ses
343
344#
345#	USB specific modules
346#
347DRV_KMODS	+= hid
348DRV_KMODS	+= hubd
349DRV_KMODS	+= uhci
350DRV_KMODS	+= ehci
351DRV_KMODS	+= ohci
352DRV_KMODS	+= usb_mid
353DRV_KMODS	+= scsa2usb
354DRV_KMODS	+= usbprn
355DRV_KMODS	+= ugen
356DRV_KMODS	+= usbser
357DRV_KMODS	+= usbser_edge
358DRV_KMODS	+= usb_ac
359DRV_KMODS	+= usb_as
360DRV_KMODS	+= usbskel
361
362#
363#	1394 modules
364#
365MISC_KMODS	+= s1394 sbp2
366DRV_KMODS	+= hci1394 scsa1394
367DRV_KMODS	+= av1394
368DRV_KMODS	+= dcam1394
369
370#
371#	InfiniBand pseudo drivers
372#
373DRV_KMODS	+= ib ibd
374
375#
376#	LVM modules
377#
378DRV_KMODS	+= md
379MISC_KMODS	+= md_stripe md_hotspares md_mirror md_raid md_trans md_notify
380MISC_KMODS	+= md_sp
381
382#
383#	Exec Class Modules (/kernel/exec):
384#
385EXEC_KMODS	+= elfexec intpexec javaexec
386
387#
388#	Scheduling Class Modules (/kernel/sched):
389#
390SCHED_KMODS	+= IA RT TS RT_DPTBL TS_DPTBL FSS FX FX_DPTBL
391
392#
393#	File System Modules (/kernel/fs):
394#
395FS_KMODS	+= autofs cachefs ctfs devfs fdfs fifofs hsfs lofs
396FS_KMODS	+= mntfs namefs nfs objfs
397FS_KMODS	+= pcfs procfs sockfs specfs tmpfs udfs ufs xmemfs
398
399#
400#	Streams Modules (/kernel/strmod):
401#
402STRMOD_KMODS	+= 6to4tun atun bufmod connld dedump ldterm pckt pfmod pipemod
403STRMOD_KMODS	+= ptem redirmod rpcmod rlmod telmod timod
404STRMOD_KMODS	+= spppasyn spppcomp
405STRMOD_KMODS	+= tirdwr ttcompat tun
406STRMOD_KMODS	+= usbkbm
407STRMOD_KMODS	+= usbms
408STRMOD_KMODS	+= usb_ah
409STRMOD_KMODS	+= drcompat
410STRMOD_KMODS	+= nattymod
411STRMOD_KMODS	+= cryptmod
412
413#
414#	'System' Modules (/kernel/sys):
415#
416SYS_KMODS	+= c2audit
417SYS_KMODS	+= doorfs
418SYS_KMODS	+= exacctsys
419SYS_KMODS	+= inst_sync
420SYS_KMODS	+= kaio
421SYS_KMODS	+= msgsys
422SYS_KMODS	+= pipe
423SYS_KMODS	+= portfs
424SYS_KMODS	+= pset
425SYS_KMODS	+= semsys
426SYS_KMODS	+= shmsys
427SYS_KMODS	+= sysacct
428SYS_KMODS	+= acctctl
429
430#
431#	'Misc' Modules (/kernel/misc)
432#	MISC_KMODS are built both 32-bit and 64-bit
433#	MISC_KMODS_32 are built only 32-bit
434#	MISC_KMODS_64 are built only 64-bit
435#
436MISC_KMODS	+= amsrc1 amsrc2
437MISC_KMODS	+= audiosup
438MISC_KMODS	+= busra
439MISC_KMODS	+= consconfig
440MISC_KMODS	+= ctf
441MISC_KMODS	+= dadk
442MISC_KMODS	+= diaudio
443MISC_KMODS	+= dls
444MISC_KMODS	+= fssnap_if
445MISC_KMODS	+= gda
446MISC_KMODS	+= ght
447MISC_KMODS	+= gld
448MISC_KMODS	+= hidparser
449MISC_KMODS	+= hpcsvc
450MISC_KMODS_32	+= i2o_msg
451MISC_KMODS	+= ibcm
452MISC_KMODS	+= ibdm
453MISC_KMODS	+= ibmf
454MISC_KMODS	+= ibtl
455MISC_KMODS	+= ipc
456MISC_KMODS	+= kbtrans
457MISC_KMODS	+= kcf
458MISC_KMODS	+= kgssapi
459MISC_KMODS	+= klmmod klmops
460MISC_KMODS	+= kmech_dummy
461MISC_KMODS	+= kmech_krb5
462MISC_KMODS	+= krtld
463MISC_KMODS	+= mac
464MISC_KMODS	+= mixer
465MISC_KMODS	+= nfs_dlboot
466MISC_KMODS	+= nfssrv
467MISC_KMODS	+= pcicfg
468MISC_KMODS	+= pcihp
469MISC_KMODS	+= pcmcia
470MISC_KMODS	+= phx
471MISC_KMODS	+= rpcsec
472MISC_KMODS	+= rpcsec_gss
473MISC_KMODS	+= rsmops
474MISC_KMODS	+= scsi
475MISC_KMODS	+= snlb
476MISC_KMODS	+= strategy
477MISC_KMODS	+= strplumb
478MISC_KMODS	+= sysinit
479MISC_KMODS	+= terminal-emulator
480MISC_KMODS	+= tlimod
481MISC_KMODS	+= usba usba10
482MISC_KMODS	+= zmod
483
484#
485#	Software Cryptographic Providers (/kernel/crypto):
486#
487CRYPTO_KMODS	+= aes
488CRYPTO_KMODS	+= arcfour
489CRYPTO_KMODS	+= blowfish
490CRYPTO_KMODS	+= des
491CRYPTO_KMODS	+= md5
492CRYPTO_KMODS	+= rsa
493CRYPTO_KMODS	+= sha1
494CRYPTO_KMODS	+= sha2
495CRYPTO_KMODS	+= swrand
496
497#
498#	IP Policy Modules (/kernel/ipp)
499#
500IPP_KMODS	+= dlcosmk
501IPP_KMODS	+= flowacct
502IPP_KMODS	+= ipgpc
503IPP_KMODS	+= dscpmk
504IPP_KMODS	+= tokenmt
505IPP_KMODS	+= tswtclmt
506
507#
508#	'Dacf' modules (/kernel/dacf)
509#
510DACF_KMODS	+= consconfig_dacf
511
512#
513#	generic-unix module (/kernel/genunix):
514#
515GENUNIX_KMODS	+= genunix
516
517#
518#	SVVS Testing Modules (/kernel/strmod):
519#
520#	These are streams and driver modules which are not to be
521#	delivered with a released system. However, during development
522#	it is convenient to build and install the SVVS kernel modules.
523#
524SVVS_KMODS	+= lmodb lmode lmodr lmodt lo tidg tivc tmux
525
526SVVS		+= svvs
527
528#
529#	Modules eXcluded from the product:
530#
531XMODS		+= e1000g adpu320 nge
532XMODS		+= tavor daplt
533
534
535#
536#	'Dacf' Modules (/kernel/dacf):
537#
538DACF_KMODS	+= usb_ac_dacf
539
540#
541#	Performance Counter BackEnd modules (/usr/kernel/pcbe)
542#
543PCBE_KMODS	+= p123_pcbe p4_pcbe opteron_pcbe
544