xref: /illumos-gate/usr/src/psm/stand/boot/sparcv9/sun4v/Makefile (revision 437220cd296f6d8b6654d6d52508b40b1e2d1ac7)
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# Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
23# Use is subject to license terms.
24#
25#ident	"%Z%%M%	%I%	%E% SMI"
26#
27
28TOPDIR =	../../../../..
29
30include $(TOPDIR)/uts/Makefile.uts
31
32MODULE	= fs
33
34PLATLINKS	= SUNW,Sun-Fire-T200
35PLATLINKS	+= SUNW,Netra-CP3060
36PLATLINKS	+= SUNW,Netra-CP3260
37PLATLINKS	+= SUNW,Sun-Blade-T6300
38PLATLINKS	+= SUNW,Sun-Blade-T6320
39PLATLINKS	+= SUNW,SPARC-Enterprise-T5120
40PLATLINKS	+= SUNW,T5140
41
42LINKED_DIRS	= $(PLATLINKS:%=$(USR_PLAT_DIR)/%)
43LINKED_LIB_DIRS	= $(PLATLINKS:%=$(USR_PLAT_DIR)/%/lib)
44LINKED_LIB_FS_DIRS	= $(PLATLINKS:%=$(USR_PLAT_DIR)/%/lib/fs)
45
46all	:=	TARGET = all
47install	:=	TARGET = install
48clean	:=	TARGET = clean
49
50TARG_MACH =	sparcv9
51TARG_MACH_DIR =	sparcv9
52ARCHVERS =	v9
53PLATFORM =	sun4v
54ARCHMMU  =	sfmmu
55PROMVERS =	ieee1275
56ASFLAGS +=	$(sparcv9_XARCH)
57
58PLAT_C_SRC =	machdep.c
59ARCH_C_SRC =	sun4u_memlist.c sun4x_standalloc.c sun4dep.c
60ARCH_S_SRC =	sparcv9_subr.s
61SRT0_S =	sun4u_srt0.s
62INLINES =
63
64LDFLAGS +=	-L$(TOPDIR)/psm/stand/lib/promif/$(TARG_MACH)/$(PROMVERS)/common
65
66#
67# The following libraries are build in LIBPLAT_DIR
68#
69LIBPLAT_DIR =	$(TOPDIR)/psm/stand/lib/promif/$(TARG_MACH)/$(PROMVERS)/$(PLATFORM)
70LIBPLAT_LIBS =  libplat.a
71LIBPLAT_L_LIBS=	$(LIBPLAT_LIBS:lib%.a=llib-l%.ln)
72LIBPLAT_DEP = 	$(LIBPLAT_DIR)/$(LIBPLAT_LIBS)
73LIBPLAT_DEP_L =	$(LIBPLAT_DIR)/$(LIBPLAT_L_LIBS)
74
75#
76# Platform specific libraries
77#
78PSMLIBS +=      $(LIBPLAT_LIBS:lib%.a=-l%)
79PSMLIB_DIRS +=  $(LIBPLAT_DIR)
80
81
82#	MPSAS support
83MPSAS_BUILD:sh=		echo \\043
84$(MPSAS_BUILD)ARCHOPTS += -DMPSAS
85
86include ../Makefile.com
87
88CPPINCS		+= -I$(SRC)/uts/sun4u
89CPPINCS		+= -I$(ROOT)/usr/platform/sun4u/include
90
91# re-define ELFCONV for 4v--- sun4v can boot ELF directly
92ELFCONV = /usr/bin/cp
93
94# Don't need mapfile.inet for 4v inetboot
95NFS_MAPFILE = $(MACH_DIR)/mapfile
96
97#
98# Set the choice of compiler.
99
100include $(TOPDIR)/psm/Makefile.psm.64
101
102CFLAGS64	+= -xchip=ultra $(CCABS32)
103
104#
105# XXX this totally sucks since it effectively turns off -errchk=longptr64,
106# which we really should be using.
107#
108LINTFLAGS64 = $(LINTFLAGS) -Xarch=v9
109
110#
111# Cross-reference customization: include all boot-related source files.
112#
113STANDLIBDIR=	../../../../../stand/lib
114STANDSYSDIR=	../../../../../stand/sys
115PROMDIRS=	../../../../promif
116NAMESDIRS=	../../../lib/names/sparcv9 ../../../lib/names/sparc/common
117XRDIRS +=	../../sparc/common ../../common $(STANDLIBDIR) \
118		$(STANDSYSDIR) $(PROMDIRS) $(NAMESDIRS)
119XRPRUNE =	i86pc i386
120
121cscope.out tags: FRC
122	$(XREF) -x $@
123
124FRC:
125