Makefile.sparc.shared revision 7302:d9c4046525ac
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 (the "License").
6# You may not use this file except in compliance with the License.
7#
8# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9# or http://www.opensolaris.org/os/licensing.
10# See the License for the specific language governing permissions
11# and limitations under the License.
12#
13# When distributing Covered Code, include this CDDL HEADER in each
14# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15# If applicable, add the following below this CDDL HEADER, with the
16# fields enclosed by brackets "[]" replaced with your own identifying
17# information: Portions Copyright [yyyy] [name of copyright owner]
18#
19# CDDL HEADER END
20#
21
22#
23# Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
24# Use is subject to license terms.
25#
26#	This makefile contains the common definitions for all sparc
27#	implementation architecture independent modules.
28#
29
30#
31#	Define supported builds
32#
33DEF_BUILDS	= $(DEF_BUILDS64)
34ALL_BUILDS	= $(ALL_BUILDS64)
35
36#
37#	Everybody needs to know how to build modstubs.o and to locate unix.o.
38#	Note that unix.o must currently be selected from among the possible
39#	"implementation architectures". Note further, that unix.o is only
40#	used as an optional error check for undefines so (theoretically)
41#	any "implementation architectures" could be used. We choose sun4u
42#	because it is the reference port.
43#
44UNIX_DIR	 = $(UTSBASE)/sun4u/unix
45GENLIB_DIR	 = $(UTSBASE)/sun4u/genunix
46IPDRV_DIR	 = $(UTSBASE)/sparc/ip
47MODSTUBS_DIR	 = $(UNIX_DIR)
48DSF_DIR		 = $(UNIX_DIR)
49LINTS_DIR	 = $(OBJS_DIR)
50LINT_LIB_DIR	 = $(UTSBASE)/sparc/lint-libs/$(OBJS_DIR)
51
52UNIX_O		 = $(UNIX_DIR)/$(OBJS_DIR)/unix.o
53MODSTUBS_O	 = $(MODSTUBS_DIR)/$(OBJS_DIR)/modstubs.o
54GENLIB		 = $(UTSBASE)/sun4u/lint-libs/$(OBJS_DIR)/libgenunix.so
55
56LINT_LIB_32	 = $(UTSBASE)/sun4u/lint-libs/$(OBJS_DIR)/llib-lunix.ln
57GEN_LINT_LIB_32	 = $(UTSBASE)/sun4u/lint-libs/$(OBJS_DIR)/llib-lgenunix.ln
58
59LINT_LIB_64	 = $(UTSBASE)/sun4u/lint-libs/$(OBJS_DIR)/llib-lunix.ln
60GEN_LINT_LIB_64	 = $(UTSBASE)/sun4u/lint-libs/$(OBJS_DIR)/llib-lgenunix.ln
61
62LINT_LIB	 = $(LINT_LIB_$(CLASS))
63GEN_LINT_LIB	 = $(GEN_LINT_LIB_$(CLASS))
64
65LINT32_DIRS	 = $(LINT32_BUILDS:%=$(UTSBASE)/sparc/lint-libs/%)
66LINT32_FILES	 = $(LINT32_DIRS:%=%/llib-l$(MODULE).ln)
67
68LINT64_DIRS	 = $(LINT64_BUILDS:%=$(UTSBASE)/sparc/lint-libs/%)
69LINT64_FILES	 = $(LINT64_DIRS:%=%/llib-l$(MODULE).ln)
70
71#
72#	Include the makefiles which define build rule templates, the
73#	collection of files per module, and a few specific flags. Note
74#	that order is significant, just as with an include path. The
75#	first build rule template which matches the files name will be
76#	used. By including these in order from most machine dependent
77#	to most machine independent, we allow a machine dependent file
78#	to be used in preference over a machine independent version
79#	(Such as a machine specific optimization, which preserves the
80#	interfaces.)
81#
82include $(UTSBASE)/sparc/Makefile.files
83include $(UTSBASE)/sparc/v9/Makefile.files
84include $(UTSTREE)/sun/Makefile.files
85include $(UTSTREE)/common/Makefile.files
86
87#
88# ----- TRANSITIONAL SECTION --------------------------------------------------
89#
90
91#
92#	Not everything which *should* be a module is a module yet. The
93#	following is a list of such objects which are currently part of
94#	genunix but which might someday become kmods.   This must be
95#	defined before we include Makefile.uts, or else genunix's build
96#	won't be as parallel as we might like.
97#
98NOT_YET_KMODS	 = $(OLDPTY_OBJS) $(PTY_OBJS) $(MOD_OBJS)
99
100#
101# ----- END OF TRANSITIONAL SECTION -------------------------------------------
102#
103#	Include machine independent rules. Note that this does not imply
104#	that the resulting module from rules in Makefile.uts is	machine
105#	independent. Only that the build rules are machine independent.
106#
107include $(UTSBASE)/Makefile.uts
108
109#
110#	machine specific optimization, override default in Makefile.master
111#
112XARCH_32	= -xarch=v8
113XARCH_64	= -xarch=v9
114XARCH		= $(XARCH_$(CLASS))
115
116COPTIMIZE_32	= -xO3
117COPTIMIZE_64	= -xO3
118COPTIMIZE	= $(COPTIMIZE_$(CLASS))
119
120CCMODE		= -Xa
121
122CFLAGS_32	= -xcg92
123CFLAGS_64	= -xchip=ultra $(CCABS32) $(CCREGSYM)
124CFLAGS		= $(CFLAGS_$(CLASS))
125
126CFLAGS		+= $(XARCH)
127CFLAGS		+= $(COPTIMIZE)
128CFLAGS		+= $(EXTRA_CFLAGS)
129CFLAGS		+= $(XAOPT)
130CFLAGS		+= $(INLINES) -D_ASM_INLINES
131CFLAGS		+= $(CCMODE)
132CFLAGS		+= $(SPACEFLAG)
133CFLAGS		+= $(CERRWARN)
134CFLAGS		+= $(CTF_FLAGS)
135CFLAGS		+= $(C99MODE)
136CFLAGS		+= $(CCUNBOUND)
137CFLAGS		+= $(CCSTATICSYM)
138CFLAGS		+= $(IROPTFLAG)
139CFLAGS		+= $(CGLOBALSTATIC)
140CFLAGS		+= -xregs=no%float
141CFLAGS		+= -xstrconst
142
143ASFLAGS		+= $(XARCH)
144
145LINT_DEFS_32	=
146LINT_DEFS_64	= -Xarch=v9
147LINT_DEFS	+= $(LINT_DEFS_$(CLASS))
148
149#
150#	The following must be defined for all implementations:
151#
152#	MODSTUBS:	Module stubs source file.
153#
154MODSTUBS	 = $(UTSBASE)/sparc/ml/modstubs.s
155
156#
157#	Define the actual specific platforms - obviously none.
158#
159MACHINE_DEFS	 =
160
161#
162#	Debugging level
163#
164#	Special knowledge of which special debugging options effect which
165#	file is used to optimize the build if these flags are changed.
166#
167#	XXX: The above could possibly be done for more flags and files, but
168#	     is left as an experiment to the interested reader. Be forewarned,
169#	     that excessive use could lead to maintenance difficulties.
170#
171DEBUG_DEFS_OBJ32	=
172DEBUG_DEFS_DBG32	= -DDEBUG
173DEBUG_DEFS_OBJ64	=
174DEBUG_DEFS_DBG64	= -DDEBUG
175DEBUG_DEFS		= $(DEBUG_DEFS_$(BUILD_TYPE))
176
177DEBUG_COND_OBJ32	:sh = echo \\043
178DEBUG_COND_DBG32	=
179DEBUG_COND_OBJ64	:sh = echo \\043
180DEBUG_COND_DBG64	=
181IF_DEBUG_OBJ		= $(DEBUG_COND_$(BUILD_TYPE))$(OBJS_DIR)/
182
183$(IF_DEBUG_OBJ)syscall.o	:=	DEBUG_DEFS	+= -DSYSCALLTRACE
184$(IF_DEBUG_OBJ)clock.o		:=	DEBUG_DEFS	+= -DKSLICE=1
185
186# Comment these out if you don't want dispatcher lock statistics.
187
188# $(IF_DEBUG_OBJ)disp_lock.o	:= DEBUG_DEFS	+= -DDISP_LOCK_STATS
189
190#
191# This rather strange collection of definitions ensures that lint sees
192# 'struct cpu' containing a fully declared embedded 'struct machcpu'
193#
194# There's something deeply dissatisfying about this.
195#
196LINTMACHFLAGS = -D_MACHDEP -I../../sun4 -I../../$(PLATFORM) -I../../sfmmu
197$(LINTS_DIR)/kcpc.ln	:=	LINTFLAGS += $(LINTMACHFLAGS)
198$(LINTS_DIR)/kdi.ln	:=	LINTFLAGS += $(LINTMACHFLAGS)
199$(LINTS_DIR)/msacct.ln	:=	LINTFLAGS += $(LINTMACHFLAGS)
200$(LINTS_DIR)/thread.ln	:=	LINTFLAGS += $(LINTMACHFLAGS)
201
202#
203#	Collect the preprocessor definitions to be associated with *all*
204#	files.
205#
206ALL_DEFS	 = $(MACHINE_DEFS) $(DEBUG_DEFS) $(OPTION_DEFS)
207#
208#
209#	The kernels modules which are "implementation architecture"
210#	specific for this machine are enumerated below. Note that most
211#	of these modules must exist (in one form or another) for each
212#	architecture.
213#
214#	Common Drivers (usually pseudo drivers) (/kernel/drv):
215#
216DRV_KMODS	+= aggr arp bl bofi clone cn conskbd consms cpuid
217DRV_KMODS	+= crypto cryptoadm devinfo dump
218DRV_KMODS	+= dtrace fasttrap fbt lockstat profile sdt systrace
219DRV_KMODS	+= fssnap icmp icmp6 ip ip6 ipsecah
220DRV_KMODS	+= ipsecesp iwscn keysock kmdb kstat ksyms llc1
221DRV_KMODS	+= lofi
222DRV_KMODS	+= log logindmux kssl mm nca physmem pm poll pool
223DRV_KMODS	+= pseudo ptc ptm pts ptsl ramdisk random rsm rts sad
224DRV_KMODS	+= softmac sppp sppptun sy sysevent sysmsg 
225DRV_KMODS	+= spdsock
226DRV_KMODS	+= tcp tcp6 tl tnf ttymux udp udp6 wc winlock zcons
227DRV_KMODS	+= ippctl sctp sctp6
228DRV_KMODS	+= dld
229DRV_KMODS	+= ipf
230DRV_KMODS	+= rpcib
231DRV_KMODS	+= vni vnic
232DRV_KMODS	+= xge
233DRV_KMODS	+= rds
234DRV_KMODS	+= chxge
235DRV_KMODS	+= smbsrv
236DRV_KMODS	+= vscan
237DRV_KMODS	+= nsmb
238
239#
240# Don't build some of these for OpenSolaris, since they will be
241# replaced by binaries that are signed by Sun Release Engineering.
242#
243$(CLOSED_BUILD)DRV_KMODS	+= dca
244
245$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= glm
246$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= isp
247$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= llc2
248$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= mpt
249$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= se
250$(CLOSED_BUILD)CLOSED_DRV_KMODS += rtls
251
252#
253#       Hardware Drivers in common space
254#
255
256DRV_KMODS	+= afe
257DRV_KMODS	+= e1000g
258DRV_KMODS	+= mxfe
259DRV_KMODS	+= pcan
260DRV_KMODS	+= pcwl
261DRV_KMODS	+= rge
262DRV_KMODS	+= sfe
263DRV_KMODS	+= aac
264DRV_KMODS	+= igb
265DRV_KMODS	+= ixgbe
266$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= ixgb
267
268#
269#	Machine Specific Driver Modules (/kernel/drv):
270#
271DRV_KMODS	+= audio1575 audio810 audiohd audiocs audiots
272DRV_KMODS	+= bge bpp dmfe eri esp fas hme qfe
273DRV_KMODS	+= openeepr options sd ses st
274DRV_KMODS	+= ssd
275DRV_KMODS	+= ecpp
276DRV_KMODS	+= hid hubd ehci ohci uhci usb_mid usb_ia scsa2usb usbprn ugen
277DRV_KMODS	+= usbser usbsacm usbsksp usbsprl
278DRV_KMODS	+= usb_as usb_ac
279DRV_KMODS	+= usbskel
280DRV_KMODS	+= usbvc
281DRV_KMODS	+= hci1394 av1394 scsa1394 dcam1394
282DRV_KMODS	+= sbp2
283DRV_KMODS	+= ib ibd rdsib sdp
284DRV_KMODS	+= pci_pci px_pci pxb_plx pxb_bcm pcie
285DRV_KMODS	+= i8042 kb8042 mouse8042
286DRV_KMODS	+= fcode
287DRV_KMODS	+= socal
288DRV_KMODS	+= sgen
289DRV_KMODS	+= smp
290DRV_KMODS	+= dad
291DRV_KMODS	+= scsi_vhci
292DRV_KMODS	+= sdcard
293DRV_KMODS	+= sdhost
294DRV_KMODS	+= wbsd
295
296$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= audioens
297$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= audiovia823x
298$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= ifp
299$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= uata
300$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= usbser_edge
301
302#
303#	I/O framework test drivers
304#
305DRV_KMODS	+= pshot
306DRV_KMODS	+= gen_drv
307DRV_KMODS	+= tvhci tphci tclient
308DRV_KMODS	+= emul64
309
310#
311# PCMCIA specific module(s)
312#
313DRV_KMODS	+= stp4020 pcs
314MISC_KMODS	+= busra cardbus dada pcmcia
315DRV_KMODS	+= pcata pcmem pcram
316DRV_KMODS	+= pcic
317DRV_KMODS	+= pem
318
319$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= pcelx
320$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= pcser
321
322# Add lvm
323#
324DRV_KMODS       += md
325MISC_KMODS      += md_mirror md_stripe md_hotspares md_raid md_trans md_notify
326MISC_KMODS      += md_sp
327
328#
329#	Exec Class Modules (/kernel/exec):
330#
331EXEC_KMODS	+= aoutexec elfexec intpexec javaexec
332
333#
334#	Scheduling Class Modules (/kernel/sched):
335#
336SCHED_KMODS	+= RT TS RT_DPTBL TS_DPTBL IA FSS FX FX_DPTBL
337
338#
339#	File System Modules (/kernel/fs):
340#
341FS_KMODS	+= dev devfs fdfs fifofs hsfs lofs namefs nfs pcfs tmpfs zfs
342FS_KMODS	+= specfs udfs ufs autofs cachefs procfs sockfs mntfs
343FS_KMODS	+= ctfs objfs sharefs dcfs smbfs
344
345#
346#	Streams Modules (/kernel/strmod):
347#
348STRMOD_KMODS	+= 6to4tun atun bufmod connld dedump ldterm ms pckt pfmod
349STRMOD_KMODS	+= pipemod ptem redirmod rpcmod rlmod telmod timod
350STRMOD_KMODS	+= spppasyn spppcomp
351STRMOD_KMODS	+= tirdwr ttcompat tun
352STRMOD_KMODS	+= usbkbm usbms usb_ah
353STRMOD_KMODS	+= drcompat
354STRMOD_KMODS	+= cryptmod
355STRMOD_KMODS	+= vuid3ps2
356
357#
358#	'System' Modules (/kernel/sys):
359#
360SYS_KMODS	+= c2audit
361SYS_KMODS	+= exacctsys
362SYS_KMODS	+= inst_sync kaio msgsys semsys shmsys sysacct pipe
363SYS_KMODS	+= doorfs pset acctctl portfs
364
365#
366#	'User' Modules (/kernel/misc):
367#
368MISC_KMODS	+= amsrc2 audiosup mixer
369MISC_KMODS	+= bignum
370MISC_KMODS	+= consconfig gld ipc nfs_dlboot nfssrv scsi
371MISC_KMODS	+= strplumb swapgeneric tlimod
372MISC_KMODS	+= rpcsec rpcsec_gss kgssapi kmech_dummy
373MISC_KMODS	+= kmech_krb5
374MISC_KMODS	+= fssnap_if
375MISC_KMODS	+= hidparser kbtrans usba usba10 usbs49_fw
376MISC_KMODS	+= s1394
377MISC_KMODS	+= hpcsvc pcihp pciehpc pcishpc
378MISC_KMODS	+= rsmops
379MISC_KMODS	+= kcf
380MISC_KMODS	+= ibcm
381MISC_KMODS	+= ibdm
382MISC_KMODS	+= ibmf
383MISC_KMODS	+= ibtl
384MISC_KMODS	+= idmap
385MISC_KMODS	+= hook
386MISC_KMODS	+= neti
387MISC_KMODS	+= ctf 
388MISC_KMODS	+= mac dls
389MISC_KMODS	+= cmlb
390MISC_KMODS	+= tem
391MISC_KMODS	+= pcicfg.e fcodem fcpci
392MISC_KMODS	+= scsi_vhci_f_sym scsi_vhci_f_tpgs scsi_vhci_f_asym_sun
393MISC_KMODS	+= scsi_vhci_f_sym_hds
394MISC_KMODS	+= scsi_vhci_f_tape scsi_vhci_f_tpgs_tape
395MISC_KMODS	+= blk2scsa
396MISC_KMODS	+= sda
397
398$(CLOSED_BUILD)CLOSED_MISC_KMODS	+= amsrc1
399$(CLOSED_BUILD)CLOSED_MISC_KMODS	+= klmmod klmops
400$(CLOSED_BUILD)CLOSED_MISC_KMODS	+= phx
401$(CLOSED_BUILD)CLOSED_MISC_KMODS	+= scsi_vhci_f_asym_lsi
402$(CLOSED_BUILD)CLOSED_MISC_KMODS	+= scsi_vhci_f_asym_emc
403$(CLOSED_BUILD)CLOSED_MISC_KMODS	+= scsi_vhci_f_sym_emc
404
405#
406#	Software Cryptographic Providers (/kernel/crypto):
407#
408# Don't build some of these for OpenSolaris, since they will be
409# replaced by binaries that are signed by Sun RE.
410#
411$(CLOSED_BUILD)CRYPTO_KMODS	+= aes
412$(CLOSED_BUILD)CRYPTO_KMODS	+= arcfour
413$(CLOSED_BUILD)CRYPTO_KMODS	+= blowfish
414$(CLOSED_BUILD)CRYPTO_KMODS	+= des
415CRYPTO_KMODS	+= md4
416CRYPTO_KMODS	+= md5
417CRYPTO_KMODS	+= ecc
418CRYPTO_KMODS	+= rsa
419CRYPTO_KMODS	+= sha1
420CRYPTO_KMODS	+= sha2
421CRYPTO_KMODS	+= swrand
422
423#
424# IP Policy Modules (/kernel/ipp):
425#
426IPP_KMODS	+= dlcosmk
427IPP_KMODS	+= flowacct
428IPP_KMODS	+= ipgpc
429IPP_KMODS	+= dscpmk
430IPP_KMODS	+= tokenmt
431IPP_KMODS	+= tswtclmt
432
433#
434# 'Dacf' modules (/kernel/dacf)
435DACF_KMODS	+= consconfig_dacf
436
437#
438#	SVVS Testing Modules (/kernel/strmod):
439#
440#	These are streams and driver modules which are not to be
441#	delivered with a released system. However, during development
442#	it is convenient to build and install the SVVS kernel modules.
443#
444SVVS_KMODS	+= lmodb lmode lmodr lmodt lo tidg tivc tmux
445
446SVVS		+= svvs
447
448#
449#	Modules eXcluded from the product:
450#
451XMODS		+=
452$(CLOSED_BUILD)CLOSED_XMODS =		\
453	daplt		\
454	sdpib		\
455	tavor		\
456	wsdrv
457
458#
459#	'Dacf' Modules (/kernel/dacf):
460#
461DACF_KMODS	+= usb_ac_dacf net_dacf
462
463#
464#	MAC-Type Plugin Modules (/kernel/mac)
465#
466MAC_KMODS	+= mac_ether
467MAC_KMODS	+= mac_wifi
468MAC_KMODS	+= mac_ib
469
470#
471# 'Devname' Modules (kernel/devname)
472#
473DEVNAME_KMODS	+= sdev_nsconfig_mod
474
475#
476#	kiconv modules (/kernel/kiconv):
477#
478KICONV_KMODS	+= kiconv_emea kiconv_ja kiconv_ko kiconv_sc kiconv_tc
479