usr/src/uts/Makefile.uts
author wesolows
Tue, 20 Sep 2005 15:07:36 -0700
changeset 580 70dfd36fd02c
parent 0 68f95e015346
child 1002 07d048eb5eb1
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
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    26
# ident	"%Z%%M%	%I%	%E% SMI"
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    27
#
580
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
    28
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
    29
#
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    30
#	This Makefile contains the common targets and definitions for
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    31
#	all kernels. It is to be included in the Makefiles for specific
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    32
#	implementation architectures and processor architecture dependent
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    33
#	modules: i.e.: all driving kernel Makefiles.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    34
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    35
#	Include global definitions:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    36
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    37
include $(SRC)/Makefile.master
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
#	No text domain in the kernel.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    41
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    42
DTEXTDOM =
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    43
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    44
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    45
# 	Keep references to $(SRC)/common relative.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    46
COMMONBASE=	$(UTSBASE)/../common
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    47
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    48
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    49
#	Setup build-specific vars
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    50
#	To add a build type:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    51
#		add name to ALL_BUILDS32 & ALL_BUILDS64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    52
#		set CLASS_name and OBJ_DIR_name
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    53
#		add targets to Makefile.targ
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    54
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    55
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    56
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    57
#	DEF_BUILDS is for def, lint and install
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    58
#	ALL_BUILDS is for everything else (all, clean, ...)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    59
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    60
# The NOT_RELEASE_BUILD noise is to maintain compatibility with the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    61
# gatekeeper's nightly build script.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    62
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    63
DEF_BUILDS32				= obj32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    64
DEF_BUILDS64				= obj64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    65
DEF_BUILDSONLY64			= obj64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    66
$(NOT_RELEASE_BUILD)DEF_BUILDS32	= debug32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    67
$(NOT_RELEASE_BUILD)DEF_BUILDS64	= debug64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    68
$(NOT_RELEASE_BUILD)DEF_BUILDSONLY64	= debug64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    69
ALL_BUILDS32				= obj32 debug32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    70
ALL_BUILDS64				= obj64 debug64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    71
ALL_BUILDSONLY64			= obj64 debug64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    72
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    73
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    74
#	For modules in 64b dirs that aren't built 64b
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    75
#	or modules in 64b dirs that aren't built 32b we
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    76
#	need to create empty modlintlib files so global lint works
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    77
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    78
LINT32_BUILDS	= debug32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    79
LINT64_BUILDS	= debug64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    80
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    81
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    82
#	Build class (32b or 64b)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    83
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    84
CLASS_OBJ32	= 32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    85
CLASS_DBG32	= 32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    86
CLASS_OBJ64	= 64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    87
CLASS_DBG64	= 64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    88
CLASS		= $(CLASS_$(BUILD_TYPE))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    89
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    90
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    91
#	Build subdirectory
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    92
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    93
OBJS_DIR_OBJ32	= obj32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    94
OBJS_DIR_DBG32	= debug32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    95
OBJS_DIR_OBJ64	= obj64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    96
OBJS_DIR_DBG64	= debug64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    97
OBJS_DIR	= $(OBJS_DIR_$(BUILD_TYPE))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    98
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    99
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   100
#	Create defaults so empty rules don't
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   101
#	confuse make
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   102
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   103
CLASS_		= 32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   104
OBJS_DIR_	= debug32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   105
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   106
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   107
#	Build tools
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   108
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   109
CC_sparc_32	= $(sparc_CC)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   110
CC_sparc_64	= $(sparcv9_CC)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   111
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   112
CC_i386_32	= $(i386_CC)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   113
CC_i386_64	= $(amd64_CC)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   114
CC_amd64_64	= $(amd64_CC)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   115
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   116
CC		= $(CC_$(MACH)_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   117
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   118
AS_sparc_32	= $(sparc_AS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   119
AS_sparc_64	= $(sparcv9_AS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   120
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   121
AS_i386_32	= $(i386_AS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   122
AS_i386_64	= $(amd64_AS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   123
AS_amd64_64	= $(amd64_AS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   124
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   125
AS		= $(AS_$(MACH)_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   126
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   127
LD_sparc_32	= $(sparc_LD)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   128
LD_sparc_64	= $(sparcv9_LD)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   129
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   130
LD_i386_32	= $(i386_LD)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   131
LD_i386_64	= $(amd64_LD)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   132
LD_amd64_64	= $(amd64_LD)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   133
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   134
LD		= $(LD_$(MACH)_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   135
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   136
LINT_sparc_32	= $(sparc_LINT)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   137
LINT_sparc_64	= $(sparcv9_LINT)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   138
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   139
LINT_i386_32	= $(i386_LINT)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   140
LINT_i386_64	= $(amd64_LINT)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   141
LINT_amd64_64	= $(amd64_LINT)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   142
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   143
LINT		= $(LINT_$(MACH)_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   144
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   145
MODEL_32	= ilp32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   146
MODEL_64	= lp64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   147
MODEL		= $(MODEL_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   148
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   149
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   150
#	Build rules for linting the kernel.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   151
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   152
LHEAD =	( $(ECHO) "\n$@";
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   153
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   154
LGREP.2 =	grep -v ' _init ' | \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   155
		grep -v ' _fini ' | \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   156
		grep -v ' _info ' | \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   157
		grep -v ' _depends_on ' | \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   158
		cat
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   159
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   160
LTAIL =	)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   161
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   162
LINT.c =	$(LINT) -c -dirout=$(LINTS_DIR) $(LINTFLAGS) $(LINT_DEFS) $(CPPFLAGS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   163
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   164
LINTTAGS_32	=
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   165
LINTTAGS_32	+= -erroff=E_BAD_PTR_CAST_ALIGN
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   166
LINTTAGS_32	+= -erroff=E_SUPPRESSION_DIRECTIVE_UNUSED
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   167
LINTTAGS_32	+= -erroff=E_SUSPICIOUS_COMPARISON
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   168
LINTTAGS_32	+= -erroff=E_CAST_UINT_TO_SIGNED_INT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   169
LINTTAGS_32	+= -erroff=E_PASS_UINT_TO_SIGNED_INT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   170
LINTTAGS_32	+= -erroff=E_INVALID_ANNOTATION_NAME
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   171
LINTTAGS_32	+= -erroff=E_OLD_STYLE_DECL_OR_BAD_TYPE
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   172
LINTTAGS_32	+= -erroff=E_NO_EXPLICIT_TYPE_GIVEN
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   173
LINTTAGS_32	+= -erroff=E_STATIC_UNUSED
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   174
LINTTAGS_32	+= -erroff=E_PTRDIFF_OVERFLOW
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   175
LINTTAGS_32	+= -erroff=E_ASSIGN_NARROW_CONV
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   176
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   177
LINTTAGS_64	= $(LINTTAGS_32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   178
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   179
# Selectively disable certain noisy lint errors
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   180
LENIENT_LINTTAGS =
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   181
LENIENT_LINTTAGS += -erroff=E_CAST_INT_TO_SMALL_INT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   182
LENIENT_LINTTAGS += -erroff=E_CAST_INT_CONST_TO_SMALL_INT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   183
LENIENT_LINTTAGS += -erroff=E_CAST_TO_PTR_FROM_INT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   184
LENIENT_LINTTAGS += -erroff=E_ASSIGN_INT_TO_SMALL_INT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   185
LENIENT_LINTTAGS += -erroff=E_ASSIGN_INT_FROM_BIG_CONST
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   186
LENIENT_LINTTAGS += -erroff=E_CONST_PROMOTED_UNSIGNED_LL
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   187
LENIENT_LINTTAGS += -erroff=E_CONST_PROMOTED_LONG_LONG
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   188
LENIENT_LINTTAGS += -erroff=E_CONST_TRUNCATED_BY_ASSIGN
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   189
LENIENT_LINTTAGS += -erroff=E_PASS_INT_FROM_BIG_CONST
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   190
LENIENT_LINTTAGS += -erroff=E_COMP_INT_WITH_LARGE_INT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   191
LENIENT_LINTTAGS += -erroff=E_ASSIGN_UINT_TO_SIGNED_INT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   192
# These are still noisy but a bit more useful.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   193
# They shouldn't be used on new code.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   194
LENIENT_LINTTAGS += -erroff=E_PASS_INT_TO_SMALL_INT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   195
LENIENT_LINTTAGS += -erroff=E_PTR_CONV_LOSES_BITS
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   196
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   197
# comment out next line to turn on pedantic 64-bit error checking
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   198
LINTTAGS_64	+= $(LENIENT_LINTTAGS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   199
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   200
LENIENT_i386_LINTTAGS	=
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   201
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   202
LENIENT_amd64_LINTTAGS	=
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   203
LENIENT_amd64_LINTTAGS	+= -erroff=E_BAD_PRAGMA_PACK_VALUE
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   204
LENIENT_amd64_LINTTAGS	+= -erroff=E_SHIFT_CNT_NEG_TOO_BIG_L
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   205
LENIENT_amd64_LINTTAGS	+= -erroff=E_CONST_PROMOTED_UNSIGNED_LL
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   206
LENIENT_amd64_LINTTAGS	+= -erroff=E_CONST_PROMOTED_LONG_LONG
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   207
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   208
LINTFLAGS_sparc_32	= $(LINTCCMODE) -nsxmuF -errtags=yes
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   209
LINTFLAGS_sparc_64	= $(LINTFLAGS_sparc_32) -Xarch=v9
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   210
LINTFLAGS_i386_32	= $(LINTCCMODE) -nsxmuF -errtags=yes
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   211
LINTFLAGS_i386_64	= $(LINTFLAGS_i386_32) -Xarch=amd64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   212
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   213
LINTTAGS_sparc_32	= $(LINTTAGS_32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   214
LINTTAGS_sparc_64	= $(LINTTAGS_64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   215
LINTTAGS_i386_32	= $(LINTTAGS_32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   216
LINTTAGS_i386_64	= $(LINTTAGS_64) $(LENIENT_amd64_LINTTAGS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   217
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   218
LINTFLAGS	= $(LINTFLAGS_$(MACH)_$(CLASS)) $(LINTTAGS_$(MACH)_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   219
LINTFLAGS	+= $(C99LMODE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   220
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   221
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   222
#	Override this variable to modify the name of the lint target.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   223
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   224
LINT_MODULE=	$(MODULE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   225
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   226
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   227
#	Build the compile/assemble lines:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   228
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   229
EXTRA_OPTIONS		= 
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   230
AS_DEFS			= -D_ASM -D__STDC__=0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   231
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   232
ALWAYS_DEFS_32		= -D_KERNEL -D_SYSCALL32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   233
ALWAYS_DEFS_64		= -D_KERNEL -D_SYSCALL32 -D_SYSCALL32_IMPL -D_ELF64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   234
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   235
# XX64	This should be defined by the compiler!
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   236
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   237
ALWAYS_DEFS_64		+= -Dsun -D__sun -D__SVR4
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   238
ALWAYS_DEFS		= $(ALWAYS_DEFS_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   239
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   240
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   241
#	CPPFLAGS is deliberatly set with a "=" and not a "+=".  For the kernel
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   242
#	the header include path should not look for header files outside of
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   243
#	the kernel code.  This "=" removes the search path built in
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   244
#	Makefile.master inside CPPFLAGS.  Ditto for AS_CPPFLAGS.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   245
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   246
CPPFLAGS	= $(ALWAYS_DEFS) $(ALL_DEFS) $(CONFIG_DEFS) \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   247
		   $(INCLUDE_PATH) $(EXTRA_OPTIONS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   248
ASFLAGS		+= -P
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   249
AS_CPPFLAGS	= $(ALWAYS_DEFS) $(ALL_DEFS) $(CONFIG_DEFS) $(AS_DEFS) \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   250
		   $(AS_INC_PATH) $(EXTRA_OPTIONS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   251
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   252
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   253
#	Make it (relatively) easy to share compilation options between
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   254
#	all kernel implementations.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   255
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   256
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   257
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   258
# XX64	Compiling with -xc99=%all on build 55 merge makes the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   259
#	kmem_alloc double map parts of the kernel data causing
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   260
#	horrible overwriting and forces a hardware reset in
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   261
#	segkp_create().  Until the origin of this problem can
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   262
#	be tracked down (i.e. is it a deliberate C89 -> C99 semantic
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   263
#	change for which the kernel needs repair, or is it just a
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   264
#	bug in the x86 compiler?) disabling C99 for kernel compilation
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   265
#	when using the Devpro compiler
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   266
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   267
i386_C99MODE		= $(C99_DISABLE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   268
$(__GNUC)i386_C99MODE	= $(C99_ENABLE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   269
sparc_C99MODE		= $(C99_DISABLE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   270
C99MODE			= $($(MACH)_C99MODE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   271
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   272
CFLAGS_uts		=
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   273
CFLAGS_uts		+= $(STAND_FLAGS_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   274
CFLAGS_uts		+= $(CCVERBOSE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   275
CFLAGS_uts		+= $(ILDOFF)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   276
CFLAGS_uts		+= $(XAOPT)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   277
CFLAGS_uts		+= $(CTF_FLAGS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   278
CFLAGS_uts		+= $(CERRWARN)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   279
CFLAGS_uts		+= $(C99MODE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   280
CFLAGS_uts		+= $(EXTRA_CFLAGS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   281
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   282
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   283
#	Declare that $(OBJECTS) and $(LINTS) can be compiled in parallel.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   284
#	The DUMMY target is for those instances where OBJECTS and LINTS
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   285
#	are empty (to avoid an unconditional .PARALLEL).
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   286
.PARALLEL:	$(OBJECTS) $(LINTS) DUMMY
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   287
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   288
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   289
#	Expanded dependencies
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   290
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   291
DEF_DEPS	= $(DEF_BUILDS:%=def.%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   292
ALL_DEPS	= $(ALL_BUILDS:%=all.%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   293
CLEAN_DEPS	= $(ALL_BUILDS:%=clean.%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   294
CLOBBER_DEPS	= $(ALL_BUILDS:%=clobber.%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   295
LINT_DEPS	= $(DEF_BUILDS:%=lint.%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   296
MODLINTLIB_DEPS	= $(DEF_BUILDS:%=modlintlib.%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   297
CLEAN_LINT_DEPS	= $(ALL_BUILDS:%=clean.lint.%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   298
INSTALL_DEPS	= $(DEF_BUILDS:%=install.%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   299
SYM_DEPS	= $(SYM_BUILDS:%=symcheck.%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   300
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   301
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   302
#	Default module name
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   303
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   304
BINARY		= $(OBJS_DIR)/$(MODULE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   305
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   306
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   307
#	Default cleanup definitions
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   308
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   309
CLEANLINTFILES	= $(LINTS) $(MOD_LINT_LIB)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   310
CLEANFILES	= $(OBJECTS) $(CLEANLINTFILES)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   311
CLOBBERFILES	= $(BINARY) $(CLEANFILES)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   312
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   313
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   314
#	Installation constants:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   315
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   316
#		FILEMODE is the mode given to the kernel modules
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   317
#		CFILEMODE is the mode given to the '.conf' files
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   318
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   319
FILEMODE	 = 755
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   320
DIRMODE		 = 755
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   321
OWNER		 = root
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   322
GROUP		 = sys
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   323
CFILEMODE	 = 644
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   324
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   325
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   326
#	Special Installation Macros for the installation of '.conf' files.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   327
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   328
#	These are unique because they are not installed from the current
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   329
#	working directory.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   330
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   331
# Sigh.  Apparently at some time in the past there was a confusion on
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   332
# whether the name is SRC_CONFFILE or SRC_CONFILE.  Consistency with the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   333
# other names would indicate SRC_CONFFILE, but the voting is >180 Makefiles
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   334
# with SRC_CONFILE and about 11 with SRC_CONFFILE.  Software development
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   335
# isn't a popularity contest, though, and so my inclination is to define
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   336
# both names for now and incrementally convert to SRC_CONFFILE to be consistent
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   337
# with the other names.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   338
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   339
CONFFILE		= $(MODULE).conf
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   340
SRC_CONFFILE		= $(CONF_SRCDIR)/$(CONFFILE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   341
SRC_CONFILE		= $(SRC_CONFFILE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   342
ROOT_CONFFILE_32	= $(ROOTMODULE).conf
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   343
ROOT_CONFFILE_64	= $(ROOTMODULE:%/$(SUBDIR64)/$(MODULE)=%/$(MODULE)).conf
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   344
ROOT_CONFFILE		= $(ROOT_CONFFILE_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   345
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   346
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   347
INS.conffile= \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   348
	$(RM) $@; $(INS) -s -m $(CFILEMODE) -f $(@D) $(SRC_CONFFILE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   349
$(CH)INS.conffile= \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   350
    $(INS) -s -m $(CFILEMODE) -u $(OWNER) -g $(GROUP) -f $(@D) $(SRC_CONFFILE)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   351
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   352
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   353
# The CTF merge of child kernel modules is performed against one of the genunix
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   354
# modules.  For Intel builds, all modules will be used with a single genunix:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   355
# the one built in intel/genunix.  For SPARC builds, a given
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   356
# module may be
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   357
# used with one of a number of genunix files, depending on what platform the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   358
# module is deployed on.  We merge against the sun4u genunix to optimize for
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   359
# the common case.  We also merge against the ip driver since networking is
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   360
# typically loaded and types defined therein are shared between many modules.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   361
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   362
CTFMERGE_GUDIR_sparc	= sun4u
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   363
CTFMERGE_GUDIR_i386	= intel
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   364
CTFMERGE_GUDIR		= $(CTFMERGE_GUDIR_$(MACH))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   365
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   366
CTFMERGE_GENUNIX 	= \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   367
	$(UTSBASE)/$(CTFMERGE_GUDIR)/genunix/$(OBJS_DIR)/genunix
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   368
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   369
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   370
# Used to uniquify a non-genunix module against genunix.  If used in patch
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   371
# mode (PATCH_BUILD != "#"), the patch ID corresponding to the module being
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   372
# built will be used as the label.  If no ID is available, or if patch mode
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   373
# is not being used, the value of $VERSION will be used.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   374
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   375
CTFMERGE_UNIQUIFY_AGAINST_GENUNIX	= \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   376
	@label="-L VERSION" ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   377
	if [ -z "$(PATCH_BUILD)" ] ; then \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   378
		uniq="-D BASE" ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   379
		set -- `$(CTFFINDMOD) -n -r -t $(PMTMO_FILE) $@` ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   380
		if [ "X$$1" != "X-" ] ; then \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   381
			label="-l $$1" ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   382
			if [ "$$2" != "fcs" ] ; then \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   383
				uniq="-D $$2" ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   384
			fi ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   385
		fi ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   386
	fi ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   387
	mergecmd="$(CTFMERGE) $(CTFMRGFLAGS)" ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   388
	cmd="$$mergecmd $$label -d $(CTFMERGE_GENUNIX) $$uniq -o $@" ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   389
	echo $$cmd "$(OBJECTS) $(CTFEXTRAOBJS)" ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   390
	$$cmd $(OBJECTS) $(CTFEXTRAOBJS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   391
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   392
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   393
# Used to merge the genunix module.  genunix has special requirements in
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   394
# patch mode.  In particular, it needs to be able to find the genunix used
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   395
# in the previous version of the KU patch (or the FCS version of genunix in
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   396
# the case of KU 1).
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   397
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   398
CTFMERGE_GENUNIX_MERGE		= \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   399
	@if [ -z "$(PATCH_BUILD)" ] ; then \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   400
		set -- `$(CTFFINDMOD) -b $(OBJS_DIR) -o patch,lastgu -n -r \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   401
		    -t $(PMTMO_FILE) $(GENUNIX) || true` '' ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   402
		msg= ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   403
		if [ $$$(POUND_SIGN) -eq 1 ] ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   404
		    then msg="Error in $(CTFFINDMOD)" ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   405
		elif [ "X$$1" = "X-" ] ; then msg="Did not get label" ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   406
		elif [ "X$$2" = "X-" ] ; then msg="Did not get withfile" ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   407
		fi ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   408
		if [ -n "$$msg" ] ; then \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   409
			echo "make ctf: $$msg - removing $(GENUNIX)" ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   410
			$(RM) $(GENUNIX) ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   411
			exit 1 ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   412
		fi ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   413
		label="-l $$1" ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   414
		with="-w $$2" ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   415
	else \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   416
		label="-L VERSION" ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   417
	fi ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   418
	cmd="$(CTFMERGE) $(CTFMRGFLAGS) $$label $$with -o $@" ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   419
	echo $$cmd "$(OBJECTS) $(CTFEXTRAOBJS) $(IPCTF_TARGET)"; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   420
	$$cmd $(OBJECTS) $(CTFEXTRAOBJS) $(IPCTF_TARGET)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   421
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   422
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   423
# Used to copy CTF data from the sun4u genunix to the sun4m genunix.  While
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   424
# we may lose some genunix-specific sun4m-only data, there really isn't any
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   425
# other way, since individual ctfmerges on the sun4u and sun4m genunix
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   426
# modules will result in differing type indices for the same types, and we
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   427
# can't uniquify a given non-genunix module against two genunix modules.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   428
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   429
CTFMERGE_COPY_CTF_DATA		= \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   430
	@if [ -f $(CTFMERGE_GENUNIX) ] ; then \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   431
		cmd="$(CTFMERGE) $(CTFMRGFLAGS) -c $(CTFMERGE_GENUNIX) $@" ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   432
		echo $$cmd ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   433
		$$cmd ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   434
	else \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   435
		echo "WARNING: $(CTFMERGE_GENUNIX) not built. " \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   436
		    "CTF data will be incomplete" ; \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   437
	fi
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   438
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   439
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   440
# We ctfmerge the ip objects into genunix to maximize the number of common types
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   441
# found there, thus maximizing the effectiveness of uniquification.  We don't
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   442
# want the genunix build to have to know about the individual ip objects, so we
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   443
# put them in an archive.  The genunix ctfmerge then includes this archive.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   444
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   445
IPCTF			= $(IPDRV_DIR)/$(OBJS_DIR)/ipctf.a
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   446
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   447
#
580
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
   448
# Rule for building fake shared libraries used for symbol resolution
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
   449
# when building other modules.  -znoreloc is needed here to avoid
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
   450
# tripping over code that isn't really suitable for shared libraries.
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
   451
#
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
   452
BUILD.SO		= \
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
   453
	$(LD) -o $@ $(GSHARED) $(ZNORELOC) -h $(SONAME)
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
   454
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
   455
#
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
   456
# SONAME defaults for common fake shared libraries.
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
   457
#
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
   458
$(LIBGEN)		:= SONAME = $(MODULE)
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
   459
$(PLATLIB)		:= SONAME = misc/platmod
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
   460
$(CPULIB)		:= SONAME = 'cpu/$$CPU'
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
   461
$(DTRACESTUBS)		:= SONAME = dtracestubs
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
   462
70dfd36fd02c 6237094 perl build should honor $(CC)
wesolows
parents: 0
diff changeset
   463
#
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   464
#	Installation directories
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   465
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   466
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   467
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   468
#	For now, 64b modules install into a subdirectory
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   469
#	of their 32b brethren.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   470
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   471
SUBDIR64_sparc		= sparcv9
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   472
SUBDIR64_i386		= amd64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   473
SUBDIR64		= $(SUBDIR64_$(MACH))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   474
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   475
ROOT_MOD_DIR		= $(ROOT)/kernel
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   476
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   477
ROOT_KERN_DIR_32	= $(ROOT_MOD_DIR)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   478
ROOT_DRV_DIR_32		= $(ROOT_MOD_DIR)/drv
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   479
ROOT_DTRACE_DIR_32	= $(ROOT_MOD_DIR)/dtrace
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   480
ROOT_EXEC_DIR_32	= $(ROOT_MOD_DIR)/exec
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   481
ROOT_FS_DIR_32		= $(ROOT_MOD_DIR)/fs
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   482
ROOT_SCHED_DIR_32	= $(ROOT_MOD_DIR)/sched
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   483
ROOT_STRMOD_DIR_32	= $(ROOT_MOD_DIR)/strmod
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   484
ROOT_IPP_DIR_32		= $(ROOT_MOD_DIR)/ipp
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   485
ROOT_SYS_DIR_32		= $(ROOT_MOD_DIR)/sys
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   486
ROOT_MISC_DIR_32	= $(ROOT_MOD_DIR)/misc
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   487
ROOT_KGSS_DIR_32	= $(ROOT_MOD_DIR)/misc/kgss
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   488
ROOT_NLMISC_DIR_32	= $(ROOT_MOD_DIR)/misc
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   489
ROOT_MACH_DIR_32	= $(ROOT_MOD_DIR)/mach
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   490
ROOT_CPU_DIR_32		= $(ROOT_MOD_DIR)/cpu
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   491
ROOT_TOD_DIR_32		= $(ROOT_MOD_DIR)/tod
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   492
ROOT_FONT_DIR_32	= $(ROOT_MOD_DIR)/fonts
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   493
ROOT_DACF_DIR_32	= $(ROOT_MOD_DIR)/dacf
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   494
ROOT_CRYPTO_DIR_32	= $(ROOT_MOD_DIR)/crypto
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   495
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   496
ROOT_KERN_DIR_64	= $(ROOT_MOD_DIR)/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   497
ROOT_DRV_DIR_64		= $(ROOT_MOD_DIR)/drv/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   498
ROOT_DTRACE_DIR_64	= $(ROOT_MOD_DIR)/dtrace/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   499
ROOT_EXEC_DIR_64	= $(ROOT_MOD_DIR)/exec/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   500
ROOT_FS_DIR_64		= $(ROOT_MOD_DIR)/fs/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   501
ROOT_SCHED_DIR_64	= $(ROOT_MOD_DIR)/sched/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   502
ROOT_STRMOD_DIR_64	= $(ROOT_MOD_DIR)/strmod/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   503
ROOT_IPP_DIR_64		= $(ROOT_MOD_DIR)/ipp/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   504
ROOT_SYS_DIR_64		= $(ROOT_MOD_DIR)/sys/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   505
ROOT_MISC_DIR_64	= $(ROOT_MOD_DIR)/misc/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   506
ROOT_KGSS_DIR_64	= $(ROOT_MOD_DIR)/misc/kgss/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   507
ROOT_NLMISC_DIR_64	= $(ROOT_MOD_DIR)/misc/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   508
ROOT_MACH_DIR_64	= $(ROOT_MOD_DIR)/mach/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   509
ROOT_CPU_DIR_64		= $(ROOT_MOD_DIR)/cpu/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   510
ROOT_TOD_DIR_64		= $(ROOT_MOD_DIR)/tod/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   511
ROOT_FONT_DIR_64	= $(ROOT_MOD_DIR)/fonts/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   512
ROOT_DACF_DIR_64	= $(ROOT_MOD_DIR)/dacf/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   513
ROOT_CRYPTO_DIR_64	= $(ROOT_MOD_DIR)/crypto/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   514
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   515
ROOT_KERN_DIR		= $(ROOT_KERN_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   516
ROOT_DRV_DIR		= $(ROOT_DRV_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   517
ROOT_DTRACE_DIR		= $(ROOT_DTRACE_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   518
ROOT_EXEC_DIR		= $(ROOT_EXEC_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   519
ROOT_FS_DIR		= $(ROOT_FS_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   520
ROOT_SCHED_DIR		= $(ROOT_SCHED_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   521
ROOT_STRMOD_DIR		= $(ROOT_STRMOD_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   522
ROOT_IPP_DIR		= $(ROOT_IPP_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   523
ROOT_SYS_DIR		= $(ROOT_SYS_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   524
ROOT_MISC_DIR		= $(ROOT_MISC_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   525
ROOT_KGSS_DIR		= $(ROOT_KGSS_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   526
ROOT_NLMISC_DIR		= $(ROOT_NLMISC_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   527
ROOT_MACH_DIR		= $(ROOT_MACH_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   528
ROOT_CPU_DIR		= $(ROOT_CPU_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   529
ROOT_TOD_DIR		= $(ROOT_TOD_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   530
ROOT_FONT_DIR		= $(ROOT_FONT_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   531
ROOT_DACF_DIR		= $(ROOT_DACF_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   532
ROOT_CRYPTO_DIR		= $(ROOT_CRYPTO_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   533
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   534
ROOT_MOD_DIRS_32	= $(ROOT_DRV_DIR_32) $(ROOT_EXEC_DIR_32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   535
ROOT_MOD_DIRS_32	+= $(ROOT_DTRACE_DIR_32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   536
ROOT_MOD_DIRS_32	+= $(ROOT_FS_DIR_32) $(ROOT_SCHED_DIR_32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   537
ROOT_MOD_DIRS_32	+= $(ROOT_STRMOD_DIR_32) $(ROOT_SYS_DIR_32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   538
ROOT_MOD_DIRS_32	+= $(ROOT_IPP_DIR_32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   539
ROOT_MOD_DIRS_32	+= $(ROOT_MISC_DIR_32) $(ROOT_MACH_DIR_32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   540
ROOT_MOD_DIRS_32	+= $(ROOT_KGSS_DIR_32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   541
ROOT_MOD_DIRS_32	+= $(ROOT_CPU_DIR_32) $(ROOT_FONT_DIR_32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   542
ROOT_MOD_DIRS_32	+= $(ROOT_TOD_DIR_32) $(ROOT_DACF_DIR_32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   543
ROOT_MOD_DIRS_32	+= $(ROOT_CRYPTO_DIR_32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   544
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   545
USR_MOD_DIR		= $(ROOT)/usr/kernel
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   546
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   547
USR_DRV_DIR_32		= $(USR_MOD_DIR)/drv
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   548
USR_EXEC_DIR_32		= $(USR_MOD_DIR)/exec
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   549
USR_FS_DIR_32		= $(USR_MOD_DIR)/fs
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   550
USR_SCHED_DIR_32	= $(USR_MOD_DIR)/sched
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   551
USR_STRMOD_DIR_32	= $(USR_MOD_DIR)/strmod
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   552
USR_SYS_DIR_32		= $(USR_MOD_DIR)/sys
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   553
USR_MISC_DIR_32		= $(USR_MOD_DIR)/misc
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   554
USR_DACF_DIR_32		= $(USR_MOD_DIR)/dacf
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   555
USR_PCBE_DIR_32		= $(USR_MOD_DIR)/pcbe
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   556
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   557
USR_DRV_DIR_64		= $(USR_MOD_DIR)/drv/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   558
USR_EXEC_DIR_64		= $(USR_MOD_DIR)/exec/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   559
USR_FS_DIR_64		= $(USR_MOD_DIR)/fs/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   560
USR_SCHED_DIR_64	= $(USR_MOD_DIR)/sched/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   561
USR_STRMOD_DIR_64	= $(USR_MOD_DIR)/strmod/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   562
USR_SYS_DIR_64		= $(USR_MOD_DIR)/sys/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   563
USR_MISC_DIR_64		= $(USR_MOD_DIR)/misc/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   564
USR_DACF_DIR_64		= $(USR_MOD_DIR)/dacf/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   565
USR_PCBE_DIR_64		= $(USR_MOD_DIR)/pcbe/$(SUBDIR64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   566
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   567
USR_DRV_DIR		= $(USR_DRV_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   568
USR_EXEC_DIR		= $(USR_EXEC_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   569
USR_FS_DIR		= $(USR_FS_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   570
USR_SCHED_DIR		= $(USR_SCHED_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   571
USR_STRMOD_DIR		= $(USR_STRMOD_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   572
USR_SYS_DIR		= $(USR_SYS_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   573
USR_MISC_DIR		= $(USR_MISC_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   574
USR_DACF_DIR		= $(USR_DACF_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   575
USR_PCBE_DIR		= $(USR_PCBE_DIR_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   576
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   577
USR_MOD_DIRS_32		= $(USR_DRV_DIR_32) $(USR_EXEC_DIR_32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   578
USR_MOD_DIRS_32		+= $(USR_FS_DIR_32) $(USR_SCHED_DIR_32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   579
USR_MOD_DIRS_32		+= $(USR_STRMOD_DIR_32) $(USR_SYS_DIR_32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   580
USR_MOD_DIRS_32		+= $(USR_MISC_DIR_32) $(USR_DACF_DIR_32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   581
USR_MOD_DIRS_32		+= $(USR_PCBE_DIR_32)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   582
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   583
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   584
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   585
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   586
include $(SRC)/Makefile.psm
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   587
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   588
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   589
#       Set ownership on links.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   590
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   591
CHOWNLINK=
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   592
$(CH)CHOWNLINK= ; $(CHOWN) $(OWNER) $@
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   593
CHGRPLINK=
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   594
$(CH)CHGRPLINK= ; $(CHGRP) $(GROUP) $@
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   595
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   596
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   597
#	The "-r" on the remove may be considered temporary, but is required
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   598
#	while the replacement of the SUNW,SPARCstation-10,SX directory by
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   599
#	a symbolic link is being propagated.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   600
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   601
INS.slink1= $(RM) -r $@; $(SYMLINK) $(PLATFORM) $@ $(CHOWNLINK) $(CHGRPLINK)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   602
INS.slink2= $(RM) -r $@; $(SYMLINK) ../$(PLATFORM)/$(@F) $@ $(CHOWNLINK) $(CHGRPLINK)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   603
INS.slink3= $(RM) -r $@; $(SYMLINK) $(IMPLEMENTED_PLATFORM) $@ $(CHOWNLINK) $(CHGRPLINK)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   604
INS.slink4= $(RM) -r $@; $(SYMLINK) ../$(PLATFORM)/include $@ $(CHOWNLINK) $(CHGRPLINK)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   605
INS.slink5= $(RM) -r $@; $(SYMLINK) ../$(PLATFORM)/sbin $@ $(CHOWNLINK) $(CHGRPLINK)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   606
INS.slink6= $(RM) -r $@; $(SYMLINK) ../../$(PLATFORM)/lib/$(MODULE) $@ $(CHOWNLINK) $(CHGRPLINK)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   607
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   608
ROOT_PLAT_LINKS		 = $(PLAT_LINKS:%=$(ROOT_PLAT_DIR)/%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   609
ROOT_PLAT_LINKS_2	 = $(PLAT_LINKS_2:%=$(ROOT_PLAT_DIR)/%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   610
USR_PLAT_LINKS		 = $(PLAT_LINKS:%=$(USR_PLAT_DIR)/%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   611
USR_PLAT_LINKS_2	 = $(PLAT_LINKS_2:%=$(USR_PLAT_DIR)/%)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   612
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   613
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   614
#	Collection of all relevant, delivered kernel modules.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   615
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   616
KMODS	= $(DRV_KMODS) $(EXEC_KMODS) $(FS_KMODS) $(SCHED_KMODS) $(TOD_KMODS) \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   617
	  $(STRMOD_KMODS) $(SYS_KMODS) $(MISC_KMODS) $(NLMISC_KMODS) \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   618
	  $(MACH_KMODS) $(CPU_KMODS) $(GENUNIX_KMODS) \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   619
	  $(GSS_KMODS) $(MMU_KMODS) $(DACF_KMODS) $(EXPORT_KMODS) \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   620
	  $(IPP_KMODS) $(CRYPTO_KMODS) $(CRYPTO_EK_KMODS) $(PCBE_KMODS) \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   621
	  $(DRV_KMODS_$(CLASS)) $(MISC_KMODS_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   622
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   623
LINT_KMODS = $(DRV_KMODS) $(EXEC_KMODS) $(FS_KMODS) $(SCHED_KMODS) \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   624
	  $(TOD_KMODS) $(STRMOD_KMODS) $(SYS_KMODS) $(MISC_KMODS) \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   625
	  $(MACH_KMODS) $(GSS_KMODS) $(DACF_KMODS) $(IPP_KMODS) \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   626
	  $(CRYPTO_KMODS) $(PCBE_KMODS) \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   627
	  $(DRV_KMODS_$(CLASS)) $(MISC_KMODS_$(CLASS))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   628
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   629
THIS_YEAR:sh=	/bin/date +%Y
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   630
$(OBJS_DIR)/logsubr.o	:= CPPFLAGS += -DTHIS_YEAR=$(THIS_YEAR)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   631
$(OBJS_DIR)/logsubr.ln	:= CPPFLAGS += -DTHIS_YEAR=$(THIS_YEAR)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   632
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   633
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   634
#	Files to be compiled with -xa, to generate basic block execution
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   635
#	count data.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   636
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   637
#	There are several ways to compile parts of the kernel for kcov:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   638
#               1)  Add targets to BB_FILES here or in other Makefiles
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   639
#                       (they must in the form of $(OBJS_DIR)/target.o)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   640
#               2)  setenv BB_FILES '$(XXX_OBJS:%=$(OBJS_DIR)/%)'
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   641
#               3)  setenv BB_FILES '$(OBJECTS)'
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   642
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   643
#       Do NOT setenv CFLAGS -xa, as that will cause infinite recursion
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   644
#       in unix_bb.o
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   645
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   646
BB_FILES =
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   647
$(BB_FILES)	:= XAOPT = -xa
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   648
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   649
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   650
#	The idea here is for unix_bb.o to be in all kernels except the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   651
#	kernel which actually gets shipped to customers.  In practice,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   652
#	$(RELEASE_BUILD) is on for a number of the late beta and fcs builds.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   653
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   654
CODE_COVERAGE=
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   655
$(RELEASE_BUILD)CODE_COVERAGE:sh=	echo \\043
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   656
$(CODE_COVERAGE)$(OBJS_DIR)/unix_bb.o   := CPPFLAGS     += -DKCOV
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   657
$(CODE_COVERAGE)$(OBJS_DIR)/unix_bb.ln  := CPPFLAGS     += -DKCOV
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   658
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   659
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   660
#	Do not let unix_bb.o get compiled with -xa!
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   661
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   662
$(OBJS_DIR)/unix_bb.o	:= XAOPT =
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   663
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   664
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   665
#	MPSAS support
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   666
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   667
MPSAS_BUILD:sh=		echo \\043
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   668
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   669
# Privilege files
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   670
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   671
PRIVS_AWK = $(SRC)/uts/common/os/privs.awk
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   672
PRIVS_DEF = $(SRC)/uts/common/os/priv_defs