git@vger.kernel.org mailing list mirror (one of many)
 help / color / mirror / code / Atom feed
From: Philip Oakley <philipoakley@iee.org>
To: Git List <git@vger.kernel.org>
Cc: Junio C Hamano <gitster@pobox.com>,
	MsysGit List <msysgit@googlegroups.com>,
	Yue Lin Ho <b8732003@student.nsysu.edu.tw>,
	Philip Oakley <philipoakley@iee.org>
Subject: [PATCH v2 16/16] config.mak.uname: add MSVC No_SafeExeceptionHandler option
Date: Sun, 19 Jul 2015 21:08:17 +0100	[thread overview]
Message-ID: <1437336497-4072-18-git-send-email-philipoakley@iee.org> (raw)
In-Reply-To: <1437336497-4072-1-git-send-email-philipoakley@iee.org>

Microsoft flipped the Windows Safe Exception Handling default
in VS2013 so that zlib became unacceptable to certain OS versions
(Vista and subsequent 32-bit OS's) without the addition of
the option -SAFESEH:NO.

Provide a switch to disable the Safe Exeption Handler when required.

The option ImageHasSafeExceptionHandlers for VS2013 is not available in
earlier versions, so use the SAFESEH:NO linker flag. See
https://msdn.microsoft.com/en-us/library/9a89h429.aspx for
further details.

This has only had limited testing due to the lack of a suitable system.

Helped-by: Yue Lin Ho <b8732003@student.nsysu.edu.tw>
Signed-off-by: Philip Oakley <philipoakley@iee.org>
---
Junio/my discussion on reviews: http://marc.info/?l=git&m=143526063906215&w=2 (2015-06-25)
Patch series v1: https://github.com/msysgit/git/pull/318
Yue Lin Ho: https://github.com/msysgit/git/pull/318#issuecomment-81292918
---
 config.mak.uname | 9 +++++++++
 1 file changed, 9 insertions(+)

diff --git a/config.mak.uname b/config.mak.uname
index 943c439..1c27828 100644
--- a/config.mak.uname
+++ b/config.mak.uname
@@ -1,5 +1,9 @@
 # Platform specific Makefile tweaks based on uname detection
 
+# Define NO_SAFESEH if you need MSVC/Visual Studio to ignore the lack of
+# Microsoft's Safe Exception Handling in libraries (such as zlib).
+# Typically required for VS2013+/32-bit compilation on Vista+ versions.
+
 uname_S := $(shell sh -c 'uname -s 2>/dev/null || echo not')
 uname_M := $(shell sh -c 'uname -m 2>/dev/null || echo not')
 uname_O := $(shell sh -c 'uname -o 2>/dev/null || echo not')
@@ -385,6 +389,11 @@ ifeq ($(uname_S),Windows)
 	PTHREAD_LIBS =
 	lib =
 	BASIC_CFLAGS += -DPROTECT_NTFS_DEFAULT=1
+
+ifdef NO_SAFESEH
+	LDFLAGS += -SAFESEH:NO
+endif
+
 ifndef DEBUG
 	BASIC_CFLAGS += -GL -Os -MD
 	BASIC_LDFLAGS += -LTCG
-- 
2.4.2.windows.1.5.gd32afb6

-- 
-- 
*** Please reply-to-all at all times ***
*** (do not pretend to know who is subscribed and who is not) ***
*** Please avoid top-posting. ***
The msysGit Wiki is here: https://github.com/msysgit/msysgit/wiki - Github accounts are free.

You received this message because you are subscribed to the Google
Groups "msysGit" group.
To post to this group, send email to msysgit@googlegroups.com
To unsubscribe from this group, send email to
msysgit+unsubscribe@googlegroups.com
For more options, and view previous threads, visit this group at
http://groups.google.com/group/msysgit?hl=en_US?hl=en

--- 
You received this message because you are subscribed to the Google Groups "Git for Windows" group.
To unsubscribe from this group and stop receiving emails from it, send an email to msysgit+unsubscribe@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

      parent reply	other threads:[~2015-07-19 20:07 UTC|newest]

Thread overview: 26+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-07-19 20:08 [PATCH v2 00/16] Make the msvc-build scripts work again Philip Oakley
2015-07-19 20:08 ` [PATCH v2 01/16] perl/Makefile: treat a missing PM.stamp as if empty Philip Oakley
2015-07-19 20:08 ` [PATCH v2 02/16] .gitignore: improve MSVC ignore patterns Philip Oakley
2015-07-19 20:08 ` [PATCH v2 03/16] .gitignore: ignore library directories created by MSVC VS2008 buildsystem Philip Oakley
2015-07-19 20:08 ` [PATCH v2 04/16] (msvc-build) Vcproj.pm: remove duplicate GUID Philip Oakley
2015-07-19 20:08 ` [PATCH v2 05/16] engine.pl: fix error message (lib->link) Philip Oakley
2015-07-19 20:08 ` [PATCH v2 06/16] engine.pl: Properly accept quoted spaces in filenames Philip Oakley
2015-07-19 20:08 ` [PATCH v2 07/16] engine.pl: Fix i18n -o option in msvc buildsystem generator Philip Oakley
2015-07-19 20:08 ` [PATCH v2 08/16] engine.pl: ignore invalidcontinue.obj which is known to MSVC Philip Oakley
2015-07-20  1:54   ` Eric Sunshine
2015-07-20  6:13     ` Philip Oakley
2015-07-19 20:08 ` [PATCH v2 09/16] engine.pl: name the msvc buildsystem's makedry error file Philip Oakley
2015-07-19 20:08 ` [PATCH v2 10/16] engine.pl: delete the captured stderr file if empty Philip Oakley
2015-07-20  2:01   ` Eric Sunshine
2015-07-20  6:16     ` Philip Oakley
2015-07-20  6:40       ` Eric Sunshine
2015-07-20 11:55         ` Philip Oakley
2015-07-20 18:10           ` Eric Sunshine
2015-07-19 20:08 ` [PATCH v2 11/16] engine.pl: add debug line to capture the dry-run Philip Oakley
2015-07-19 20:08 ` [PATCH v2 12/16] engine.pl: provide more debug print statements Philip Oakley
2015-07-19 20:08 ` [PATCH v2 13/16] Vcproj.pm: list git.exe first to be startup project Philip Oakley
2015-07-19 20:08 ` [PATCH v2 14/16] vcbuild/readme: Improve layout and reference msvc-build script Philip Oakley
2015-07-19 20:21   ` Philip Oakley
2015-07-19 20:08 ` [PATCH v2 14/16] vcbuild/readme: Improve layout Philip Oakley
2015-07-19 20:08 ` [PATCH v2 15/16] msvc-build: add complete Microsoft Visual C compilation script Philip Oakley
2015-07-19 20:08 ` Philip Oakley [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: http://vger.kernel.org/majordomo-info.html

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1437336497-4072-18-git-send-email-philipoakley@iee.org \
    --to=philipoakley@iee.org \
    --cc=b8732003@student.nsysu.edu.tw \
    --cc=git@vger.kernel.org \
    --cc=gitster@pobox.com \
    --cc=msysgit@googlegroups.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this public inbox

	https://80x24.org/mirrors/git.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).