diff options
author | Steve Hay <SteveHay@planit.com> | 2006-03-20 17:32:25 +0000 |
---|---|---|
committer | Steve Hay <SteveHay@planit.com> | 2006-03-20 17:32:25 +0000 |
commit | 9453ddcdbeef10a6fde0fc2cfacccab40a79f2fb (patch) | |
tree | 8c21f81430a366fe5350a94b41fc57ad6acf30a3 /win32 | |
parent | 465b7da9858f72896e8487a1bf0595ae400e05fe (diff) | |
download | perl-9453ddcdbeef10a6fde0fc2cfacccab40a79f2fb.tar.gz |
Merge some more changes from ActivePerl 5.8.8.816
See (again):
http://downloads.activestate.com/ActivePerl/src/5.8/AP816_diff.txt
These changes improve support for the MS 64-bit compiler in
win32/Makefile (and tentatively make the same changes to
win32/makefile.mk), and also switches the now deprecated -Gf switch to
-GF for all flavours of VC++ instead of just the latest ones.
(See:
http://www.xray.mpe.mpg.de/mailing-lists/perl5-porters/2006-02/msg00353.html
for a comment on the s/-Gf/-GF/ change.)
p4raw-id: //depot/perl@27556
Diffstat (limited to 'win32')
-rw-r--r-- | win32/Makefile | 32 | ||||
-rw-r--r-- | win32/makefile.mk | 30 |
2 files changed, 33 insertions, 29 deletions
diff --git a/win32/Makefile b/win32/Makefile index 77f9ddc2c6..3257ed311b 100644 --- a/win32/Makefile +++ b/win32/Makefile @@ -2,7 +2,7 @@ # Makefile to build perl on Windows NT using Microsoft NMAKE. # Supported compilers: # Visual C++ 2.0 through 7.0 (and possibly newer versions) -# MS Platform SDK 64-bit compiler and tools **experimental** +# MS Platform SDK 64-bit compiler and tools # # This is set up to build a perl.exe that runs off a shared library # (perl59.dll). Also makes individual DLLs for the XS extensions. @@ -320,6 +320,13 @@ WIN64 = undef !ENDIF !ENDIF +!IF "$(PROCESSOR_ARCHITECTURE)" == "AMD64" +PROCESSOR_ARCHITECTURE = x86_64 +!ENDIF +!IF "$(PROCESSOR_ARCHITECTURE)" == "IA64" +PROCESSOR_ARCHITECTURE = ia64 +!ENDIF + !IF "$(USE_MULTI)" == "define" ARCHNAME = MSWin32-$(PROCESSOR_ARCHITECTURE)-multi !ELSE @@ -419,15 +426,7 @@ OPTIMIZE = $(OPTIMIZE) -O1 !IF "$(WIN64)" == "define" DEFINES = $(DEFINES) -DWIN64 -DCONSERVATIVE -OPTIMIZE = $(OPTIMIZE) -Wp64 -Op -!ENDIF - -# the string-pooling option -Gf is deprecated in VC++ 7.x and will be removed -# in later versions, so use read-only string-pooling (-GF) instead -!IF "$(CCTYPE)" == "MSVC70FREE" || "$(CCTYPE)" == "MSVC70" || "$(CCTYPE)" == "MSVC80FREE" || "$(CCTYPE)" == "MSVC80" -STRPOOL = -GF -!ELSE -STRPOOL = -Gf +OPTIMIZE = $(OPTIMIZE) -Wp64 -fp:precise !ENDIF !IF "$(USE_PERLCRT)" != "define" @@ -438,17 +437,20 @@ LIBBASEFILES = $(CRYPT_LIB) \ oldnames.lib kernel32.lib user32.lib gdi32.lib winspool.lib \ comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib \ netapi32.lib uuid.lib ws2_32.lib mpr.lib winmm.lib \ - version.lib + version.lib odbc32.lib odbccp32.lib -# win64 doesn't have some libs -!IF "$(WIN64)" != "define" -LIBBASEFILES = $(LIBBASEFILES) odbc32.lib odbccp32.lib +# The 64 bit Platform SDK compilers contain a runtime library that doesn't +# include the buffer overrun verification code used by the /GS switch. +# Since the code links against libraries that are compiled with /GS, this +# "security cookie verification" must be included via bufferoverlow.lib. +!IF "$(WIN64)" == "define" +LIBBASEFILES = $(LIBBASEFILES) bufferoverflowU.lib !ENDIF # we add LIBC here, since we may be using PerlCRT.dll LIBFILES = $(LIBBASEFILES) $(LIBC) -EXTRACFLAGS = -nologo $(STRPOOL) -W3 +EXTRACFLAGS = -nologo -GF -W3 CFLAGS = $(EXTRACFLAGS) $(INCLUDES) $(DEFINES) $(LOCDEFS) \ $(PCHFLAGS) $(OPTIMIZE) LINK_FLAGS = -nologo -nodefaultlib $(LINK_DBG) \ diff --git a/win32/makefile.mk b/win32/makefile.mk index ebf6e444f0..f3604893fc 100644 --- a/win32/makefile.mk +++ b/win32/makefile.mk @@ -319,6 +319,13 @@ WIN64 = undef .ENDIF .ENDIF +.IF "$(PROCESSOR_ARCHITECTURE)" == "AMD64" +PROCESSOR_ARCHITECTURE = x86_64 +.ENDIF +.IF "$(PROCESSOR_ARCHITECTURE)" == "IA64" +PROCESSOR_ARCHITECTURE = ia64 +.ENDIF + .IF "$(USE_MULTI)" == "define" ARCHNAME = MSWin32-$(PROCESSOR_ARCHITECTURE)-multi .ELSE @@ -525,15 +532,7 @@ OPTIMIZE += -O1 .IF "$(WIN64)" == "define" DEFINES += -DWIN64 -DCONSERVATIVE -OPTIMIZE += -Wp64 -Op -.ENDIF - -# the string-pooling option -Gf is deprecated in VC++ 7.x and will be removed -# in later versions, so use read-only string-pooling (-GF) instead -.IF "$(CCTYPE)" == "MSVC70FREE" || "$(CCTYPE)" == "MSVC70" -STRPOOL = -GF -.ELSE -STRPOOL = -Gf +OPTIMIZE += -Wp64 -fp:precise .ENDIF .IF "$(USE_PERLCRT)" != "define" @@ -544,17 +543,20 @@ LIBBASEFILES = $(CRYPT_LIB) \ oldnames.lib kernel32.lib user32.lib gdi32.lib winspool.lib \ comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib \ netapi32.lib uuid.lib ws2_32.lib mpr.lib winmm.lib \ - version.lib + version.lib odbc32.lib odbccp32.lib -# win64 doesn't have some libs -.IF "$(WIN64)" != "define" -LIBBASEFILES += odbc32.lib odbccp32.lib +# The 64 bit Platform SDK compilers contain a runtime library that doesn't +# include the buffer overrun verification code used by the /GS switch. +# Since the code links against libraries that are compiled with /GS, this +# "security cookie verification" must be included via bufferoverlow.lib. +.IF "$(WIN64)" == "define" +LIBBASEFILES = $(LIBBASEFILES) bufferoverflowU.lib .ENDIF # we add LIBC here, since we may be using PerlCRT.dll LIBFILES = $(LIBBASEFILES) $(LIBC) -EXTRACFLAGS = -nologo $(STRPOOL) -W3 +EXTRACFLAGS = -nologo -GF -W3 CFLAGS = $(EXTRACFLAGS) $(INCLUDES) $(DEFINES) $(LOCDEFS) \ $(PCHFLAGS) $(OPTIMIZE) LINK_FLAGS = -nologo -nodefaultlib $(LINK_DBG) \ |