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# 215aefb655Srie# 225aefb655Srie# Copyright 2006 Sun Microsystems, Inc. All rights reserved. 235aefb655Srie# Use is subject to license terms. 247c478bd9Sstevel@tonic-gate# 257c478bd9Sstevel@tonic-gate# ident "%Z%%M% %I% %E% SMI" 267c478bd9Sstevel@tonic-gate# 277c478bd9Sstevel@tonic-gate 287c478bd9Sstevel@tonic-gate.KEEP_STATE: 295aefb655Srie.KEEP_STATE_FILE: .make.state.$(MACH) 305aefb655Srie 317c478bd9Sstevel@tonic-gate 327c478bd9Sstevel@tonic-gateinclude $(SRC)/cmd/sgs/Makefile.var 337c478bd9Sstevel@tonic-gate 347c478bd9Sstevel@tonic-gateSRCBASE = ../../../.. 357c478bd9Sstevel@tonic-gate 367c478bd9Sstevel@tonic-gatei386_ARCH = $(VAR_I386_ARCH) 377c478bd9Sstevel@tonic-gatesparc_ARCH = sparc 387c478bd9Sstevel@tonic-gate 397c478bd9Sstevel@tonic-gateARCH = $($(MACH)_ARCH) 407c478bd9Sstevel@tonic-gate 417c478bd9Sstevel@tonic-gateROOTCCSBIN64 = $(ROOTCCSBIN)/$(MACH64) 425aefb655SrieROOTCCSBINPROG64 = \ 435aefb655Srie $(PROG:%=$(ROOTCCSBIN64)/%) 447c478bd9Sstevel@tonic-gate 457c478bd9Sstevel@tonic-gate# Establish any global flags. 467c478bd9Sstevel@tonic-gate 47b3fbe5e6Sseizo# Setting DEBUG = -DDEBUG (or "make DEBUG=-DDEBUG ...") enables ASSERT() 48b3fbe5e6Sseizo# checking. This is automatically enabled for DEBUG builds, not for non-debug 49b3fbe5e6Sseizo# builds. Unset the global C99_DISABLE flag to insure we uncover all compiler 50b3fbe5e6Sseizo# warnings/errors. 517c478bd9Sstevel@tonic-gateDEBUG = 527c478bd9Sstevel@tonic-gate$(NOT_RELEASE_BUILD)DEBUG = -DDEBUG 537c478bd9Sstevel@tonic-gate 54b3fbe5e6SseizoC99_DISABLE = $(C99_ENABLE) 55b3fbe5e6Sseizo 567c478bd9Sstevel@tonic-gateCFLAGS += $(CCVERBOSE) $(DEBUG) $(XFFLAG) 577c478bd9Sstevel@tonic-gateCFLAGS64 += $(CCVERBOSE) $(DEBUG) $(XFFLAG) 587c478bd9Sstevel@tonic-gate 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) \ 627c478bd9Sstevel@tonic-gate $(VAR_CPPFLAGS) $(CPPFLAGS.master) 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 1007c478bd9Sstevel@tonic-gate# The cmd/Makefile.com and lib/Makefile.com define TEXT_DOMAIN. We don't need 1017c478bd9Sstevel@tonic-gate# this definition as the sgs utilities obtain their domain via sgsmsg(1l). 1027c478bd9Sstevel@tonic-gate 1037c478bd9Sstevel@tonic-gateDTEXTDOM = 1047c478bd9Sstevel@tonic-gate 1057c478bd9Sstevel@tonic-gate# Define any generic sgsmsg(1l) flags. The default message generation system 1067c478bd9Sstevel@tonic-gate# is to use gettext(3i), add the -C flag to switch to catgets(3c). 1077c478bd9Sstevel@tonic-gate 1087c478bd9Sstevel@tonic-gateSGSMSG = $(SGSTOOLS)/$(MACH)/sgsmsg 1097c478bd9Sstevel@tonic-gateCHKMSG = $(SGSTOOLS)/chkmsg.sh 1107c478bd9Sstevel@tonic-gate 1117c478bd9Sstevel@tonic-gateSGSMSGVFLAG = 1127c478bd9Sstevel@tonic-gateSGSMSGFLAGS = $(SGSMSGVFLAG) -i $(SGSMSGID)/sgs.ident 1137c478bd9Sstevel@tonic-gateCHKMSGFLAGS = $(SGSMSGTARG:%=-m %) $(SGSMSGCHK:%=-m %) 1147c478bd9Sstevel@tonic-gate 1157c478bd9Sstevel@tonic-gate# Native targets should use the minimum of ld(1) flags to allow building on 1167c478bd9Sstevel@tonic-gate# previous releases. We use mapfiles to scope, but don't bother versioning. 1177c478bd9Sstevel@tonic-gate 118*f808c858Srafnative := DYNFLAGS = -R$(SGSPROTO) -L$(SGSPROTO) $(ZNOVERSION) 1197c478bd9Sstevel@tonic-gate 1207c478bd9Sstevel@tonic-gateUSE_PROTO = -Yl,$(SGSPROTO) 1217c478bd9Sstevel@tonic-gate 1227c478bd9Sstevel@tonic-gate# 1237c478bd9Sstevel@tonic-gate# lint-related stuff 1247c478bd9Sstevel@tonic-gate# 1257c478bd9Sstevel@tonic-gate 1267c478bd9Sstevel@tonic-gateDASHES = "------------------------------------------------------------" 1277c478bd9Sstevel@tonic-gate 1287c478bd9Sstevel@tonic-gateLIBNAME32 = $(LIBNAME:%=%32) 1297c478bd9Sstevel@tonic-gateLIBNAME64 = $(LIBNAME:%=%64) 1307c478bd9Sstevel@tonic-gateLIBNAMES = $(LIBNAME32) $(LIBNAME64) 1317c478bd9Sstevel@tonic-gate 1327c478bd9Sstevel@tonic-gateSGSLINTOUT = lint.out 1337c478bd9Sstevel@tonic-gateLINTOUT1 = lint.out.1 1347c478bd9Sstevel@tonic-gateLINTOUT32 = lint.out.32 1357c478bd9Sstevel@tonic-gateLINTOUT64 = lint.out.64 1367c478bd9Sstevel@tonic-gateLINTOUTS = $(SGSLINTOUT) $(LINTOUT1) $(LINTOUT32) $(LINTOUT64) 1377c478bd9Sstevel@tonic-gate 1387c478bd9Sstevel@tonic-gateLINTLIBSRC = $(LINTLIB:%.ln=%) 1397c478bd9Sstevel@tonic-gateLINTLIB32 = $(LINTLIB:%.ln=%32.ln) 1407c478bd9Sstevel@tonic-gateLINTLIB64 = $(LINTLIB:%.ln=%64.ln) 1417c478bd9Sstevel@tonic-gateLINTLIBS = $(LINTLIB32) $(LINTLIB64) 1427c478bd9Sstevel@tonic-gate 1437c478bd9Sstevel@tonic-gateLINTFLAGS = -m -errtags=yes -erroff=E_SUPPRESSION_DIRECTIVE_UNUSED 1447c478bd9Sstevel@tonic-gateLINTFLAGS64 = -m -errtags=yes -erroff=E_SUPPRESSION_DIRECTIVE_UNUSED \ 1455aefb655Srie $(VAR_LINTFLAGS64) \ 1467c478bd9Sstevel@tonic-gate 1477c478bd9Sstevel@tonic-gate# 1485aefb655Srie# These libraries have two resulting lint libraries. If a dependency is 1495aefb655Srie# declared using these variables, the substitution for the 32/64 versions at 1505aefb655Srie# lint time happens automatically (see Makefile.targ). 1517c478bd9Sstevel@tonic-gate# 1525aefb655SrieLD_LIB = -lld 1535aefb655SrieLD_LIB32 = -lld32 1545aefb655SrieLD_LIB64 = -lld64 1555aefb655Srie 1567c478bd9Sstevel@tonic-gateLDDBG_LIB = -llddbg 1577c478bd9Sstevel@tonic-gateLDDBG_LIB32 = -llddbg32 1587c478bd9Sstevel@tonic-gateLDDBG_LIB64 = -llddbg64 1597c478bd9Sstevel@tonic-gate 1605aefb655SrieCONV_LIB = -lconv 1615aefb655SrieCONV_LIB32 = -lconv32 1625aefb655SrieCONV_LIB64 = -lconv64 163