17c478bd9Sstevel@tonic-gate# 27c478bd9Sstevel@tonic-gate# CDDL HEADER START 37c478bd9Sstevel@tonic-gate# 47c478bd9Sstevel@tonic-gate# The contents of this file are subject to the terms of the 55aefb655Srie# Common Development and Distribution License (the "License"). 65aefb655Srie# You may not use this file except in compliance with the License. 77c478bd9Sstevel@tonic-gate# 87c478bd9Sstevel@tonic-gate# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 97c478bd9Sstevel@tonic-gate# or http://www.opensolaris.org/os/licensing. 107c478bd9Sstevel@tonic-gate# See the License for the specific language governing permissions 117c478bd9Sstevel@tonic-gate# and limitations under the License. 127c478bd9Sstevel@tonic-gate# 137c478bd9Sstevel@tonic-gate# When distributing Covered Code, include this CDDL HEADER in each 147c478bd9Sstevel@tonic-gate# file and include the License file at usr/src/OPENSOLARIS.LICENSE. 157c478bd9Sstevel@tonic-gate# If applicable, add the following below this CDDL HEADER, with the 167c478bd9Sstevel@tonic-gate# fields enclosed by brackets "[]" replaced with your own identifying 177c478bd9Sstevel@tonic-gate# information: Portions Copyright [yyyy] [name of copyright owner] 187c478bd9Sstevel@tonic-gate# 197c478bd9Sstevel@tonic-gate# CDDL HEADER END 207c478bd9Sstevel@tonic-gate# 21*08278a5eSRod Evans 225aefb655Srie# 2369112eddSAli Bahrami# Copyright 2010 Sun Microsystems, Inc. All rights reserved. 245aefb655Srie# Use is subject to license terms. 257c478bd9Sstevel@tonic-gate# 267c478bd9Sstevel@tonic-gate 277c478bd9Sstevel@tonic-gate.KEEP_STATE: 285aefb655Srie.KEEP_STATE_FILE: .make.state.$(MACH) 295aefb655Srie 307c478bd9Sstevel@tonic-gate 317c478bd9Sstevel@tonic-gateinclude $(SRC)/cmd/sgs/Makefile.var 327c478bd9Sstevel@tonic-gate 337c478bd9Sstevel@tonic-gateSRCBASE = ../../../.. 347c478bd9Sstevel@tonic-gate 3556deab07SRod Evansi386_ARCH = intel 367c478bd9Sstevel@tonic-gatesparc_ARCH = sparc 377c478bd9Sstevel@tonic-gate 387c478bd9Sstevel@tonic-gateARCH = $($(MACH)_ARCH) 397c478bd9Sstevel@tonic-gate 407c478bd9Sstevel@tonic-gate# Establish any global flags. 417c478bd9Sstevel@tonic-gate 42b3fbe5e6Sseizo# Setting DEBUG = -DDEBUG (or "make DEBUG=-DDEBUG ...") enables ASSERT() 43b3fbe5e6Sseizo# checking. This is automatically enabled for DEBUG builds, not for non-debug 44b3fbe5e6Sseizo# builds. Unset the global C99_DISABLE flag to insure we uncover all compiler 45b3fbe5e6Sseizo# warnings/errors. 467c478bd9Sstevel@tonic-gateDEBUG = 477c478bd9Sstevel@tonic-gate$(NOT_RELEASE_BUILD)DEBUG = -DDEBUG 487c478bd9Sstevel@tonic-gate 49b3fbe5e6SseizoC99_DISABLE = $(C99_ENABLE) 50b3fbe5e6Sseizo 517c478bd9Sstevel@tonic-gateCFLAGS += $(CCVERBOSE) $(DEBUG) $(XFFLAG) 527c478bd9Sstevel@tonic-gateCFLAGS64 += $(CCVERBOSE) $(DEBUG) $(XFFLAG) 537c478bd9Sstevel@tonic-gate 5469112eddSAli Bahrami# 5569112eddSAli Bahrami# Location of the shared elfcap code 5669112eddSAli Bahrami# 5769112eddSAli BahramiELFCAP= $(SRC)/common/elfcap 5869112eddSAli Bahrami 597c478bd9Sstevel@tonic-gate# Reassign CPPFLAGS so that local search paths are used before any parent 607c478bd9Sstevel@tonic-gate# $ROOT paths. 617c478bd9Sstevel@tonic-gateCPPFLAGS = -I. -I../common -I../../include -I../../include/$(MACH) \ 6269112eddSAli Bahrami $(VAR_CPPFLAGS) $(CPPFLAGS.master) -I$(ELFCAP) 637c478bd9Sstevel@tonic-gate 647c478bd9Sstevel@tonic-gate# PICS64 is unique to our environment 657c478bd9Sstevel@tonic-gate$(PICS64) := sparc_CFLAGS += -xregs=no%appl -K pic 667c478bd9Sstevel@tonic-gate$(PICS64) := sparcv9_CFLAGS += -xregs=no%appl -K pic 677c478bd9Sstevel@tonic-gate$(PICS64) := CPPFLAGS += -DPIC -D_REENTRANT 687c478bd9Sstevel@tonic-gate 69fb1354edSrieLDFLAGS += $(ZIGNORE) 70fb1354edSrieDYNFLAGS += $(ZIGNORE) 717c478bd9Sstevel@tonic-gate 727c478bd9Sstevel@tonic-gate# Establish the local tools, proto and package area. 737c478bd9Sstevel@tonic-gate 747c478bd9Sstevel@tonic-gateSGSHOME = $(SRC)/cmd/sgs 757c478bd9Sstevel@tonic-gateSGSPROTO = $(SGSHOME)/proto/$(MACH) 767c478bd9Sstevel@tonic-gateSGSTOOLS = $(SGSHOME)/tools 777c478bd9Sstevel@tonic-gateSGSMSGID = $(SGSHOME)/messages 787c478bd9Sstevel@tonic-gateSGSMSGDIR = $(SGSHOME)/messages/$(MACH) 797c478bd9Sstevel@tonic-gateSGSONLD = $(ROOT)/opt/SUNWonld 807c478bd9Sstevel@tonic-gateSGSRPATH = /usr/lib 817c478bd9Sstevel@tonic-gateSGSRPATH64 = $(SGSRPATH)/$(MACH64) 827c478bd9Sstevel@tonic-gate 837c478bd9Sstevel@tonic-gate# 845aefb655Srie# Macros to be used to include link against libconv and include vernote.o 857c478bd9Sstevel@tonic-gate# 867c478bd9Sstevel@tonic-gateVERSREF = -ulink_ver_string 875aefb655Srie 885aefb655SrieLDLIBDIR = -L$(SGSHOME)/libld/$(MACH) 895aefb655SrieLDLIBDIR64 = -L$(SGSHOME)/libld/$(MACH64) 905aefb655Srie 917c478bd9Sstevel@tonic-gateCONVLIBDIR = -L$(SGSHOME)/libconv/$(MACH) 927c478bd9Sstevel@tonic-gateCONVLIBDIR64 = -L$(SGSHOME)/libconv/$(MACH64) 937c478bd9Sstevel@tonic-gate 947c478bd9Sstevel@tonic-gateELFLIBDIR = -L$(SGSHOME)/libelf/$(MACH) 957c478bd9Sstevel@tonic-gateELFLIBDIR64 = -L$(SGSHOME)/libelf/$(MACH64) 967c478bd9Sstevel@tonic-gate 977c478bd9Sstevel@tonic-gateLDDBGLIBDIR = -L$(SGSHOME)/liblddbg/$(MACH) 987c478bd9Sstevel@tonic-gateLDDBGLIBDIR64 = -L$(SGSHOME)/liblddbg/$(MACH64) 997c478bd9Sstevel@tonic-gate 10069112eddSAli Bahrami 1017c478bd9Sstevel@tonic-gate# The cmd/Makefile.com and lib/Makefile.com define TEXT_DOMAIN. We don't need 1027c478bd9Sstevel@tonic-gate# this definition as the sgs utilities obtain their domain via sgsmsg(1l). 1037c478bd9Sstevel@tonic-gate 1047c478bd9Sstevel@tonic-gateDTEXTDOM = 1057c478bd9Sstevel@tonic-gate 1067c478bd9Sstevel@tonic-gate# Define any generic sgsmsg(1l) flags. The default message generation system 1077c478bd9Sstevel@tonic-gate# is to use gettext(3i), add the -C flag to switch to catgets(3c). 1087c478bd9Sstevel@tonic-gate 1097c478bd9Sstevel@tonic-gateSGSMSG = $(SGSTOOLS)/$(MACH)/sgsmsg 110d29b2c44Sab196087SGSMSG_PIGLATIN_NL = perl $(SGSTOOLS)/common/sgsmsg_piglatin_nl.pl 1117c478bd9Sstevel@tonic-gateCHKMSG = $(SGSTOOLS)/chkmsg.sh 1127c478bd9Sstevel@tonic-gate 1137c478bd9Sstevel@tonic-gateSGSMSGVFLAG = 1147c478bd9Sstevel@tonic-gateSGSMSGFLAGS = $(SGSMSGVFLAG) -i $(SGSMSGID)/sgs.ident 1157c478bd9Sstevel@tonic-gateCHKMSGFLAGS = $(SGSMSGTARG:%=-m %) $(SGSMSGCHK:%=-m %) 1167c478bd9Sstevel@tonic-gate 1177c478bd9Sstevel@tonic-gate# Native targets should use the minimum of ld(1) flags to allow building on 1187c478bd9Sstevel@tonic-gate# previous releases. We use mapfiles to scope, but don't bother versioning. 1197c478bd9Sstevel@tonic-gate 120f808c858Srafnative := DYNFLAGS = -R$(SGSPROTO) -L$(SGSPROTO) $(ZNOVERSION) 1217c478bd9Sstevel@tonic-gate 122*08278a5eSRod Evans# Comment out the following two lines to have the sgs built from the system 123*08278a5eSRod Evans# link-editor, rather than the local proto link-editor. 124*08278a5eSRod EvansCC_USE_PROTO = -Yl,$(SGSPROTO) 125*08278a5eSRod EvansLD_USE_PROTO = $(SGSPROTO)/ 1267c478bd9Sstevel@tonic-gate 1277c478bd9Sstevel@tonic-gate# 1287c478bd9Sstevel@tonic-gate# lint-related stuff 1297c478bd9Sstevel@tonic-gate# 1307c478bd9Sstevel@tonic-gateLIBNAME32 = $(LIBNAME:%=%32) 1317c478bd9Sstevel@tonic-gateLIBNAME64 = $(LIBNAME:%=%64) 1327c478bd9Sstevel@tonic-gateLIBNAMES = $(LIBNAME32) $(LIBNAME64) 1337c478bd9Sstevel@tonic-gate 1347c478bd9Sstevel@tonic-gateSGSLINTOUT = lint.out 1357c478bd9Sstevel@tonic-gateLINTOUT1 = lint.out.1 1367c478bd9Sstevel@tonic-gateLINTOUT32 = lint.out.32 1377c478bd9Sstevel@tonic-gateLINTOUT64 = lint.out.64 1387c478bd9Sstevel@tonic-gateLINTOUTS = $(SGSLINTOUT) $(LINTOUT1) $(LINTOUT32) $(LINTOUT64) 1397c478bd9Sstevel@tonic-gate 1407c478bd9Sstevel@tonic-gateLINTLIBSRC = $(LINTLIB:%.ln=%) 1417c478bd9Sstevel@tonic-gateLINTLIB32 = $(LINTLIB:%.ln=%32.ln) 1427c478bd9Sstevel@tonic-gateLINTLIB64 = $(LINTLIB:%.ln=%64.ln) 1437c478bd9Sstevel@tonic-gateLINTLIBS = $(LINTLIB32) $(LINTLIB64) 1447c478bd9Sstevel@tonic-gate 1457c478bd9Sstevel@tonic-gateLINTFLAGS = -m -errtags=yes -erroff=E_SUPPRESSION_DIRECTIVE_UNUSED 1467c478bd9Sstevel@tonic-gateLINTFLAGS64 = -m -errtags=yes -erroff=E_SUPPRESSION_DIRECTIVE_UNUSED \ 147*08278a5eSRod Evans $(VAR_LINTFLAGS64) 148*08278a5eSRod Evans 149*08278a5eSRod Evans# 150*08278a5eSRod Evans# When building a lint library, no other lint libraries are verified as 151*08278a5eSRod Evans# dependencies, nor is the stardard C lint library processed. All dependency 152*08278a5eSRod Evans# verification is carried out through linting the sources themselves. 153*08278a5eSRod Evans# 154*08278a5eSRod Evans$(LINTLIB) := LINTFLAGS += -n 155*08278a5eSRod Evans$(LINTLIB) := LINTFLAGS64 += -n 156*08278a5eSRod Evans 157*08278a5eSRod Evans$(LINTLIB32) := LINTFLAGS += -n 158*08278a5eSRod Evans$(LINTLIB32) := LINTFLAGS64 += -n 159*08278a5eSRod Evans$(LINTLIB64) := LINTFLAGS += -n 160*08278a5eSRod Evans$(LINTLIB64) := LINTFLAGS64 += -n 1617c478bd9Sstevel@tonic-gate 1627c478bd9Sstevel@tonic-gate# 1635aefb655Srie# These libraries have two resulting lint libraries. If a dependency is 1645aefb655Srie# declared using these variables, the substitution for the 32/64 versions at 1655aefb655Srie# lint time happens automatically (see Makefile.targ). 1667c478bd9Sstevel@tonic-gate# 1675aefb655SrieLD_LIB = -lld 1685aefb655SrieLD_LIB32 = -lld32 1695aefb655SrieLD_LIB64 = -lld64 1705aefb655Srie 1717c478bd9Sstevel@tonic-gateLDDBG_LIB = -llddbg 1727c478bd9Sstevel@tonic-gateLDDBG_LIB32 = -llddbg32 1737c478bd9Sstevel@tonic-gateLDDBG_LIB64 = -llddbg64 1747c478bd9Sstevel@tonic-gate 1755aefb655SrieCONV_LIB = -lconv 1765aefb655SrieCONV_LIB32 = -lconv32 1775aefb655SrieCONV_LIB64 = -lconv64 178