xref: /titanic_50/usr/src/uts/sun4v/Makefile.files (revision 5829b1c983804e9f5553f65d47f088a97a89700b)
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 sun4v
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 +=	memseg.o
64CORE_OBJS +=	mpo.o
65CORE_OBJS +=	ppage.o
66CORE_OBJS +=	promif_asr.o
67CORE_OBJS +=	promif_cpu.o
68CORE_OBJS +=	promif_emul.o
69CORE_OBJS +=	promif_mon.o
70CORE_OBJS +=	promif_io.o
71CORE_OBJS +=	promif_interp.o
72CORE_OBJS +=	promif_key.o
73CORE_OBJS +=	promif_power_off.o
74CORE_OBJS +=	promif_prop.o
75CORE_OBJS +=	promif_node.o
76CORE_OBJS +=	promif_reboot.o
77CORE_OBJS +=	promif_stree.o
78CORE_OBJS +=	promif_test.o
79CORE_OBJS +=	promif_version.o
80CORE_OBJS +=	sfmmu_kdi.o
81CORE_OBJS +=	swtch.o
82CORE_OBJS +=	wdt.o
83CORE_OBJS +=	kldc.o
84CORE_OBJS +=	xhat_sfmmu.o
85
86CORE_OBJS +=	mdesc_diff.o
87CORE_OBJS +=	mdesc_findname.o
88CORE_OBJS +=	mdesc_findnodeprop.o
89CORE_OBJS +=	mdesc_fini.o
90CORE_OBJS +=	mdesc_getbinsize.o
91CORE_OBJS +=	mdesc_getgen.o
92CORE_OBJS +=	mdesc_getpropdata.o
93CORE_OBJS +=	mdesc_getpropstr.o
94CORE_OBJS +=	mdesc_getpropval.o
95CORE_OBJS +=	mdesc_init_intern.o
96CORE_OBJS +=	mdesc_nodecount.o
97CORE_OBJS +=	mdesc_rootnode.o
98CORE_OBJS +=	mdesc_scandag.o
99
100#
101#	Some objects must be linked at the front of the image (or
102#	near other objects at the front of the image).
103#
104SPECIAL_OBJS +=	trap_table.o
105SPECIAL_OBJS +=	locore.o
106SPECIAL_OBJS +=	mach_locore.o
107SPECIAL_OBJS +=	sfmmu_asm.o
108SPECIAL_OBJS +=	mach_sfmmu_asm.o
109SPECIAL_OBJS +=	interrupt.o
110SPECIAL_OBJS +=	mach_interrupt.o
111SPECIAL_OBJS +=	wbuf.o
112SPECIAL_OBJS += hcall.o
113SPECIAL_OBJS += intrq.o
114
115#
116#			driver modules
117#
118ROOTNEX_OBJS	+= mach_rootnex.o
119PX_OBJS		+= px_lib4v.o px_err.o px_tools_4v.o px_hcall.o px_libhv.o
120FPC_OBJS	+= fpc-impl-4v.o fpc-asm-4v.o
121N2PIUPC_OBJS	+= n2piupc.o n2piupc_tables.o n2piupc_kstats.o \
122			n2piupc_biterr.o n2piupc_asm.o
123TRAPSTAT_OBJS	+= trapstat.o
124NIUMX_OBJS	+= niumx.o
125N2RNG_OBJS	+= n2rng.o n2rng_debug.o n2rng_hcall.o n2rng_kcf.o \
126		   n2rng_entp_algs.o n2rng_entp_setup.o n2rng_kstat.o \
127		   n2rng_provider.o
128
129#
130# 			CPU/Memory Error Injector (memtest) sun4v driver
131#
132MEMTEST_OBJS	+= memtest.o memtest_asm.o \
133			memtest_v.o memtest_v_asm.o \
134			memtest_ni.o memtest_ni_asm.o \
135			memtest_n2.o memtest_n2_asm.o \
136			memtest_vf.o
137
138#
139#			sun4v virtual devices
140#
141QCN_OBJS	= qcn.o
142VNEX_OBJS	= vnex.o
143CNEX_OBJS	= cnex.o
144GLVC_OBJS	= glvc.o glvc_hcall.o
145MDESC_OBJS	= mdesc.o
146LDC_OBJS	= ldc.o ldc_shm.o vio_util.o vdsk_common.o vgen_stats.o \
147			vnet_common.o
148NTWDT_OBJS	= ntwdt.o
149VLDC_OBJS	= vldc.o
150VCC_OBJS	= vcc.o
151VNET_OBJS	= vnet.o vnet_gen.o vnet_dds.o vnet_dds_hcall.o
152VSW_OBJS	= vsw.o vsw_ldc.o vsw_phys.o vsw_switching.o vsw_hio.o
153VDC_OBJS	= vdc.o
154VDS_OBJS	= vds.o
155DS_PRI_OBJS	= ds_pri.o
156DS_SNMP_OBJS	= ds_snmp.o
157VLDS_OBJS	= vlds.o
158
159#
160#			Misc modules
161#
162BOOTDEV_OBJS	+= bootdev.o
163DR_CPU_OBJS	+= dr_cpu.o
164DR_IO_OBJS	+= dr_io.o
165DR_MEM_OBJS	+= dr_mem.o
166DRCTL_OBJS	= drctl.o drctl_impl.o dr_util.o
167DS_OBJS		= ds_common.o ds_drv.o
168FAULT_ISO_OBJS	= fault_iso.o
169OBPSYM_OBJS	+= obpsym.o obpsym_1275.o
170PLATSVC_OBJS	= platsvc.o mdeg.o
171
172#
173#			Brand modules
174#
175SN1_BRAND_OBJS		= sn1_brand.o sn1_brand_asm.o
176
177#
178#			Performance Counter BackEnd (PCBE) Modules
179#
180NI_PCBE_OBJS	= niagara_pcbe.o
181N2_PCBE_OBJS	= niagara2_pcbe.o
182
183#
184#			cpu modules
185#
186CPU_OBJ		+= $(OBJS_DIR)/mach_cpu_module.o
187GENERIC_OBJS = generic.o generic_copy.o common_asm.o atomic.o
188NIAGARACPU_OBJS = niagara.o niagara_copy.o common_asm.o niagara_perfctr.o
189NIAGARACPU_OBJS += niagara_asm.o atomic.o
190NIAGARA2CPU_OBJS = niagara2.o niagara_copy.o common_asm.o niagara_perfctr.o
191NIAGARA2CPU_OBJS += niagara2_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