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 5*5aefb655Srie# Common Development and Distribution License (the "License"). 6*5aefb655Srie# 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*5aefb655Srie 22*5aefb655Srie# 23*5aefb655Srie# Copyright 2006 Sun Microsystems, Inc. All rights reserved. 24*5aefb655Srie# Use is subject to license terms. 257c478bd9Sstevel@tonic-gate# 267c478bd9Sstevel@tonic-gate# ident "%Z%%M% %I% %E% SMI" 277c478bd9Sstevel@tonic-gate# 287c478bd9Sstevel@tonic-gate 297c478bd9Sstevel@tonic-gate.KEEP_STATE: 30*5aefb655Srie.KEEP_STATE_FILE: .make.state.$(MACH) 31*5aefb655Srie 327c478bd9Sstevel@tonic-gate 337c478bd9Sstevel@tonic-gateinclude $(SRC)/cmd/sgs/Makefile.var 347c478bd9Sstevel@tonic-gate 357c478bd9Sstevel@tonic-gateSRCBASE = ../../../.. 367c478bd9Sstevel@tonic-gate 377c478bd9Sstevel@tonic-gatei386_ARCH = $(VAR_I386_ARCH) 387c478bd9Sstevel@tonic-gatesparc_ARCH = sparc 397c478bd9Sstevel@tonic-gate 407c478bd9Sstevel@tonic-gateARCH = $($(MACH)_ARCH) 417c478bd9Sstevel@tonic-gate 427c478bd9Sstevel@tonic-gateROOTCCSBIN64 = $(ROOTCCSBIN)/$(MACH64) 43*5aefb655SrieROOTCCSBINPROG64 = \ 44*5aefb655Srie $(PROG:%=$(ROOTCCSBIN64)/%) 457c478bd9Sstevel@tonic-gate 467c478bd9Sstevel@tonic-gate# Establish any global flags. 477c478bd9Sstevel@tonic-gate 48b3fbe5e6Sseizo# Setting DEBUG = -DDEBUG (or "make DEBUG=-DDEBUG ...") enables ASSERT() 49b3fbe5e6Sseizo# checking. This is automatically enabled for DEBUG builds, not for non-debug 50b3fbe5e6Sseizo# builds. Unset the global C99_DISABLE flag to insure we uncover all compiler 51b3fbe5e6Sseizo# warnings/errors. 527c478bd9Sstevel@tonic-gateDEBUG = 537c478bd9Sstevel@tonic-gate$(NOT_RELEASE_BUILD)DEBUG = -DDEBUG 547c478bd9Sstevel@tonic-gate 55b3fbe5e6SseizoC99_DISABLE = $(C99_ENABLE) 56b3fbe5e6Sseizo 577c478bd9Sstevel@tonic-gateCFLAGS += $(CCVERBOSE) $(DEBUG) $(XFFLAG) 587c478bd9Sstevel@tonic-gateCFLAGS64 += $(CCVERBOSE) $(DEBUG) $(XFFLAG) 597c478bd9Sstevel@tonic-gate 607c478bd9Sstevel@tonic-gate# Reassign CPPFLAGS so that local search paths are used before any parent 617c478bd9Sstevel@tonic-gate# $ROOT paths. 627c478bd9Sstevel@tonic-gateCPPFLAGS = -I. -I../common -I../../include -I../../include/$(MACH) \ 637c478bd9Sstevel@tonic-gate $(VAR_CPPFLAGS) $(CPPFLAGS.master) 647c478bd9Sstevel@tonic-gate 657c478bd9Sstevel@tonic-gate# PICS64 is unique to our environment 667c478bd9Sstevel@tonic-gate$(PICS64) := sparc_CFLAGS += -xregs=no%appl -K pic 677c478bd9Sstevel@tonic-gate$(PICS64) := sparcv9_CFLAGS += -xregs=no%appl -K pic 687c478bd9Sstevel@tonic-gate$(PICS64) := CPPFLAGS += -DPIC -D_REENTRANT 697c478bd9Sstevel@tonic-gate 70fb1354edSrieLDFLAGS += $(ZIGNORE) 71fb1354edSrieDYNFLAGS += $(ZIGNORE) 727c478bd9Sstevel@tonic-gate 737c478bd9Sstevel@tonic-gate# Establish the local tools, proto and package area. 747c478bd9Sstevel@tonic-gate 757c478bd9Sstevel@tonic-gateSGSHOME = $(SRC)/cmd/sgs 767c478bd9Sstevel@tonic-gateSGSPROTO = $(SGSHOME)/proto/$(MACH) 777c478bd9Sstevel@tonic-gateSGSTOOLS = $(SGSHOME)/tools 787c478bd9Sstevel@tonic-gateSGSMSGID = $(SGSHOME)/messages 797c478bd9Sstevel@tonic-gateSGSMSGDIR = $(SGSHOME)/messages/$(MACH) 807c478bd9Sstevel@tonic-gateSGSONLD = $(ROOT)/opt/SUNWonld 817c478bd9Sstevel@tonic-gateSGSRPATH = /usr/lib 827c478bd9Sstevel@tonic-gateSGSRPATH64 = $(SGSRPATH)/$(MACH64) 837c478bd9Sstevel@tonic-gate 847c478bd9Sstevel@tonic-gate# 85*5aefb655Srie# Macros to be used to include link against libconv and include vernote.o 867c478bd9Sstevel@tonic-gate# 877c478bd9Sstevel@tonic-gateVERSREF = -ulink_ver_string 88*5aefb655Srie 89*5aefb655SrieLDLIBDIR = -L$(SGSHOME)/libld/$(MACH) 90*5aefb655SrieLDLIBDIR64 = -L$(SGSHOME)/libld/$(MACH64) 91*5aefb655Srie 927c478bd9Sstevel@tonic-gateCONVLIBDIR = -L$(SGSHOME)/libconv/$(MACH) 937c478bd9Sstevel@tonic-gateCONVLIBDIR64 = -L$(SGSHOME)/libconv/$(MACH64) 947c478bd9Sstevel@tonic-gate 957c478bd9Sstevel@tonic-gateELFLIBDIR = -L$(SGSHOME)/libelf/$(MACH) 967c478bd9Sstevel@tonic-gateELFLIBDIR64 = -L$(SGSHOME)/libelf/$(MACH64) 977c478bd9Sstevel@tonic-gate 987c478bd9Sstevel@tonic-gateLDDBGLIBDIR = -L$(SGSHOME)/liblddbg/$(MACH) 997c478bd9Sstevel@tonic-gateLDDBGLIBDIR64 = -L$(SGSHOME)/liblddbg/$(MACH64) 1007c478bd9Sstevel@tonic-gate 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 1107c478bd9Sstevel@tonic-gateCHKMSG = $(SGSTOOLS)/chkmsg.sh 1117c478bd9Sstevel@tonic-gate 1127c478bd9Sstevel@tonic-gateSGSMSGVFLAG = 1137c478bd9Sstevel@tonic-gateSGSMSGFLAGS = $(SGSMSGVFLAG) -i $(SGSMSGID)/sgs.ident 1147c478bd9Sstevel@tonic-gateCHKMSGFLAGS = $(SGSMSGTARG:%=-m %) $(SGSMSGCHK:%=-m %) 1157c478bd9Sstevel@tonic-gate 1167c478bd9Sstevel@tonic-gate# Native targets should use the minimum of ld(1) flags to allow building on 1177c478bd9Sstevel@tonic-gate# previous releases. We use mapfiles to scope, but don't bother versioning. 1187c478bd9Sstevel@tonic-gate 1197c478bd9Sstevel@tonic-gatenative := DYNFLAGS = $(MAPOPTS) -R$(SGSPROTO) -L$(SGSPROTO) $(ZNOVERSION) 1207c478bd9Sstevel@tonic-gate 1217c478bd9Sstevel@tonic-gateUSE_PROTO = -Yl,$(SGSPROTO) 1227c478bd9Sstevel@tonic-gate 1237c478bd9Sstevel@tonic-gate# 1247c478bd9Sstevel@tonic-gate# lint-related stuff 1257c478bd9Sstevel@tonic-gate# 1267c478bd9Sstevel@tonic-gate 1277c478bd9Sstevel@tonic-gateDASHES = "------------------------------------------------------------" 1287c478bd9Sstevel@tonic-gate 1297c478bd9Sstevel@tonic-gateLIBNAME32 = $(LIBNAME:%=%32) 1307c478bd9Sstevel@tonic-gateLIBNAME64 = $(LIBNAME:%=%64) 1317c478bd9Sstevel@tonic-gateLIBNAMES = $(LIBNAME32) $(LIBNAME64) 1327c478bd9Sstevel@tonic-gate 1337c478bd9Sstevel@tonic-gateSGSLINTOUT = lint.out 1347c478bd9Sstevel@tonic-gateLINTOUT1 = lint.out.1 1357c478bd9Sstevel@tonic-gateLINTOUT32 = lint.out.32 1367c478bd9Sstevel@tonic-gateLINTOUT64 = lint.out.64 1377c478bd9Sstevel@tonic-gateLINTOUTS = $(SGSLINTOUT) $(LINTOUT1) $(LINTOUT32) $(LINTOUT64) 1387c478bd9Sstevel@tonic-gate 1397c478bd9Sstevel@tonic-gateLINTLIBSRC = $(LINTLIB:%.ln=%) 1407c478bd9Sstevel@tonic-gateLINTLIB32 = $(LINTLIB:%.ln=%32.ln) 1417c478bd9Sstevel@tonic-gateLINTLIB64 = $(LINTLIB:%.ln=%64.ln) 1427c478bd9Sstevel@tonic-gateLINTLIBS = $(LINTLIB32) $(LINTLIB64) 1437c478bd9Sstevel@tonic-gate 1447c478bd9Sstevel@tonic-gateLINTFLAGS = -m -errtags=yes -erroff=E_SUPPRESSION_DIRECTIVE_UNUSED 1457c478bd9Sstevel@tonic-gateLINTFLAGS64 = -m -errtags=yes -erroff=E_SUPPRESSION_DIRECTIVE_UNUSED \ 146*5aefb655Srie $(VAR_LINTFLAGS64) \ 1477c478bd9Sstevel@tonic-gate 1487c478bd9Sstevel@tonic-gate# 149*5aefb655Srie# These libraries have two resulting lint libraries. If a dependency is 150*5aefb655Srie# declared using these variables, the substitution for the 32/64 versions at 151*5aefb655Srie# lint time happens automatically (see Makefile.targ). 1527c478bd9Sstevel@tonic-gate# 153*5aefb655SrieLD_LIB = -lld 154*5aefb655SrieLD_LIB32 = -lld32 155*5aefb655SrieLD_LIB64 = -lld64 156*5aefb655Srie 1577c478bd9Sstevel@tonic-gateLDDBG_LIB = -llddbg 1587c478bd9Sstevel@tonic-gateLDDBG_LIB32 = -llddbg32 1597c478bd9Sstevel@tonic-gateLDDBG_LIB64 = -llddbg64 1607c478bd9Sstevel@tonic-gate 161*5aefb655SrieCONV_LIB = -lconv 162*5aefb655SrieCONV_LIB32 = -lconv32 163*5aefb655SrieCONV_LIB64 = -lconv64 164