xref: /titanic_52/usr/src/uts/sun4v/Makefile.files (revision d20abfaa275f62e387fe9d814375fb3829fdb91f)
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 2009 Sun Microsystems, Inc.  All rights reserved.
24# Use is subject to license terms.
25#
26#	This Makefile defines all file modules for the directory uts/sun4v
27#	and it's children. These are the source files which are sun4u
28#	"implementation architecture" dependent.
29#
30
31#
32#	object lists
33#
34CORE_OBJS +=	bootops.o
35CORE_OBJS +=	cmp.o
36CORE_OBJS +=	cpc_hwreg.o
37CORE_OBJS +=	cpc_subr.o
38CORE_OBJS +=	error.o
39CORE_OBJS +=	fillsysinfo.o
40CORE_OBJS +=	forthdebug.o
41CORE_OBJS +=	hardclk.o
42CORE_OBJS +=	hat_sfmmu.o
43CORE_OBJS +=	hat_kdi.o
44CORE_OBJS +=	hsvc.o
45CORE_OBJS +=	iscsi_boot.o
46CORE_OBJS +=	lpad.o
47CORE_OBJS +=	mach_cpu_states.o
48CORE_OBJS +=	mach_ddi_impl.o
49CORE_OBJS +=	mach_descrip.o
50CORE_OBJS +=	mach_kpm.o
51CORE_OBJS +=	mach_mp_startup.o
52CORE_OBJS +=	mach_mp_states.o
53CORE_OBJS +=	mach_proc_init.o
54CORE_OBJS +=	mach_sfmmu.o
55CORE_OBJS +=	mach_startup.o
56CORE_OBJS +=	mach_subr_asm.o
57CORE_OBJS +=	mach_trap.o
58CORE_OBJS +=	mach_vm_dep.o
59CORE_OBJS +=	mach_xc.o
60CORE_OBJS +=	mem_cage.o
61CORE_OBJS +=	mem_config.o
62CORE_OBJS +=	memlist_new.o
63CORE_OBJS +=	mpo.o
64CORE_OBJS +=	ppage.o
65CORE_OBJS +=	promif_asr.o
66CORE_OBJS +=	promif_cpu.o
67CORE_OBJS +=	promif_emul.o
68CORE_OBJS +=	promif_mon.o
69CORE_OBJS +=	promif_io.o
70CORE_OBJS +=	promif_interp.o
71CORE_OBJS +=	promif_key.o
72CORE_OBJS +=	promif_power_off.o
73CORE_OBJS +=	promif_prop.o
74CORE_OBJS +=	promif_node.o
75CORE_OBJS +=	promif_reboot.o
76CORE_OBJS +=	promif_stree.o
77CORE_OBJS +=	promif_test.o
78CORE_OBJS +=	promif_version.o
79CORE_OBJS +=	sfmmu_kdi.o
80CORE_OBJS +=	swtch.o
81CORE_OBJS +=	wdt.o
82CORE_OBJS +=	kldc.o
83CORE_OBJS +=	xhat_sfmmu.o
84
85CORE_OBJS +=	mdesc_diff.o
86CORE_OBJS +=	mdesc_findname.o
87CORE_OBJS +=	mdesc_findnodeprop.o
88CORE_OBJS +=	mdesc_fini.o
89CORE_OBJS +=	mdesc_getbinsize.o
90CORE_OBJS +=	mdesc_getgen.o
91CORE_OBJS +=	mdesc_getpropdata.o
92CORE_OBJS +=	mdesc_getpropstr.o
93CORE_OBJS +=	mdesc_getpropval.o
94CORE_OBJS +=	mdesc_init_intern.o
95CORE_OBJS +=	mdesc_nodecount.o
96CORE_OBJS +=	mdesc_rootnode.o
97CORE_OBJS +=	mdesc_scandag.o
98
99#
100#	Some objects must be linked at the front of the image (or
101#	near other objects at the front of the image).
102#
103SPECIAL_OBJS +=	trap_table.o
104SPECIAL_OBJS +=	locore.o
105SPECIAL_OBJS +=	mach_locore.o
106SPECIAL_OBJS +=	sfmmu_asm.o
107SPECIAL_OBJS +=	mach_sfmmu_asm.o
108SPECIAL_OBJS +=	interrupt.o
109SPECIAL_OBJS +=	mach_interrupt.o
110SPECIAL_OBJS +=	wbuf.o
111SPECIAL_OBJS += hcall.o
112SPECIAL_OBJS += intrq.o
113
114#
115#			driver modules
116#
117ROOTNEX_OBJS	+= mach_rootnex.o
118PX_OBJS		+= px_lib4v.o px_err.o px_tools_4v.o px_hcall.o px_libhv.o
119FPC_OBJS	+= fpc-impl-4v.o fpc-asm-4v.o
120N2PIUPC_OBJS	+= n2piupc.o n2piupc_tables.o n2piupc_kstats.o \
121			n2piupc_biterr.o n2piupc_asm.o
122TRAPSTAT_OBJS	+= trapstat.o
123NIUMX_OBJS	+= niumx.o
124N2RNG_OBJS	+= n2rng.o n2rng_debug.o n2rng_hcall.o n2rng_kcf.o \
125		   n2rng_entp_algs.o n2rng_entp_setup.o n2rng_kstat.o \
126		   n2rng_provider.o
127
128#
129# 			CPU/Memory Error Injector (memtest) sun4v driver
130#
131MEMTEST_OBJS	+= memtest.o memtest_asm.o \
132			memtest_v.o memtest_v_asm.o \
133			memtest_ni.o memtest_ni_asm.o \
134			memtest_n2.o memtest_n2_asm.o \
135			memtest_vf.o
136
137#
138#			sun4v virtual devices
139#
140QCN_OBJS	= qcn.o
141VNEX_OBJS	= vnex.o
142CNEX_OBJS	= cnex.o
143GLVC_OBJS	= glvc.o glvc_hcall.o
144MDESC_OBJS	= mdesc.o
145LDC_OBJS	= ldc.o ldc_shm.o vio_util.o vdsk_common.o vgen_stats.o \
146			vnet_common.o
147NTWDT_OBJS	= ntwdt.o
148VLDC_OBJS	= vldc.o
149VCC_OBJS	= vcc.o
150VNET_OBJS	= vnet.o vnet_gen.o vnet_dds.o vnet_dds_hcall.o
151VSW_OBJS	= vsw.o vsw_ldc.o vsw_phys.o vsw_switching.o vsw_hio.o
152VDC_OBJS	= vdc.o
153VDS_OBJS	= vds.o
154DS_PRI_OBJS	= ds_pri.o
155DS_SNMP_OBJS	= ds_snmp.o
156VLDS_OBJS	= vlds.o
157
158#
159#			Misc modules
160#
161BOOTDEV_OBJS	+= bootdev.o
162DR_CPU_OBJS	+= dr_cpu.o
163DR_IO_OBJS	+= dr_io.o
164DRCTL_OBJS	= drctl.o drctl_impl.o dr_util.o
165DS_OBJS		= ds_common.o ds_drv.o
166FAULT_ISO_OBJS	= fault_iso.o
167OBPSYM_OBJS	+= obpsym.o obpsym_1275.o
168PLATSVC_OBJS	= platsvc.o mdeg.o
169
170#
171#			Brand modules
172#
173SN1_BRAND_OBJS		= sn1_brand.o sn1_brand_asm.o
174
175#
176#			Performance Counter BackEnd (PCBE) Modules
177#
178NI_PCBE_OBJS	= niagara_pcbe.o
179N2_PCBE_OBJS	= niagara2_pcbe.o
180RK_PCBE_OBJS	= rock_pcbe.o
181
182#
183#			cpu modules
184#
185CPU_OBJ		+= $(OBJS_DIR)/mach_cpu_module.o
186GENERIC_OBJS = generic.o generic_copy.o common_asm.o atomic.o
187NIAGARACPU_OBJS = niagara.o niagara_copy.o common_asm.o niagara_perfctr.o
188NIAGARACPU_OBJS += niagara_asm.o atomic.o
189NIAGARA2CPU_OBJS = niagara2.o niagara_copy.o common_asm.o niagara_perfctr.o
190NIAGARA2CPU_OBJS += niagara2_asm.o atomic.o
191ROCKCPU_OBJS = rock.o rock_copy.o common_asm.o rock_asm.o atomic.o
192
193#
194#			platform module
195#
196PLATMOD_OBJS	= platmod.o
197
198#	Section 3:	Misc.
199#
200ALL_DEFS	+= -Dsun4u -Dsun4v
201INC_PATH	+= -I$(UTSBASE)/sun4v
202#
203# Since assym.h is a derived file, the dependency must be explicit for
204# all files including this file. (This is only actually required in the
205# instance when the .make.state file does not exist.) It may seem that
206# the lint targets should also have a similar dependency, but they don't
207# since only C headers are included when #defined(lint) is true.
208#
209ASSYM_DEPS	+= mach_locore.o
210ASSYM_DEPS	+= module_sfmmu_asm.o
211ASSYM_DEPS	+= generic_asm.o generic_copy.o
212ASSYM_DEPS	+= niagara_copy.o niagara_asm.o niagara2_asm.o
213ASSYM_DEPS	+= mach_subr_asm.o swtch.o
214ASSYM_DEPS	+= mach_interrupt.o mach_xc.o
215ASSYM_DEPS	+= trap_table.o wbuf.o
216ASSYM_DEPS	+= mach_sfmmu_asm.o sfmmu_asm.o
217
218#
219#			kernel cryptographic framework
220#
221
222ARCFOUR_OBJS	+= arcfour.o arcfour_crypt.o
223
224