Don't use -safeseh with ml64
This commit is contained in:
@@ -12,3 +12,4 @@ ffi_last_abi
|
|||||||
win64-struct-args
|
win64-struct-args
|
||||||
define-generic-symbols-carefully
|
define-generic-symbols-carefully
|
||||||
stdcall-x86-closure-fix
|
stdcall-x86-closure-fix
|
||||||
|
ml64-safeseh
|
||||||
|
|||||||
0
.pc/ml64-safeseh/.timestamp
Normal file
0
.pc/ml64-safeseh/.timestamp
Normal file
4248
.pc/ml64-safeseh/ChangeLog
Normal file
4248
.pc/ml64-safeseh/ChangeLog
Normal file
File diff suppressed because it is too large
Load Diff
183
.pc/ml64-safeseh/msvcc.sh
Executable file
183
.pc/ml64-safeseh/msvcc.sh
Executable file
@@ -0,0 +1,183 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# ***** BEGIN LICENSE BLOCK *****
|
||||||
|
# Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
||||||
|
#
|
||||||
|
# The contents of this file are subject to the Mozilla Public License Version
|
||||||
|
# 1.1 (the "License"); you may not use this file except in compliance with
|
||||||
|
# the License. You may obtain a copy of the License at
|
||||||
|
# http://www.mozilla.org/MPL/
|
||||||
|
#
|
||||||
|
# Software distributed under the License is distributed on an "AS IS" basis,
|
||||||
|
# WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
||||||
|
# for the specific language governing rights and limitations under the
|
||||||
|
# License.
|
||||||
|
#
|
||||||
|
# The Original Code is the MSVC wrappificator.
|
||||||
|
#
|
||||||
|
# The Initial Developer of the Original Code is
|
||||||
|
# Timothy Wall <twalljava@dev.java.net>.
|
||||||
|
# Portions created by the Initial Developer are Copyright (C) 2009
|
||||||
|
# the Initial Developer. All Rights Reserved.
|
||||||
|
#
|
||||||
|
# Contributor(s):
|
||||||
|
# Daniel Witte <dwitte@mozilla.com>
|
||||||
|
#
|
||||||
|
# Alternatively, the contents of this file may be used under the terms of
|
||||||
|
# either the GNU General Public License Version 2 or later (the "GPL"), or
|
||||||
|
# the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
||||||
|
# in which case the provisions of the GPL or the LGPL are applicable instead
|
||||||
|
# of those above. If you wish to allow use of your version of this file only
|
||||||
|
# under the terms of either the GPL or the LGPL, and not to allow others to
|
||||||
|
# use your version of this file under the terms of the MPL, indicate your
|
||||||
|
# decision by deleting the provisions above and replace them with the notice
|
||||||
|
# and other provisions required by the GPL or the LGPL. If you do not delete
|
||||||
|
# the provisions above, a recipient may use your version of this file under
|
||||||
|
# the terms of any one of the MPL, the GPL or the LGPL.
|
||||||
|
#
|
||||||
|
# ***** END LICENSE BLOCK *****
|
||||||
|
|
||||||
|
#
|
||||||
|
# GCC-compatible wrapper for cl.exe and ml.exe. Arguments are given in GCC
|
||||||
|
# format and translated into something sensible for cl or ml.
|
||||||
|
#
|
||||||
|
|
||||||
|
args="-nologo"
|
||||||
|
md=-MD
|
||||||
|
cl="cl"
|
||||||
|
ml="ml"
|
||||||
|
output=
|
||||||
|
|
||||||
|
while [ $# -gt 0 ]
|
||||||
|
do
|
||||||
|
case $1
|
||||||
|
in
|
||||||
|
-fexceptions)
|
||||||
|
# Don't enable exceptions for now.
|
||||||
|
#args="$args -EHac"
|
||||||
|
shift 1
|
||||||
|
;;
|
||||||
|
-m32)
|
||||||
|
shift 1
|
||||||
|
;;
|
||||||
|
-m64)
|
||||||
|
cl="cl" # "$MSVC/x86_amd64/cl"
|
||||||
|
ml="ml64" # "$MSVC/x86_amd64/ml64"
|
||||||
|
shift 1
|
||||||
|
;;
|
||||||
|
-O*)
|
||||||
|
args="$args $1"
|
||||||
|
shift 1
|
||||||
|
;;
|
||||||
|
-g)
|
||||||
|
# Can't specify -RTC1 or -Zi in opt. -Gy is ok. Use -OPT:REF?
|
||||||
|
args="$args -D_DEBUG -RTC1 -Zi"
|
||||||
|
md=-MDd
|
||||||
|
shift 1
|
||||||
|
;;
|
||||||
|
-c)
|
||||||
|
args="$args -c"
|
||||||
|
args="$(echo $args | sed 's%/Fe%/Fo%g')"
|
||||||
|
single="-c"
|
||||||
|
shift 1
|
||||||
|
;;
|
||||||
|
-D*=*)
|
||||||
|
name="$(echo $1|sed 's/-D\([^=][^=]*\)=.*/\1/g')"
|
||||||
|
value="$(echo $1|sed 's/-D[^=][^=]*=//g')"
|
||||||
|
args="$args -D${name}='$value'"
|
||||||
|
defines="$defines -D${name}='$value'"
|
||||||
|
shift 1
|
||||||
|
;;
|
||||||
|
-D*)
|
||||||
|
args="$args $1"
|
||||||
|
defines="$defines $1"
|
||||||
|
shift 1
|
||||||
|
;;
|
||||||
|
-I)
|
||||||
|
args="$args -I$2"
|
||||||
|
includes="$includes -I$2"
|
||||||
|
shift 2
|
||||||
|
;;
|
||||||
|
-I*)
|
||||||
|
args="$args $1"
|
||||||
|
includes="$includes $1"
|
||||||
|
shift 1
|
||||||
|
;;
|
||||||
|
-W|-Wextra)
|
||||||
|
# TODO map extra warnings
|
||||||
|
shift 1
|
||||||
|
;;
|
||||||
|
-Wall)
|
||||||
|
# -Wall on MSVC is overzealous. Use -W3 instead.
|
||||||
|
args="$args -W3"
|
||||||
|
shift 1
|
||||||
|
;;
|
||||||
|
-Werror)
|
||||||
|
args="$args -WX"
|
||||||
|
shift 1
|
||||||
|
;;
|
||||||
|
-W*)
|
||||||
|
# TODO map specific warnings
|
||||||
|
shift 1
|
||||||
|
;;
|
||||||
|
-S)
|
||||||
|
args="$args -FAs"
|
||||||
|
shift 1
|
||||||
|
;;
|
||||||
|
-o)
|
||||||
|
outdir="$(dirname $2)"
|
||||||
|
base="$(basename $2|sed 's/\.[^.]*//g')"
|
||||||
|
if [ -n "$single" ]; then
|
||||||
|
output="-Fo$2"
|
||||||
|
else
|
||||||
|
output="-Fe$2"
|
||||||
|
fi
|
||||||
|
if [ -n "$assembly" ]; then
|
||||||
|
args="$args $output"
|
||||||
|
else
|
||||||
|
args="$args $output -Fd$outdir/$base -Fp$outdir/$base -Fa$outdir/$base"
|
||||||
|
fi
|
||||||
|
shift 2
|
||||||
|
;;
|
||||||
|
*.S)
|
||||||
|
src=$1
|
||||||
|
assembly="true"
|
||||||
|
shift 1
|
||||||
|
;;
|
||||||
|
*.c)
|
||||||
|
args="$args $1"
|
||||||
|
shift 1
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
# Assume it's an MSVC argument, and pass it through.
|
||||||
|
args="$args $1"
|
||||||
|
shift 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ -n "$assembly" ]; then
|
||||||
|
if [ -z "$outdir" ]; then
|
||||||
|
outdir="."
|
||||||
|
fi
|
||||||
|
ppsrc="$outdir/$(basename $src|sed 's/.S$/.asm/g')"
|
||||||
|
echo "$cl -nologo -EP $includes $defines $src > $ppsrc"
|
||||||
|
"$cl" -nologo -EP $includes $defines $src > $ppsrc || exit $?
|
||||||
|
output="$(echo $output | sed 's%/F[dpa][^ ]*%%g')"
|
||||||
|
args="-nologo -safeseh $single $output $ppsrc"
|
||||||
|
|
||||||
|
echo "$ml $args"
|
||||||
|
eval "\"$ml\" $args"
|
||||||
|
result=$?
|
||||||
|
|
||||||
|
# required to fix ml64 broken output?
|
||||||
|
#mv *.obj $outdir
|
||||||
|
else
|
||||||
|
args="$md $args"
|
||||||
|
echo "$cl $args"
|
||||||
|
eval "\"$cl\" $args"
|
||||||
|
result=$?
|
||||||
|
fi
|
||||||
|
|
||||||
|
exit $result
|
||||||
|
|
||||||
@@ -6,6 +6,10 @@
|
|||||||
* src/prep_cif.c: Push stack space computation into src/x86/ffi.c
|
* src/prep_cif.c: Push stack space computation into src/x86/ffi.c
|
||||||
for X86_ANY so return value space doesn't get added twice.
|
for X86_ANY so return value space doesn't get added twice.
|
||||||
|
|
||||||
|
2010-08-03 Neil Rashbrooke <neil@parkwaycc.co.uk>
|
||||||
|
|
||||||
|
* msvcc.sh: Don't pass -safeseh to ml64 because behavior is buggy.
|
||||||
|
|
||||||
2010-07-22 Dan Witte <dwitte@mozilla.com>
|
2010-07-22 Dan Witte <dwitte@mozilla.com>
|
||||||
|
|
||||||
* src/*/ffitarget.h: Make FFI_LAST_ABI one past the last valid ABI.
|
* src/*/ffitarget.h: Make FFI_LAST_ABI one past the last valid ABI.
|
||||||
|
|||||||
4
msvcc.sh
4
msvcc.sh
@@ -46,6 +46,7 @@ args="-nologo"
|
|||||||
md=-MD
|
md=-MD
|
||||||
cl="cl"
|
cl="cl"
|
||||||
ml="ml"
|
ml="ml"
|
||||||
|
safeseh="-safeseh"
|
||||||
output=
|
output=
|
||||||
|
|
||||||
while [ $# -gt 0 ]
|
while [ $# -gt 0 ]
|
||||||
@@ -63,6 +64,7 @@ do
|
|||||||
-m64)
|
-m64)
|
||||||
cl="cl" # "$MSVC/x86_amd64/cl"
|
cl="cl" # "$MSVC/x86_amd64/cl"
|
||||||
ml="ml64" # "$MSVC/x86_amd64/ml64"
|
ml="ml64" # "$MSVC/x86_amd64/ml64"
|
||||||
|
safeseh=
|
||||||
shift 1
|
shift 1
|
||||||
;;
|
;;
|
||||||
-O*)
|
-O*)
|
||||||
@@ -164,7 +166,7 @@ if [ -n "$assembly" ]; then
|
|||||||
echo "$cl -nologo -EP $includes $defines $src > $ppsrc"
|
echo "$cl -nologo -EP $includes $defines $src > $ppsrc"
|
||||||
"$cl" -nologo -EP $includes $defines $src > $ppsrc || exit $?
|
"$cl" -nologo -EP $includes $defines $src > $ppsrc || exit $?
|
||||||
output="$(echo $output | sed 's%/F[dpa][^ ]*%%g')"
|
output="$(echo $output | sed 's%/F[dpa][^ ]*%%g')"
|
||||||
args="-nologo -safeseh $single $output $ppsrc"
|
args="-nologo $safeseh $single $output $ppsrc"
|
||||||
|
|
||||||
echo "$ml $args"
|
echo "$ml $args"
|
||||||
eval "\"$ml\" $args"
|
eval "\"$ml\" $args"
|
||||||
|
|||||||
44
patches/ml64-safeseh
Normal file
44
patches/ml64-safeseh
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
Index: libffi/ChangeLog
|
||||||
|
===================================================================
|
||||||
|
--- libffi.orig/ChangeLog
|
||||||
|
+++ libffi/ChangeLog
|
||||||
|
@@ -6,6 +6,10 @@
|
||||||
|
* src/prep_cif.c: Push stack space computation into src/x86/ffi.c
|
||||||
|
for X86_ANY so return value space doesn't get added twice.
|
||||||
|
|
||||||
|
+2010-08-03 Neil Rashbrooke <neil@parkwaycc.co.uk>
|
||||||
|
+
|
||||||
|
+ * msvcc.sh: Don't pass -safeseh to ml64 because behavior is buggy.
|
||||||
|
+
|
||||||
|
2010-07-22 Dan Witte <dwitte@mozilla.com>
|
||||||
|
|
||||||
|
* src/*/ffitarget.h: Make FFI_LAST_ABI one past the last valid ABI.
|
||||||
|
Index: libffi/msvcc.sh
|
||||||
|
===================================================================
|
||||||
|
--- libffi.orig/msvcc.sh
|
||||||
|
+++ libffi/msvcc.sh
|
||||||
|
@@ -46,6 +46,7 @@ args="-nologo"
|
||||||
|
md=-MD
|
||||||
|
cl="cl"
|
||||||
|
ml="ml"
|
||||||
|
+safeseh="-safeseh"
|
||||||
|
output=
|
||||||
|
|
||||||
|
while [ $# -gt 0 ]
|
||||||
|
@@ -63,6 +64,7 @@ do
|
||||||
|
-m64)
|
||||||
|
cl="cl" # "$MSVC/x86_amd64/cl"
|
||||||
|
ml="ml64" # "$MSVC/x86_amd64/ml64"
|
||||||
|
+ safeseh=
|
||||||
|
shift 1
|
||||||
|
;;
|
||||||
|
-O*)
|
||||||
|
@@ -164,7 +166,7 @@ if [ -n "$assembly" ]; then
|
||||||
|
echo "$cl -nologo -EP $includes $defines $src > $ppsrc"
|
||||||
|
"$cl" -nologo -EP $includes $defines $src > $ppsrc || exit $?
|
||||||
|
output="$(echo $output | sed 's%/F[dpa][^ ]*%%g')"
|
||||||
|
- args="-nologo -safeseh $single $output $ppsrc"
|
||||||
|
+ args="-nologo $safeseh $single $output $ppsrc"
|
||||||
|
|
||||||
|
echo "$ml $args"
|
||||||
|
eval "\"$ml\" $args"
|
||||||
@@ -12,3 +12,4 @@ ffi_last_abi
|
|||||||
win64-struct-args
|
win64-struct-args
|
||||||
define-generic-symbols-carefully
|
define-generic-symbols-carefully
|
||||||
stdcall-x86-closure-fix
|
stdcall-x86-closure-fix
|
||||||
|
ml64-safeseh
|
||||||
|
|||||||
Reference in New Issue
Block a user