Defs-windows.gmk revision 0
486N/A# Copyright 1999-2007 Sun Microsystems, Inc. All Rights Reserved. 486N/A# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 486N/A# This code is free software; you can redistribute it and/or modify it 486N/A# under the terms of the GNU General Public License version 2 only, as 486N/A# published by the Free Software Foundation. Sun designates this 486N/A# particular file as subject to the "Classpath" exception as provided 486N/A# by Sun in the LICENSE file that accompanied this code. 486N/A# This code is distributed in the hope that it will be useful, but WITHOUT 486N/A# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 486N/A# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 486N/A# version 2 for more details (a copy is included in the LICENSE file that 486N/A# accompanied this code). 486N/A# You should have received a copy of the GNU General Public License version 486N/A# 2 along with this work; if not, write to the Free Software Foundation, 486N/A# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 486N/A# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, 486N/A# Makefile to specify compiler flags for programs and libraries 486N/A# targeted to Windows builds. Should not contain any rules. 619N/A# WARNING: This file is shared with other workspaces. 619N/A# So when it includes other files, it must use JDK_TOPDIR. 619N/A# CC compiler object code output directive flag value 619N/A# The suffix applied to the library name for FDLIBM 486N/A# The suffix applied to scripts (.bat for windows, nothing for unix) 486N/A# LIB_LOCATION, which for windows identifies where .exe files go, may be 486N/A# set by each GNUmakefile. The default is BINDIR. 2976N/A# Platform specific closed sources 536N/A# for backwards compatability, the old "win32" is used here instead of 830N/A# The following DLL's are considered MS runtime libraries and should 2976N/A# C Compiler flag definitions 2296N/A # Visual Studio .NET 2003 or VS2003 compiler option definitions: 2650N/A # -O1 Favors reduced size over speed (-Og -Os -Oy -Ob2 -Gs -GF -Gy) 2296N/A # -O2 Favors speed over reduced size (-Og -Oi -Ot -Oy -Ob2 -Gs -GF -Gy) 2296N/A # -Ox Full optimization (use -O2) (-Og -Oi -Ot -Oy -Ob2) 2650N/A # (Removed in Visual Studio 2005 or VS2005) 2296N/A # -Ob2 More aggressive inlining 2402N/A # -Oi Replace some functions with intrinsic or special forms 2402N/A # -Op Improve floating point calculations (disables some optimizations) 2402N/A # (Replaced with -fp:precise in VS2005, /Op is default now) 2402N/A # -Oy Frame pointer omission 2422N/A # -GB Optimize for pentium (old VC6 option?) 2402N/A # -G6 VS2003 version of -GB? 2402N/A # -GF Pool strings in read-only memory 2402N/A # -Gf Pool strings in read-write memory (the default) 2402N/A # -Gs Controls stack probess 2402N/A # -GS Adds buffer overflow checks on stacks 2402N/A # -GX Enables exception handling 2402N/A # (Replaced with /EHsc in VS2005) 2402N/A # -Gy Function level linking only 961N/A # NOTE: With VC6, -Ox included -Gs. 961N/A # NOTE: With VC6, -Ox, -O1, and -O2 used -Ob1, not -Ob2. 961N/A # NOTE: With VC6, -O1 and -O2 used -Gf, not -GF. 961N/A # VC6 (6.2) msvc compiler (the way Tiger and early Mustang were built) 961N/A # Automatic precompiled header option to use (if COMPILE_APPROACH=batch) 3590N/A # Automatic precompiled header option to use (if COMPILE_APPROACH=batch) 3590N/A # Also known as VC7 compiler 961N/A # Lowered opt level to try and reduce footprint, dll size especially. 961N/A # Was: CC_HIGHEST_OPT = -O2 -G6 961N/A # Was: CC_HIGHER_OPT = -O2 # Automatic precompiled header option to use (if COMPILE_APPROACH=batch) # VS2005 compiler, only with Platform SDK right now? # GCC not supported, but left for historical reference... # If NO_OPTIMIZATIONS is defined in the environment, turn all optimzations off # Select the runtime support library carefully, need to be consistent # VS2003 compiler option definitions: # -MD Use dynamic multi-threaded runtime library # -MDd Use debug version (don't use, doesn't mix with -MD DLL's) # -MT Use static multi-threaded runtime library (-ML is going away) # -MTd Use static debug version (better than -MDd, no runtime issues) # -D_DEBUG Change use of malloc/free/etc to use special debug ones (-MTd) # NOTE: We also will use /D _STATIC_CPPLIB so we don't need msvcp71.dll # The _DEBUG macro option (changes things like malloc to use debug version) # Externally set environment variable can force any build to use the debug vers # This MS debugging flag forces a dependence on the debug # version of the runtime library (MSVCRTD.DLL), as does -MDd. # We cannot re-distribute this debug runtime. # Always add _STATIC_CPPLIB definition # VS2003 compiler option definitions: # -Zi Cause *.pdb file to be created, full debug information # -Z7 Full debug inside the .obj, no .pdb # -Zd Basic debug, no local variables? In the .obj # -Zl Don't add runtime library name to obj file? # -Od Turns off optimization and speeds compilation # -YX -Fp/.../foobar.pch Use precompiled headers (try someday?) # -nologo Don't print out startup message # Use static link for the C++ runtime (so msvcp71.dll not needed) # Starting from VS2005 the wchar_t is handled as a built-in C/C++ data type # by default. However, we expect the wchar_t to be a typedef to the # unsigned short data type. The -Zc:wchar_t- option restores the old # behavior (as seen in VS2003) to avoid massive code modifications. # When/if our code will be "C/C++ Standard"-compliant (at least in the area # of handling the wchar_t type), the option won't be necessary. # The 64bit Platform SDK we use (April 2005) doesn't like this option # All builds get the same runtime setting # The new Platform SDK and VS2005 has /GS as a default and requires # we get missing __security_check_cookie externals at link time. # LFLAGS are the flags given to $(LINK) and used to build the actual DLL file # Preprocessor macro definitions # Output options (use specific filenames to avoid parallel compile errors) # Add warnings and extra on 64bit issues # Treat compiler warnings as errors, if requested # Path and option to link against the VM, if you have to. # not supported, but left for historical reference... # Settings for the JDI - Serviceability Agent binding. # SA will never be supported here. # Hopefully, SA will be supported here one of these days, # and these will be changed to true. Until then, # to build SA on windows, do a control build with # Settings for the VERSIONINFO tap on windows. # If the update version contains non-numeric characters, we need # to massage it into a numeric format. # We use the following formula: # JDK_UPDATE_VER = JDK_UPDATE_VERSION * 10 + EXCEPTION_VERSION # Here are some examples: # 1.5.0_10 b01 -> 5,0,100,1 # 1.4.2_02 b01 -> 4,2,20,1 # 1.4.2_02a b01 -> 4,2,21,1 # 1.4.2_02b b01 -> 4,2,22,1 # J2SE name required here