usr/src/psm/stand/lib/promif/sparcv9/ieee1275/sun4v/Makefile
author stevel@tonic-gate
Tue, 14 Jun 2005 00:00:00 -0700
changeset 0 68f95e015346
child 5648 161f8007cab9
permissions -rw-r--r--
OpenSolaris Launch
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     1
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     2
# CDDL HEADER START
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     3
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     4
# The contents of this file are subject to the terms of the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     5
# Common Development and Distribution License, Version 1.0 only
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     6
# (the "License").  You may not use this file except in compliance
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     7
# with the License.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     8
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     9
# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    10
# or http://www.opensolaris.org/os/licensing.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    11
# See the License for the specific language governing permissions
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    12
# and limitations under the License.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    13
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    14
# When distributing Covered Code, include this CDDL HEADER in each
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    15
# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    16
# If applicable, add the following below this CDDL HEADER, with the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    17
# fields enclosed by brackets "[]" replaced with your own identifying
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    18
# information: Portions Copyright [yyyy] [name of copyright owner]
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    19
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    20
# CDDL HEADER END
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    21
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    22
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    23
# Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    24
# Use is subject to license terms.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    25
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    26
# psm/stand/boot/sparcv9/ieee1275/sun4v/Makefile
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    27
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    28
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    29
#ident	"%Z%%M%	%I%	%E% SMI"
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    30
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    31
TOPDIR =	../../../../../../..
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    33
include $(TOPDIR)/Makefile.master
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    34
include $(TOPDIR)/lib/Makefile.lib
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    35
include $(TOPDIR)/psm/stand/lib/Makefile.lib
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    36
include $(TOPDIR)/psm/Makefile.psm.64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    37
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    38
CFLAGS64	+= -xchip=ultra $(CCABS32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    39
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    40
PLATDIR =	$(TOPDIR)/psm/promif/ieee1275/sun4u
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    41
PLATSUN4DIR =	$(TOPDIR)/psm/promif/ieee1275/sun4
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    42
SYSDIR =	$(TOPDIR)/uts
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    43
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    44
LIBPLAT =	libplat.a
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    45
LINTLIBPLAT =	llib-lplat.ln
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    46
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    47
PLAT_PFILES = 			\
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    48
	prom_heartbeat.c	\
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    49
	prom_mmu.c		\
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    50
	prom_vercheck.c
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    51
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    52
PLAT_PSUN4FILES =		\
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    53
	prom_alloc.c		\
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    54
	prom_cpuctl.c		\
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    55
	prom_getunum.c		\
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    56
	prom_idprom.c		\
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    57
	prom_init.c		\
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    58
	prom_macaddr.c		\
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    59
	prom_map.c		\
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    60
	prom_mem.c		\
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    61
	prom_retain.c		\
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    62
	prom_sparc.c
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    63
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    64
KARCH =		sun4v
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    65
MMU =		sfmmu
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    66
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    67
OBJSDIR =	objs
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    68
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    69
PLAT_POBJ =	$(PLAT_PFILES:%.c=$(OBJSDIR)/%.o)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    70
PLAT_PSUN4OBJ =	$(PLAT_PSUN4FILES:%.c=$(OBJSDIR)/%.o)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    71
OBJS =		$(PLAT_POBJ) $(PLAT_PSUN4OBJ)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    72
L_OBJS =	$(OBJS:%.o=%.ln)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    73
L_SRCS = 	$(PLAT_PFILES:%=$(PLATDIR)/%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    74
L_SRCS += 	$(PLAT_PSUN4FILES:%=$(PLATSUN4DIR)/%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    75
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    76
ARCHOPTS=	-Dsun4v
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    77
ASFLAGS =	-P -D__STDC__ -D_BOOT -D_ASM
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    78
CPPDEFS	=	$(ARCHOPTS) -D$(KARCH) -D_BOOT -D_KERNEL -D_MACHDEP
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    79
CPPINCS =	-I. -I$(SYSDIR)/sun4 -I$(SYSDIR)/$(KARCH) -I$(SYSDIR)/$(MMU) \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    80
		-I$(SYSDIR)/sun4u \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    81
		-I$(SYSDIR)/sparc/v9 -I$(SYSDIR)/sparc \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    82
		-I$(SYSDIR)/sun -I$(SYSDIR)/common
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    83
CPPFLAGS=	$(CPPDEFS) $(CPPINCS) $(CPPFLAGS.master)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    84
CFLAGS +=	$(CCVERBOSE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    85
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    86
.KEEP_STATE:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    87
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    88
.PARALLEL:	$(OBJS) $(L_OBJS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    89
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    90
all install: $(LIBPLAT)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    91
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    92
lint: $(LINTLIBPLAT)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    93
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    94
clean:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    95
	$(RM) $(OBJS) $(L_OBJS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    96
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    97
clobber: clean
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    98
	$(RM) $(LIBPLAT) $(LINTLIBPLAT) a.out core
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    99
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   100
$(LIBPLAT): $(OBJSDIR) .WAIT $(OBJS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   101
	$(BUILD.AR) $(OBJS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   102
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   103
$(LINTLIBPLAT): $(OBJSDIR) .WAIT $(L_OBJS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   104
	@$(ECHO) "\nlint library construction:" $@
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   105
	@$(LINT.lib) -o plat $(L_SRCS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   106
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   107
$(OBJSDIR):
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   108
	-@[ -d $@ ] || mkdir $@
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   109
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   110
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   111
# build rules using standard library object subdirectory
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   112
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   113
$(OBJSDIR)/%.o: $(PLATDIR)/%.c
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   114
	$(COMPILE.c) -o $@ $<
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   115
	$(POST_PROCESS_O)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   116
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   117
$(OBJSDIR)/%.o: $(PLATDIR)/%.s
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   118
	$(COMPILE.s) -o $@ $<
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   119
	$(POST_PROCESS_O)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   120
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   121
$(OBJSDIR)/%.o: $(PLATSUN4DIR)/%.c
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   122
	$(COMPILE.c) -o $@ $<
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   123
	$(POST_PROCESS_O)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   124
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   125
$(OBJSDIR)/%.o: $(PLATSUN4DIR)/%.s
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   126
	$(COMPILE.s) -o $@ $<
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   127
	$(POST_PROCESS_O)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   128
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   129
$(OBJSDIR)/%.ln: $(PLATDIR)/%.c
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   130
	@($(LHEAD) $(LINT.c) $< $(LTAIL))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   131
	@$(MV) $(@F) $@
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   132
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   133
$(OBJSDIR)/%.ln: $(PLATDIR)/%.s
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   134
	@($(LHEAD) $(LINT.s) $< $(LTAIL))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   135
	@$(MV) $(@F) $@
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   136
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   137
$(OBJSDIR)/%.ln: $(PLATSUN4DIR)/%.c
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   138
	@($(LHEAD) $(LINT.c) $< $(LTAIL))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   139
	@$(MV) $(@F) $@
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   140
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   141
$(OBJSDIR)/%.ln: $(PLATSUN4DIR)/%.s
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   142
	@($(LHEAD) $(LINT.s) $< $(LTAIL))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   143
	@$(MV) $(@F) $@