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