Makefile.sun4u.shared revision 6094:3154969ecb41
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# ident	"%Z%%M%	%I%	%E% SMI"
27#
28#	This makefile contains the common definitions for the sun4u unix
29#	and all sun4u implementation architecture dependent modules.
30#
31
32#
33#	Machine type (implementation architecture):
34#
35PLATFORM	 = sun4u
36PROMIF		 = ieee1275
37PSMBASE		 = $(UTSBASE)/../psm
38
39#
40#	uname -m value
41#
42UNAME_M		= $(PLATFORM)
43
44#
45# Definitions for the platform-specific /platform directories.
46#
47# PLATFORMS designates those sun4u machines which have no platform
48# specific code.
49#
50# IMPLEMENTATIONS is used to designate sun4u machines which do have
51# platform specific modules (perhaps including their own unix).  All
52# code specific to a given implementation resides in the appropriately
53# named subdirectory.   This requires these platforms to have their
54# own Makefiles to define ROOT_PLAT_DIRS, USR_PLAT_DIRS, etc.
55#
56# So if we had an implementation named 'foo', we would need the following
57# Makefiles in the foo subdirectory:
58#
59#	sun4u/foo/Makefile
60#	sun4u/foo/Makefile.foo
61#	sun4u/foo/Makefile.targ
62#
63
64#
65# /usr/platform/$(IMPLEMENTED_PLATFORM) is created as a directory that
66# all the $(LINKED_PLATFORMS) link to.
67#
68IMPLEMENTED_PLATFORM	= SUNW,Ultra-2
69
70LINKED_PLATFORMS	+= SUNW,Ultra-30
71LINKED_PLATFORMS	+= SUNW,Ultra-60
72
73#
74# all PLATFORMS that do not belong in the $(IMPLEMENTATIONS) list
75# ie. all desktop platforms
76#
77PLATFORMS                = $(IMPLEMENTED_PLATFORM)
78PLATFORMS               += $(LINKED_PLATFORMS)
79
80ROOT_PLAT_DIRS		= $(PLATFORMS:%=$(ROOT_PLAT_DIR)/%)
81USR_PLAT_DIRS		= $(PLATFORMS:%=$(USR_PLAT_DIR)/%)
82
83USR_DESKTOP_DIR		= $(USR_PLAT_DIR)/$(IMPLEMENTED_PLATFORM)
84USR_DESKTOP_INC_DIR	= $(USR_DESKTOP_DIR)/include
85USR_DESKTOP_SBIN_DIR	= $(USR_DESKTOP_DIR)/sbin
86USR_DESKTOP_LIB_DIR	= $(USR_DESKTOP_DIR)/lib
87
88#
89# Welcome to SPARC V9.
90#
91
92#
93#	Define supported builds
94#
95DEF_BUILDS	= $(DEF_BUILDS64)
96ALL_BUILDS	= $(ALL_BUILDS64)
97
98#
99#	Everybody needs to know how to build modstubs.o and to locate unix.o
100#
101UNIX_DIR	 = $(UTSBASE)/$(PLATFORM)/unix
102GENLIB_DIR	 = $(UTSBASE)/$(PLATFORM)/genunix
103MODSTUBS_DIR	 = $(UNIX_DIR)
104DSF_DIR		 = $(UTSBASE)/$(PLATFORM)/genassym
105LINTS_DIR	 = $(OBJS_DIR)
106LINT_LIB_DIR	 = $(UTSBASE)/$(PLATFORM)/lint-libs/$(OBJS_DIR)
107 
108DTRACESTUBS_O	 = $(OBJS_DIR)/dtracestubs.o
109DTRACESTUBS	 = $(OBJS_DIR)/libdtracestubs.so
110
111UNIX_O		 = $(UNIX_DIR)/$(OBJS_DIR)/unix.o
112MODSTUBS_O	 = $(MODSTUBS_DIR)/$(OBJS_DIR)/modstubs.o
113GENLIB	 	 = $(GENLIB_DIR)/$(OBJS_DIR)/libgenunix.so
114
115LINT_LIB	 = $(LINT_LIB_DIR)/llib-lunix.ln
116GEN_LINT_LIB	 = $(LINT_LIB_DIR)/llib-lgenunix.ln
117
118LINT64_DIRS	 = $(LINT64_BUILDS:%=$(UTSBASE)/$(PLATFORM)/lint-libs/%)
119LINT64_FILES	 = $(LINT64_DIRS:%=%/llib-l$(MODULE).ln)
120
121#
122#	cpu and platform modules need to know how to build their own symcheck module
123#
124PLATMOD		 = platmod
125PLATLIB		 = $(PLAT_DIR)/$(OBJS_DIR)/libplatmod.so
126
127CPUNAME		 = cpu
128CPULIB		 = $(CPU_DIR)/$(OBJS_DIR)/libcpu.so
129
130SYM_MOD		 = $(OBJS_DIR)/unix.sym
131
132#
133#	Include the makefiles which define build rule templates, the
134#	collection of files per module, and a few specific flags. Note
135#	that order is significant, just as with an include path. The
136#	first build rule template which matches the files name will be
137#	used. By including these in order from most machine dependent
138#	to most machine independent, we allow a machine dependent file
139#	to be used in preference over a machine independent version
140#	(Such as a machine specific optimization, which preserves the
141#	interfaces.)
142#
143include $(UTSBASE)/sun4/Makefile.files
144include $(UTSTREE)/$(PLATFORM)/Makefile.files
145include $(UTSBASE)/sfmmu/Makefile.files
146include $(UTSBASE)/sparc/v9/Makefile.files
147include $(UTSBASE)/sparc/Makefile.files
148include $(UTSTREE)/sun/Makefile.files
149include $(SRC)/psm/promif/$(PROMIF)/common/Makefile.files
150include $(SRC)/psm/promif/$(PROMIF)/$(PLATFORM)/Makefile.files
151include $(UTSTREE)/common/Makefile.files
152
153#
154#	Include machine independent rules. Note that this does not imply
155#	that the resulting module from rules in Makefile.uts is	machine
156#	independent. Only that the build rules are machine independent.
157#
158include $(UTSBASE)/Makefile.uts
159
160# These come after Makefile.uts (for CLOSED_BUILD).
161IMPLEMENTATIONS		 = tazmo 
162IMPLEMENTATIONS		+= starfire 
163IMPLEMENTATIONS		+= javelin 
164IMPLEMENTATIONS		+= darwin 
165IMPLEMENTATIONS		+= quasar 
166IMPLEMENTATIONS		+= grover 
167IMPLEMENTATIONS		+= enchilada 
168IMPLEMENTATIONS		+= taco 
169IMPLEMENTATIONS		+= mpxu 
170IMPLEMENTATIONS		+= excalibur 
171IMPLEMENTATIONS		+= montecarlo 
172IMPLEMENTATIONS		+= serengeti 
173IMPLEMENTATIONS		+= littleneck 
174IMPLEMENTATIONS		+= starcat 
175IMPLEMENTATIONS		+= daktari 
176IMPLEMENTATIONS		+= cherrystone 
177IMPLEMENTATIONS		+= fjlite 
178IMPLEMENTATIONS		+= snowbird 
179IMPLEMENTATIONS		+= schumacher 
180IMPLEMENTATIONS		+= blade 
181IMPLEMENTATIONS		+= boston 
182IMPLEMENTATIONS		+= seattle 
183IMPLEMENTATIONS		+= chicago 
184IMPLEMENTATIONS		+= sunfire 
185IMPLEMENTATIONS		+= lw8 
186IMPLEMENTATIONS		+= makaha 
187IMPLEMENTATIONS		+= opl 
188IMPLEMENTATIONS		+= lw2plus 
189IMPLEMENTATIONS		+= douglas
190
191$(CLOSED_BUILD)CLOSED_IMPLEMENTATIONS	= chalupa 
192$(CLOSED_BUILD)CLOSED_IMPLEMENTATIONS	+= ents 
193
194#
195#	machine specific optimization, override default in Makefile.master
196#
197CC_XARCH	= -xarch=v9a
198AS_XARCH	= -xarch=v9a
199COPTIMIZE	= -xO3
200CCMODE		= -Xa
201
202CFLAGS		= -xchip=ultra $(CCABS32) $(CCREGSYM)
203CFLAGS		+= $(CC_XARCH)
204CFLAGS		+= $(COPTIMIZE)
205CFLAGS		+= $(EXTRA_CFLAGS)
206CFLAGS		+= $(XAOPT)
207CFLAGS		+= $(INLINES) -D_ASM_INLINES
208CFLAGS		+= $(CCMODE)
209CFLAGS		+= $(SPACEFLAG)
210CFLAGS		+= $(CERRWARN)
211CFLAGS		+= $(CTF_FLAGS)
212CFLAGS		+= $(C99MODE)
213CFLAGS		+= $(CCUNBOUND)
214CFLAGS		+= $(CCSTATICSYM)
215CFLAGS		+= $(IROPTFLAG)
216CFLAGS		+= $(CGLOBALSTATIC)
217CFLAGS		+= -xregs=no%float
218CFLAGS		+= -xstrconst
219
220ASFLAGS		+= $(AS_XARCH)
221
222AS_INC_PATH	+= -I$(DSF_DIR)/$(OBJS_DIR)
223
224LINT_KMODS	+= $(GENUNIX_KMODS)
225
226LINT_DEFS	= -Xarch=v9
227
228#
229#	The following must be defined for all implementations:
230#
231#	MAPFILE:		ld mapfile for the build of kernel/unix.
232#	MODSTUBS:		Module stubs source file.
233#	GENCONST_SRC:		genconst.c
234#	OFFSETS:		offsets.in
235#	PLATFORM_OFFSETS:	Platform specific mach_offsets.in
236#	FDOFFSETS:		fd_offsets.in
237#
238MAPFILE		 = $(UTSBASE)/sun4/conf/Mapfile
239MODSTUBS	 = $(UTSBASE)/sparc/ml/modstubs.s
240GENCONST_SRC	 = $(UTSBASE)/sun4/ml/genconst.c
241OFFSETS		 = $(UTSBASE)/sun4/ml/offsets.in
242PLATFORM_OFFSETS = $(UTSBASE)/sun4u/ml/mach_offsets.in
243FDOFFSETS 	 = $(UTSBASE)/sun/io/fd_offsets.in
244
245#
246#	Define the actual specific platforms
247#
248
249MACHINE_DEFS	= -D$(PLATFORM) -D_MACHDEP -DSFMMU
250
251$(MPSAS_BUILD)MACHINE_DEFS      += -DMPSAS
252
253#
254#	Software workarounds for hardware "features"
255#
256
257include $(UTSBASE)/$(PLATFORM)/Makefile.workarounds
258
259#
260#	Debugging level
261#
262#	Special knowledge of which special debugging options effect which
263#	file is used to optimize the build if these flags are changed.
264#
265#	XXX: The above could possibly be done for more flags and files, but
266#	     is left as an experiment to the interested reader. Be forewarned,
267#	     that excessive use could lead to maintenance difficulties.
268#
269#	Note: kslice can be enabled for the sun4u, but is disabled by default
270#	      in all cases.
271#
272
273DEBUG_DEFS_OBJ64	=
274DEBUG_DEFS_DBG64	= -DDEBUG
275DEBUG_DEFS		= $(DEBUG_DEFS_$(BUILD_TYPE))
276
277DEBUG_COND_OBJ64	:sh = echo \\043
278DEBUG_COND_DBG64	= 
279IF_DEBUG_OBJ		= $(DEBUG_COND_$(BUILD_TYPE))$(OBJS_DIR)/
280
281$(IF_DEBUG_OBJ)trap.o		:=	DEBUG_DEFS	+= -DTRAPDEBUG
282$(IF_DEBUG_OBJ)mach_trap.o	:=	DEBUG_DEFS	+= -DTRAPDEBUG
283$(IF_DEBUG_OBJ)syscall_trap.o	:=	DEBUG_DEFS	+= -DSYSCALLTRACE
284$(IF_DEBUG_OBJ)clock.o		:=	DEBUG_DEFS	+= -DKSLICE=0
285
286IF_TRAPTRACE_OBJ = $(IF_DEBUG_OBJ)
287# comment this out for a non-debug kernel with TRAPTRACE
288#IF_TRAPTRACE_OBJ = $(OBJS_DIR)/
289
290$(IF_TRAPTRACE_OBJ)mach_locore.o	:=	DEBUG_DEFS	+= -DTRAPTRACE
291$(IF_TRAPTRACE_OBJ)mlsetup.o		:=	DEBUG_DEFS	+= -DTRAPTRACE
292$(IF_TRAPTRACE_OBJ)syscall_trap.o 	:=	DEBUG_DEFS	+= -DTRAPTRACE
293$(IF_TRAPTRACE_OBJ)startup.o		:=	DEBUG_DEFS	+= -DTRAPTRACE
294$(IF_TRAPTRACE_OBJ)mach_startup.o	:=	DEBUG_DEFS	+= -DTRAPTRACE
295$(IF_TRAPTRACE_OBJ)mp_startup.o		:=	DEBUG_DEFS	+= -DTRAPTRACE
296$(IF_TRAPTRACE_OBJ)cpu_states.o		:=	DEBUG_DEFS	+= -DTRAPTRACE
297$(IF_TRAPTRACE_OBJ)mach_cpu_states.o	:=	DEBUG_DEFS	+= -DTRAPTRACE
298$(IF_TRAPTRACE_OBJ)interrupt.o		:=	DEBUG_DEFS	+= -DTRAPTRACE
299$(IF_TRAPTRACE_OBJ)mach_interrupt.o	:=	DEBUG_DEFS	+= -DTRAPTRACE
300$(IF_TRAPTRACE_OBJ)sfmmu_asm.o		:=	DEBUG_DEFS	+= -DTRAPTRACE
301$(IF_TRAPTRACE_OBJ)trap_table.o		:=	DEBUG_DEFS	+= -DTRAPTRACE
302$(IF_TRAPTRACE_OBJ)xc.o			:=	DEBUG_DEFS	+= -DTRAPTRACE
303$(IF_TRAPTRACE_OBJ)mach_xc.o		:=	DEBUG_DEFS	+= -DTRAPTRACE
304$(IF_TRAPTRACE_OBJ)wbuf.o		:=	DEBUG_DEFS	+= -DTRAPTRACE
305$(IF_TRAPTRACE_OBJ)trap.o		:=	DEBUG_DEFS	+= -DTRAPTRACE
306$(IF_TRAPTRACE_OBJ)mach_trap.o		:=	DEBUG_DEFS	+= -DTRAPTRACE
307$(IF_TRAPTRACE_OBJ)x_call.o		:=	DEBUG_DEFS	+= -DTRAPTRACE
308$(IF_TRAPTRACE_OBJ)spitfire_asm.o	:=	DEBUG_DEFS	+= -DTRAPTRACE
309$(IF_TRAPTRACE_OBJ)us3_common_asm.o	:=	DEBUG_DEFS	+= -DTRAPTRACE
310$(IF_TRAPTRACE_OBJ)us3_cheetah_asm.o	:=	DEBUG_DEFS	+= -DTRAPTRACE
311$(IF_TRAPTRACE_OBJ)us3_cheetahplus_asm.o :=	DEBUG_DEFS	+= -DTRAPTRACE
312$(IF_TRAPTRACE_OBJ)us3_jalapeno_asm.o	:=	DEBUG_DEFS	+= -DTRAPTRACE
313$(IF_TRAPTRACE_OBJ)opl_olympus_asm.o	:=	DEBUG_DEFS	+= -DTRAPTRACE
314
315# Comment these out if you don't want dispatcher lock statistics.
316
317#$(IF_DEBUG_OBJ)lock_prim.o	:= DEBUG_DEFS	+= -DDISP_LOCK_STATS
318#$(IF_DEBUG_OBJ)disp.o		:= DEBUG_DEFS	+= -DDISP_LOCK_STATS
319
320# Comment these out if you don't want dispatcher debugging 
321
322#$(IF_DEBUG_OBJ)lock_prim.o	:= DEBUG_DEFS	+= -DDISP_DEBUG
323
324#
325#	Collect the preprocessor definitions to be associated with *all*
326#	files.
327#
328ALL_DEFS	 = $(MACHINE_DEFS) $(WORKAROUND_DEFS) $(DEBUG_DEFS) \
329		   $(OPTION_DEFS)
330GENCONST_DEFS	 = $(MACHINE_DEFS) $(OPTION_DEFS)
331
332#
333# ----- TRANSITIONAL SECTION --------------------------------------------------
334#
335
336#
337#	Not everything which *should* be a module is a module yet. The
338#	following is a list of such objects which are currently part of
339#	the base kernel but should soon become kmods.
340#
341MACH_NOT_YET_KMODS	 = $(AUTOCONF_OBJS)
342
343#
344# ----- END OF TRANSITIONAL SECTION -------------------------------------------
345#
346
347#
348#	The kernels modules which are "implementation architecture"
349#	specific for this machine are enumerated below. Note that most
350#	of these modules must exist (in one form or another) for each
351#	architecture.
352#
353#	Common Drivers (usually pseudo drivers) (/kernel/drv):
354#
355
356#
357#	Machine Specific Driver Modules (/kernel/drv):
358#
359#	XXX: How many of these are really machine specific?
360#
361DRV_KMODS	+= bbc_beep
362DRV_KMODS	+= cgsix
363DRV_KMODS	+= cpc
364DRV_KMODS	+= dma fd
365DRV_KMODS	+= rootnex sbusmem upa64s zs zsh
366DRV_KMODS	+= sbus
367DRV_KMODS	+= pcisch pcipsy simba
368DRV_KMODS	+= px
369DRV_KMODS	+= ebus
370DRV_KMODS	+= su
371DRV_KMODS	+= tod
372DRV_KMODS	+= power
373DRV_KMODS	+= epic
374DRV_KMODS	+= grbeep
375DRV_KMODS	+= pcf8584 max1617 seeprom tda8444 pca9556
376DRV_KMODS	+= ics951601 adm1031
377DRV_KMODS	+= lm75 ltc1427 pcf8591 pcf8574 ssc050 ssc100
378DRV_KMODS	+= pic16f819
379DRV_KMODS	+= pic16f747
380DRV_KMODS	+= adm1026
381DRV_KMODS	+= us
382DRV_KMODS	+= ppm schppm jbusppm
383DRV_KMODS	+= mc-us3
384DRV_KMODS	+= mc-us3i
385DRV_KMODS       += smbus
386DRV_KMODS	+= db21554
387DRV_KMODS	+= gpio_87317
388DRV_KMODS	+= isadma
389DRV_KMODS	+= sbbc
390DRV_KMODS	+= pmubus
391DRV_KMODS	+= pmugpio
392DRV_KMODS	+= pmc
393DRV_KMODS	+= trapstat
394DRV_KMODS	+= rmc_comm
395DRV_KMODS	+= rmcadm
396DRV_KMODS	+= rmclomv
397DRV_KMODS	+= sf
398DRV_KMODS	+= nxge
399DRV_KMODS	+= i2bsc 
400
401$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= ctsmc
402$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= m1535ppm
403$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= memtest
404$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= mi2cv
405$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= scmi2c
406$(CLOSED_BUILD)CLOSED_DRV_KMODS	+= smbus_ara
407
408#
409#	Exec Class Modules (/kernel/exec):
410#
411EXEC_KMODS	+=
412
413#
414#	Scheduling Class Modules (/kernel/sched):
415#
416SCHED_KMODS	+=
417
418#
419#	File System Modules (/kernel/fs):
420#
421FS_KMODS	+=
422
423#
424#	Streams Modules (/kernel/strmod):
425#
426STRMOD_KMODS	+= kb
427
428#
429#	'System' Modules (/kernel/sys):
430#
431SYS_KMODS	+=
432
433#
434#	'User' Modules (/kernel/misc):
435#
436MISC_KMODS	+= obpsym bootdev vis cpr platmod md5 sha1 i2c_svc
437MISC_KMODS	+= sbd
438
439MISC_KMODS	+= opl_cfg
440MISC_KMODS	+= zuluvm
441MISC_KMODS	+= gptwo_cpu gptwocfg
442
443#
444#	Brand modules
445#
446BRAND_KMODS	+= sn1_brand
447
448#
449#	Software Cryptographic Providers (/kernel/crypto):
450#
451# Don't build some of these for OpenSolaris, since they will be
452# replaced by binaries that are signed by Sun RE.
453#
454$(CLOSED_BUILD)CRYPTO_KMODS	+= aes
455$(CLOSED_BUILD)CRYPTO_KMODS	+= arcfour
456$(CLOSED_BUILD)CRYPTO_KMODS	+= des
457CRYPTO_KMODS	+= rsa
458
459#
460#	generic-unix module (/kernel/genunix):
461#
462GENUNIX_KMODS	+= genunix
463
464#	'User' "Modules" excluded from the Full Kernel lint target:
465#
466$(CLOSED_BUILD)CLOSED_NLMISC_KMODS	+= forthdebug
467
468#
469#	Modules eXcluded from the product:
470#
471XMODS		+=
472
473#
474#	cpu modules
475#
476CPU_KMODS	+= cheetah cheetahplus jalapeno serrano spitfire hummingbird
477
478#
479#	sun4u 'TOD' Modules (/platform/.../kernel/tod):
480#
481TOD_KMODS	+= todds1287 todds1337 todmostek todstarfire 
482TOD_KMODS	+= todm5819 todblade todbq4802 todsg todopl
483TOD_KMODS	+= todm5819p_rmc todstarcat 
484
485$(CLOSED_BUILD)CLOSED_TOD_KMODS	+= todm5823
486
487#
488#	Performance Counter BackEnd Modules (/usr/kernel/pcbe):
489#
490PCBE_KMODS	+= us234_pcbe
491PCBE_KMODS	+= opl_pcbe
492