usr/src/uts/sun4u/genunix/Makefile
author wesolows
Tue, 20 Sep 2005 15:07:36 -0700
changeset 580 70dfd36fd02c
parent 0 68f95e015346
child 3066 2a2af34f0642
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
#
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
#
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 generic
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    31
#	unix kernel module.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    32
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    33
#	sparc implementation architecture dependent
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    34
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    35
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    36
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    37
#	Path to the base of the uts directory tree (usually /usr/src/uts).
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    38
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    39
UTSBASE	= ../..
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    40
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    41
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    42
#	Define the module and object file sets.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    43
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    44
MODULE		= genunix
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    45
GENUNIX		= $(OBJS_DIR)/$(MODULE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    46
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    47
OBJECTS		= $(GENUNIX_OBJS:%=$(OBJS_DIR)/%) \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    48
		  $(NOT_YET_KMODS:%=$(OBJS_DIR)/%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    49
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    50
LINTS		= $(GENUNIX_OBJS:%.o=$(LINTS_DIR)/%.ln) \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    51
		  $(NOT_YET_KMODS:%.o=$(LINTS_DIR)/%.ln)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    52
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    53
ROOTMODULE	= $(ROOT_PSM_KERN_DIR)/$(MODULE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    54
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    55
PLATFORM	= sun4u
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    56
LIBGEN		= $(OBJS_DIR)/libgenunix.so
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    57
LIBSTUBS	= $(GENSTUBS_OBJS:%=$(OBJS_DIR)/%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    58
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    59
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    60
#	Include common rules.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    61
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    62
include $(UTSBASE)/sparc/Makefile.sparc
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    63
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    64
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    65
#	Define targets
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    66
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    67
ALL_TARGET	= $(LIBGEN)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    68
LINT_TARGET	= $(MODULE).lint
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    69
INSTALL_TARGET	= $(GENUNIX) $(ROOTMODULE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    70
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    71
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    72
#	Override defaults
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    73
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    74
CLEANFILES	+= $(LIBSTUBS) $(LIBGEN)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    75
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    76
LINT_LIB_DIR	= $(UTSBASE)/$(PLATFORM)/lint-libs/$(OBJS_DIR)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    77
LINT_LIB	= $(LINT_LIB_DIR)/llib-lunix.ln
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    78
GEN_LINT_LIB	=
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    79
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    80
BINARY		=
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    81
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    82
CLOBBERFILES	+= $(GENUNIX)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    83
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    84
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    85
# Non-patch genunix builds merge a version of the ip module called ipctf.  This
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    86
# is to ensure that the common network-related types are included in genunix and
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    87
# can thus be uniquified out of other modules.  We don't want to do this for
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    88
# patch builds, since we can't guarantee that ip and genunix will be in the same
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    89
# patch.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    90
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    91
IPCTF_TARGET	= $(IPCTF)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    92
$(PATCH_BUILD)IPCTF_TARGET =
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
# lint pass one enforcement 
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    96
# 
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    97
CFLAGS += $(CCVERBOSE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    98
CPPFLAGS += -I$(SRC)/common
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    99
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   100
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   101
#	Default build targets.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   102
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   103
.KEEP_STATE:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   104
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   105
.PARALLEL:	$(LIBSTUBS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   106
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   107
def:		$(DEF_DEPS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   108
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   109
all:		$(ALL_DEPS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   110
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   111
clean:		$(CLEAN_DEPS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   112
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   113
clobber:	$(CLOBBER_DEPS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   114
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   115
lint:		$(LINT_DEPS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   116
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   117
modlintlib:	$(MODLINTLIB_DEPS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   118
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   119
clean.lint:	$(CLEAN_LINT_DEPS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   120
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   121
install:  	$(INSTALL_DEPS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   122
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   123
$(LIBGEN):	$(GENUNIX) $(LIBSTUBS)
580
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
   124
	$(BUILD.SO) $(GENUNIX) $(LIBSTUBS)
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   125
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   126
$(IPCTF_TARGET) ipctf_target: FRC
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   127
	@cd $(IPDRV_DIR); pwd; $(MAKE) ipctf.$(OBJS_DIR)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   128
	@pwd
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   129
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   130
$(GENUNIX): $(IPCTF_TARGET) $(OBJECTS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   131
	$(LD) -r $(LDFLAGS) -o $@ $(OBJECTS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   132
	$(CTFMERGE_GENUNIX_MERGE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   133
	$(POST_PROCESS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   134
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   135
$(OBJECTS): $(OBJS_DIR)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   136
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   137
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   138
#	Include common targets.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   139
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   140
include $(UTSBASE)/sparc/Makefile.targ
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   141
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   142
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   143
#	Include sun4u workarounds.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   144
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   145
include $(UTSBASE)/sun4u/Makefile.workarounds
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   146
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   147
ALL_DEFS +=	$(WORKAROUND_DEFS)