diff options
author | William R. Otte <wotte@dre.vanderbilt.edu> | 2008-03-04 14:51:23 +0000 |
---|---|---|
committer | William R. Otte <wotte@dre.vanderbilt.edu> | 2008-03-04 14:51:23 +0000 |
commit | 99aa8c60282c7b8072eb35eb9ac815702f5bf586 (patch) | |
tree | bda96bf8c3a4c2875a083d7b16720533c8ffeaf4 /ACE/include/makeinclude/platform_sunos5_sunc++.GNU | |
parent | c4078c377d74290ebe4e66da0b4975da91732376 (diff) | |
download | ATCD-99aa8c60282c7b8072eb35eb9ac815702f5bf586.tar.gz |
undoing accidental deletion
Diffstat (limited to 'ACE/include/makeinclude/platform_sunos5_sunc++.GNU')
-rw-r--r-- | ACE/include/makeinclude/platform_sunos5_sunc++.GNU | 263 |
1 files changed, 263 insertions, 0 deletions
diff --git a/ACE/include/makeinclude/platform_sunos5_sunc++.GNU b/ACE/include/makeinclude/platform_sunos5_sunc++.GNU new file mode 100644 index 00000000000..8f7df58072b --- /dev/null +++ b/ACE/include/makeinclude/platform_sunos5_sunc++.GNU @@ -0,0 +1,263 @@ +# -*- Makefile -*- + +# $Id$ + +# SunOS 5.x (Solaris 2.x) with Sun C++ 4.2 and 5.x +# +# NOTE: Sun C++ 5.0 users might need to add this to their CCFLAGS: +# -compat=4 and/or remove -instances=explicit. Please note that +# inlining is disabled by default with Sun C++ 5.0. If you'd like +# to try enabling it, comment out the "inline = 0" line below. +# +# To enable compilation of 64-bit binaries with Sun CC 5.0, a +# platform_macros.GNU file such as this can be used: +# fast=1 +# include $(ACE_ROOT)/include/makeinclude/platform_sunos5_sunc++.GNU +# CFLAGS += -xtarget=ultra2 -xarch=v9a #### CPU specific! +# SOFLAGS += -xtarget=ultra2 -xarch=v9a +# LDFLAGS += -L/opt/SUNWspro/SC5.0/lib/v9 -L/usr/lib/sparcv9 +# Please note that the xtarget and xarch settings are specific to +# the target CPU. The /opt/SUNWspro/ Sun C++ installation directory +# is site-specific. +# +# To build 64-bit binaries with Forte 6 and later, build with the +# "buildbits=64" option (make buildbits=64). +# +# With slight modification, this file could be used with Sun C++ 4.1. +# However, it's likely that you won't be able to build all of ACE +# with Sun C++ 4.1. +# +# NOTE: some ACE files might generate this warning: +# "Warning: Could not find source for " one of the following: +# default constructor, copy constructor, destructor, or assignment +# operator. It appears that with +w, Sun C++ 4.x issues this warning +# whenever it has to generate one of these functions (because it wasn't +# defined by the user). This isn't really a problem. +# This warning appears to be fixed by Sun C++ 4.2 jumbo patch 104631-02. +# +# -pta instantiates all template members, which makes libraries bigger. +# But, it's supposed to put each member into it's own .o, so executable +# size should not be penalized. We don't use it because it's not +# necessary with automatic template instantiation. + +compat4 ?= 0 +debug ?= 1 +distrib ?= 0 +stdcpplib ?= 1 +threads ?= 1 +versioned_so ?= 1 +tk_reactor ?= 0 +ace_with_x11 ?= 0 +no_hidden_visibility ?= 1 +templates ?= automatic + +## If you set this to 1 you will need to add -xarch=v8plus (or higher) +## to CFLAGS or the assembler code will not compile +atomic_ops_sparc ?= 0 + +ifeq ($(threads),1) + CFLAGS += -mt + LDFLAGS += -mt +endif # threads + +CC = cc +CXX = CC + +CC_VERSION := $(shell $(CXX) -V 2>&1) + +### CC 5.4 provides insufficient preprocessor output (at 111715-17 2005/10/13) +### We need to use cc instead - see bugzilla #2478. +ifeq (C++ 5.4,$(findstring C++ 5.4,$(CC_VERSION))) + ACE_CC_PREPROCESSOR = cc +endif + +PLATFORM_STLPORT_CPPFLAGS = -library=stlport4 + +ifeq ($(atomic_ops_sparc),1) + CFLAGS += -DACE_HAS_BUILTIN_ATOMIC_OP -DACE_INCLUDE_ATOMIC_OP_SPARC +endif + +#### The following macro overrides enable creation of fast executables. +#### They _don't_ support fast compilation :-) +#### To use, add fast=1 to your "make" invocation. +#### +#### -g is incompatible with -fast. If you need -g, you can +#### use "-fast -O3". +#### +#### Have to do this _before_ adding any -xarch, -xtarget, etc. flags since +#### -fast is shorthand for a list of internally-assigned options, some of +#### which will are -xarch, -xtarget. Thus, explicit -xarch needs to go +#### to the right of -fast. +DCFLAGS += -g +DCCFLAGS += +DLD = $(CXX) +ifeq (1,$(fast)) + CFLAGS += -fast + DCFLAGS = + DCCFLAGS = + LDFLAGS += -fast +endif # fast +# Make sure we resolve all symbols at link time, see bugzilla 2710 +LDFLAGS += -z now + +ifeq (C++ 5,$(findstring C++ 5,$(CC_VERSION))) + #### CC 5.0 or later + #### Inlining appears to cause link problems with early releases of + #### CC 5.0. + ifeq (C++ 5.0,$(findstring C++ 5.0,$(CC_VERSION))) + inline = 0 + else + ifeq (C++ 5.1,$(findstring C++ 5.1,$(CC_VERSION))) + inline = 0 + else # ! 5.1 + inline ?= 1 + exceptions ?= 1 + endif # 5.2 or greater + endif #! 5.0 + + CCFLAGS += $(CFLAGS) + + #### If compat=4 is desired, set up for that. There are syntactic diffs + #### in the compatibility modes, but here all we need to be concerned with + #### is turning on -compat=4, and not trying to enable the new libraries. + ifeq ($(compat4),1) + CCFLAGS += -compat=4 + CCFLAGS += -features=rtti + else + #### Use old iostreams. + ifeq (C++ 5.0,$(findstring C++ 5.0,$(CC_VERSION))) + ifeq (1,$(stdcpplib)) + CCFLAGS += -library=Cstd + else + CCFLAGS += -library=iostream,no%Cstd + CPPFLAGS += -DACE_USES_OLD_IOSTREAMS + endif # stdcpplib + else + ifeq (0,$(stdcpplib)) + CCFLAGS += -library=iostream + CPPFLAGS += -DACE_USES_OLD_IOSTREAMS + endif # stdcpplib + + # If 64-bit build is desired, turn that on. If no code gen options + # are given to Forte 6, the default build is 32-bit, even when + # building on a 64-bit system. Specifying xarch=v9 generates code + # that runs on any Sparc v9 (64-bit) processor. + # Beginning at (I believe) Studio 10 (C++ 5.7) there's a + # -xarch=generic64 option that works for both Sparc and x86. + # If you want to tune this further, you should extract and insert + # from CCFLAGS in a private platform_macros.GNU file. + ifeq (64,$(buildbits)) + ifeq (C++ 5.7,$(findstring C++ 5.7,$(CC_VERSION))) + CFLAGS += -xarch=generic64 + LDFLAGS += -xarch=generic64 + else + ifeq (C++ 5.8,$(findstring C++ 5.8,$(CC_VERSION))) + CFLAGS += -xarch=generic64 + LDFLAGS += -xarch=generic64 + else + ifeq (C++ 5.9,$(findstring C++ 5.9,$(CC_VERSION))) + CFLAGS += -m64 + LDFLAGS += -m64 + else + CFLAGS += -xarch=v9 + LDFLAGS += -xarch=v9 + endif + endif # C++ 5.8 + endif # C++ 5.7 + endif # buildbits + endif # CC 5.0 + endif # compat4 requested +endif # CC 5.0 or later + +CCFLAGS += $(TEMPLATES_FLAG) + +#### Sun CC-specific "Pure virtual function called" bug fix trigger. +#### XXX: Shouldn't this go into a compiler version specific guard ??? +CPPFLAGS += -DSUN_CC_HAS_PVFC_BUG + +#### Exception handling breaks on MP machines prior to Sun C++ 4.2 +#### with jumbo patch 104631-02, see ace/config-sunos5.5.h. +#### If you are using a version of Sun C++ prior to 4,2, or haven't +#### applied that jumbo patch to your 4.2, or don't want to pay the +#### performance penalty of exception handling, then use the default +#### of no exceptions. If you want to enable exception handling, +#### add "exceptions=1" to your "make" invocation. +ifeq (0,$(exceptions)) + CCFLAGS += -noex + ifeq (C++ 5.6,$(findstring C++ 5.6,$(CC_VERSION))) + override stlport = 1 + else + ifeq (C++ 5.7,$(findstring C++ 5.7,$(CC_VERSION))) + override stlport = 1 + endif + endif +endif # ! exceptions + +ifeq ($(shared_libs), 1) + ifneq ($(static_libs_only), 1) + + # Sun Studio 8 or better has version greater than 5.4 (Studio 8 == CC 5.5). + SUN_STUDIO_8_OR_BETTER := $(shell a=`echo $(CC_VERSION) | sed -e 's/[^0-9]*\([0-9]*\)\.\([0-9]*\).*$$/\1\2/g'`; if test "$$a" -gt 54; then echo 1; else echo 0; fi) + + # Take advantage of Sun Studio 8 (v5.5) symbol scopes to + # generate improved shared library binaries. + ifeq ($(SUN_STUDIO_8_OR_BETTER),1) + ifneq ($(no_hidden_visibility),1) + CCFLAGS += -xldscope=hidden + else + CPPFLAGS += -DACE_HAS_CUSTOM_EXPORT_MACROS=0 + endif # no_hidden_visibility + endif # Sun Studio 8 (C++ 5.5) or better. + endif # static_libs_only +endif # shared_libs + +LD = $(CXX) +ifeq ($(distrib),0) + LDFLAGS += -R $(ACE_ROOT)/lib -R./ +endif + +# Get common Solaris settings +include $(ACE_ROOT)/include/makeinclude/platform_sunos5_common.GNU + +LIBS += -lsocket -lrt -laio -ldl -lnsl -lgen -lposix4 -ladm + +LDFLAGS += -xildoff + +OCFLAGS += -xO4 +PIC = -KPIC +AR = CC +ARFLAGS = -xar -o +RANLIB = echo +SOFLAGS += -G $(CPPFLAGS) + +# The correct flags to pass to the linker for ELF dynamic shared library +# versioning. This knows that wrapper_macros.GNU will set versioned_so to +# 1 if it's not set. So, the only way SOFLAGS should _not_ get this is if +# versioned_so has been explicitly disabled. +# +ifeq ($(versioned_so),1) + SOFLAGS += -h $(SONAME) +endif + +ifdef CLEANUP_BIN + #### Builds .shobj/$*.o file, then .shobj/$*.so file. The .o files + #### are used for building libraries and executables. But, it seems + #### to be necessary to build the .so files (with -G) in order to get + #### all template instantiations. + SOBUILD = $(COMPILE.cc) $(PIC) -o $(VSHDIR)$*.o $<; \ + $(SOLINK.cc) -o $@ -h $@ $(LDFLAGS) $(VSHDIR)$*.o +else + #### Optimize builds when no executables are built in the current + #### directory. Only a library is being created, and -G is used + #### in that step. Therefore, all templates instantations are + #### included in the library. This optimization saves almost 11 Mb + #### (2.6 percent) and 27 minutes (22 percent) on the entire ACE + #### build on a 168 MHz Sun Ultra2. + #### + #### Sun C++ won't allow the output from a compile to be named with + #### a .so extension. Rather than muck with the ACE build rules and + #### risk upsetting builds on other platforms, just ln the output + #### after building it. + SOBUILD = $(RM) $@; $(COMPILE.cc) $(PIC) -o $(VSHDIR)$*.o $< && \ + /bin/ln $(VSHDIR)$*.o $@ +endif # CLEANUP_BIN |