usr/src/uts/sun4u/serengeti/cheetahplus/Makefile
author wesolows
Tue, 20 Sep 2005 15:07:36 -0700
changeset 580 70dfd36fd02c
parent 0 68f95e015346
child 10207 87c40ea3fc4b
permissions -rw-r--r--
6237094 perl build should honor $(CC) 6272179 relocation processing should be bypassed when building libgenunix et al 6307198 Need to pass in -save_args option when the new gcc is available 6310495 gcc and sun4 rootnex don't get along 6310534 new gcc options should be used to build ON 6319181 cw needs -xbuiltin support
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
580
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
     5
# Common Development and Distribution License (the "License").
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
     6
# You may not use this file except in compliance with the License.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     7
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     8
# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     9
# or http://www.opensolaris.org/os/licensing.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    10
# See the License for the specific language governing permissions
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    11
# and limitations under the License.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    12
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    13
# When distributing Covered Code, include this CDDL HEADER in each
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    14
# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    15
# If applicable, add the following below this CDDL HEADER, with the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    16
# fields enclosed by brackets "[]" replaced with your own identifying
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    17
# information: Portions Copyright [yyyy] [name of copyright owner]
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    18
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    19
# CDDL HEADER END
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    20
#
580
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
    21
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    22
#
580
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
    23
# Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
0
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
#
580
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
    26
# ident	"%Z%%M%	%I%	%E% SMI"
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
    27
#
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
    28
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    29
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    30
#	This makefile drives the production of the Serengeti
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    31
#	UltraSPARC driver module.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    32
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    33
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    34
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    35
#	Path to the base of the uts directory tree (usually /usr/src/uts).
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    36
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    37
UTSBASE	= ../../..
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    38
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    39
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    40
#	Define the module and object file sets.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    41
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    42
MODULE		= SUNW,UltraSPARC-III+
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    43
OBJECTS		= $(CHEETAHPLUS_OBJS:%=$(OBJS_DIR)/%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    44
LINTS		= $(CHEETAHPLUS_OBJS:%.o=$(LINTS_DIR)/%.ln)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    45
ROOTMODULE	= $(ROOT_SERENGETI_CPU_DIR)/$(MODULE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    46
SOFTLINKS	= SUNW,UltraSPARC-IV SUNW,UltraSPARC-IV+
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    47
ROOTSOFTLINKS	= $(SOFTLINKS:%=$(ROOT_SERENGETI_CPU_DIR)/%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    48
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    49
CPU_DIR		= .
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    50
HERE		= ../cheetahplus
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    51
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    52
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    53
#	Include common rules.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    54
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    55
include $(UTSBASE)/sun4u/serengeti/Makefile.serengeti
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    56
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    57
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    58
#	Override defaults
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    59
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    60
CLEANFILES	+= $(CPULIB) $(SYM_MOD)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    61
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    62
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    63
#	Define targets
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    64
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    65
SYM_MOD		= $(OBJS_DIR)/unix.sym
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    66
ALL_TARGET	= $(SYM_MOD)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    67
LINT_TARGET	= $(MODULE).lint
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    68
INSTALL_TARGET	= def $(BINARY) $(ROOTMODULE) $(ROOTSOFTLINKS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    69
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    70
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    71
#	Overrides
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    72
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    73
ALL_BUILDS	= $(ALL_BUILDSONLY64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    74
DEF_BUILDS	= $(DEF_BUILDSONLY64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    75
CLEANLINTFILES	+= $(LINT32_FILES)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    76
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    77
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    78
# lint pass one enforcement
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    79
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    80
CFLAGS += $(CCVERBOSE) -DCHEETAH -DCHEETAH_PLUS -DCPU_IMP_L1_CACHE_PARITY \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    81
	     -DCPU_IMP_ECACHE_ASSOC -DCPU_IMP_DUAL_PAGESIZE -DCPU_IMP_AFSR_EXT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    82
ASFLAGS +=  -DCHEETAH -DCHEETAH_PLUS -DCPU_IMP_L1_CACHE_PARITY \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    83
	    -DCPU_IMP_ECACHE_ASSOC -DCPU_IMP_DUAL_PAGESIZE -DCPU_IMP_AFSR_EXT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    84
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    85
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    86
# cpu-module-specific flags
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    87
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    88
CPPFLAGS += -DCPU_MODULE -DCHEETAH -DCHEETAH_PLUS -DCPU_IMP_L1_CACHE_PARITY \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    89
	    -DCPU_IMP_ECACHE_ASSOC -DCPU_IMP_DUAL_PAGESIZE -DCPU_IMP_AFSR_EXT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    90
AS_CPPFLAGS += -DCPU_MODULE -DCHEETAH -DCHEETAH_PLUS -DCPU_IMP_L1_CACHE_PARITY \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    91
	       -DCPU_IMP_ECACHE_ASSOC -DCPU_IMP_DUAL_PAGESIZE -DCPU_IMP_AFSR_EXT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    92
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    93
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    94
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    95
#	Default build targets.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    96
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    97
.KEEP_STATE:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    98
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    99
def:		$(DEF_DEPS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   100
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   101
all:		$(ALL_DEPS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   102
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   103
clean:		$(CLEAN_DEPS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   104
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   105
clobber:	$(CLOBBER_DEPS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   106
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   107
lint:		$(LINT_DEPS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   108
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   109
modlintlib:	$(MODLINTLIB_DEPS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   110
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   111
clean.lint:	$(CLEAN_LINT_DEPS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   112
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   113
install:	$(INSTALL_DEPS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   114
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   115
$(CPULIB):	$(BINARY)
580
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
   116
	$(BUILD.SO) $(BINARY)
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   117
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   118
$(SYM_MOD):	$(UNIX_O) $(CPULIB)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   119
	@echo "resolving symbols against unix.o"
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   120
	@echo $(UNIX_DIR)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   121
	@echo $(OBJS_DIR)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   122
	@(cd $(UNIX_DIR); pwd; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   123
	    CPU_DIR=$(HERE) SYM_MOD=$(HERE)/$(SYM_MOD) $(MAKE) symcheck)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   124
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   125
$(ROOTSOFTLINKS): $(ROOTMODULE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   126
	$(RM) $@; $(SYMLINK) $(MODULE) $@ $(CHOWNLINK) $(CHGRPLINK)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   127
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   128
#	Include common targets.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   129
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   130
include $(UTSBASE)/sun4u/serengeti/Makefile.targ