[tor-commits] [tor-browser-build/master] Bug 23228: add support for building mingw-w64 for Windows 64

gk at torproject.org gk at torproject.org
Mon Nov 6 09:47:27 UTC 2017


commit b82d82d9cf9cb751e088085fb1093026b20a0e4d
Author: Nicolas Vigier <boklm at torproject.org>
Date:   Sat Aug 12 22:50:58 2017 +0200

    Bug 23228: add support for building mingw-w64 for Windows 64
    
    Add torbrowser-windows-x86_64 support to rbm.conf.
    
    Update mingw-w64 to use the x86_64-w64-mingw32 target (instead of
    i686-w64-mingw32) for torbrowser-windows-x86_64 builds.
---
 projects/binutils/64bit-fixups.patch    | 55 +++++++++++++++++++++++++++++++++
 projects/binutils/build                 |  7 +++--
 projects/binutils/config                |  6 ++--
 projects/mingw-w64/build                | 32 +++++++++++++------
 projects/mingw-w64/config               | 15 ++++++---
 projects/mingw-w64/i686-w64-mingw32-g++ |  4 ---
 projects/mingw-w64/i686-w64-mingw32-gcc |  4 ---
 projects/mingw-w64/i686-w64-mingw32-ld  |  4 ---
 rbm.conf                                | 33 ++++++++++++++------
 9 files changed, 122 insertions(+), 38 deletions(-)

diff --git a/projects/binutils/64bit-fixups.patch b/projects/binutils/64bit-fixups.patch
new file mode 100644
index 0000000..33c0297
--- /dev/null
+++ b/projects/binutils/64bit-fixups.patch
@@ -0,0 +1,55 @@
+From f3ba95e14437f10de8b8f296930ff2a8495d18c6 Mon Sep 17 00:00:00 2001
+From: Georg Koppen <gk at torproject.org>
+Date: Tue, 12 Sep 2017 07:21:16 +0000
+Subject: [PATCH] 64bit fixups
+
+
+diff --git a/ld/emultempl/pep.em b/ld/emultempl/pep.em
+index b566903b14..27006bdf79 100644
+--- a/ld/emultempl/pep.em
++++ b/ld/emultempl/pep.em
+@@ -730,7 +730,7 @@ gld${EMULATION_NAME}_handle_option (int optc)
+       pep_dll_exclude_all_symbols = 1;
+       break;
+     case OPTION_ENABLE_RELOC_SECTION:
+-      pe_dll_enable_reloc_section = 1;
++      pep_dll_enable_reloc_section = 1;
+       break;
+     case OPTION_EXCLUDE_LIBS:
+       pep_dll_add_excludes (optarg, EXCLUDELIBS);
+@@ -1623,7 +1623,7 @@ gld_${EMULATION_NAME}_finish (void)
+ 
+ #ifdef DLL_SUPPORT
+   if (link_info.shared
+-      || (!link_info.relocatable && pe_dll_enable_reloc_section)
++      || (!link_info.relocatable && pep_dll_enable_reloc_section)
+       || (!link_info.relocatable && pep_def_file->num_exports != 0))
+     {
+       pep_dll_fill_sections (link_info.output_bfd, &link_info);
+diff --git a/ld/pep-dll.c b/ld/pep-dll.c
+index 0e5e8b1523..b5f99b90e0 100644
+--- a/ld/pep-dll.c
++++ b/ld/pep-dll.c
+@@ -31,6 +31,7 @@
+ #define pe_dll_export_everything    pep_dll_export_everything
+ #define pe_dll_exclude_all_symbols  pep_dll_exclude_all_symbols
+ #define pe_dll_do_default_excludes  pep_dll_do_default_excludes
++#define pe_dll_enable_reloc_section pep_dll_enable_reloc_section
+ #define pe_dll_kill_ats             pep_dll_kill_ats
+ #define pe_dll_stdcall_aliases      pep_dll_stdcall_aliases
+ #define pe_dll_warn_dup_exports     pep_dll_warn_dup_exports
+diff --git a/ld/pep-dll.h b/ld/pep-dll.h
+index 1e7e3d65d4..c31e69cc8e 100644
+--- a/ld/pep-dll.h
++++ b/ld/pep-dll.h
+@@ -31,6 +31,7 @@ extern def_file * pep_def_file;
+ extern int pep_dll_export_everything;
+ extern int pep_dll_exclude_all_symbols;
+ extern int pep_dll_do_default_excludes;
++extern int pep_dll_enable_reloc_section;
+ extern int pep_dll_kill_ats;
+ extern int pep_dll_stdcall_aliases;
+ extern int pep_dll_warn_dup_exports;
+-- 
+2.14.1
+
diff --git a/projects/binutils/build b/projects/binutils/build
index a7d83d9..6d8e0b2 100644
--- a/projects/binutils/build
+++ b/projects/binutils/build
@@ -21,10 +21,13 @@ cd [% project %]-[% c("version") %]
 [% IF c('var/windows') -%]
   # XXX: This is needed due to bug 10102.
   sed 's/= extern_rt_rel_d;/= extern_rt_rel_d;\n  memset (extern_rt_rel_d, 0, PE_IDATA5_SIZE);/' -i ld/pe-dll.c
-  # Needed for the hardening...
-  patch -p1 < ../enable-reloc-section-ld.patch
   # Zeroing timestamps in PE headers reliably, see bug 12753.
   patch -p1 < ../peXXigen.patch
+  # Needed for the hardening...
+  patch -p1 < ../enable-reloc-section-ld.patch
+[% END -%]
+[% IF c('var/windows-x86_64') -%]
+  patch -p1 < ../64bit-fixups.patch
 [% END -%]
 [% IF c("var/linux") -%]
   # We need to work around a gold linker bug in 2.24 to get selfrando working,
diff --git a/projects/binutils/config b/projects/binutils/config
index f272c76..25417c0 100644
--- a/projects/binutils/config
+++ b/projects/binutils/config
@@ -7,9 +7,9 @@ var:
     use_container: 1
 
 targets:
-  windows-i686:
+  windows:
     var:
-      configure_opt: '--target=i686-w64-mingw32 --disable-multilib --enable-deterministic-archives'
+      configure_opt: '--target=[% c("arch") %]-w64-mingw32 --disable-multilib --enable-deterministic-archives'
 
 input_files:
   - URL: https://ftp.gnu.org/gnu/binutils/binutils-[% c("version") %].tar.bz2
@@ -19,6 +19,8 @@ input_files:
   - project: container-image
   - filename: enable-reloc-section-ld.patch
     enable: '[% c("var/windows") %]'
+  - filename: 64bit-fixups.patch
+    enable: '[% c("var/windows-x86_64") %]'
   - filename: peXXigen.patch
     enable: '[% c("var/windows") %]'
   - filename: binutils-224-gold.patch
diff --git a/projects/mingw-w64/build b/projects/mingw-w64/build
index 0fc4517..8d3e567 100644
--- a/projects/mingw-w64/build
+++ b/projects/mingw-w64/build
@@ -14,7 +14,7 @@ tar xf $rootdir/[% project %]-[% c("version") %].tar.gz
 mkdir -p builddir/mingw-w64/mingw-w64-headers32
 cd builddir/mingw-w64/mingw-w64-headers32
 /var/tmp/build/[% project %]-[% c("version") %]/mingw-w64-headers/configure \
-                --prefix=$distdir/i686-w64-mingw32 --host=i686-w64-mingw32 \
+                --prefix=$distdir/[% c("arch") %]-w64-mingw32 --host=[% c("arch") %]-w64-mingw32 \
                 --enable-sdk=all --enable-secure-api --enable-idl
 make install
 
@@ -23,28 +23,28 @@ mkdir gcc
 cd gcc
 tar xjf $rootdir/gcc-[% c("var/gcc_version") %].tar.bz2
 # We don't want to link against msvcrt.dll due to bug 9084.
-i686-w64-mingw32-g++ -dumpspecs > $distdir/msvcr100.spec
+[% c("arch") %]-w64-mingw32-g++ -dumpspecs > $distdir/msvcr100.spec
 sed 's/msvcrt/msvcr100/' -i $distdir/msvcr100.spec
 # Linking libgcc against msvcrt is hard-coded...
 sed 's/msvcrt/msvcr100/' -i gcc-[% c("var/gcc_version") %]/gcc/config/i386/t-mingw-w32
 # LDFLAGS_FOR_TARGET does not work for some reason. Thus, we take
 # CFLAGS_FOR_TARGET.
 export CFLAGS_FOR_TARGET="-specs=$distdir/msvcr100.spec -Wl,--nxcompat -Wl,--dynamicbase"
-gcc-[% c("var/gcc_version") %]/configure --prefix=$distdir --target=i686-w64-mingw32 --disable-multilib --enable-languages=c,c++
+gcc-[% c("var/gcc_version") %]/configure --prefix=$distdir --target=[% c("arch") %]-w64-mingw32 --disable-multilib --enable-languages=c,c++
 make -j[% c("buildconf/num_procs") %] all-gcc
 make install-gcc
 
 mkdir -p /var/tmp/build/builddir/mingw-w64/mingw-w64-crt32
 cd /var/tmp/build/builddir/mingw-w64/mingw-w64-crt32
 /var/tmp/build/[% project %]-[% c("version") %]/mingw-w64-crt/configure \
-                 --host=i686-w64-mingw32 --prefix=$distdir/i686-w64-mingw32
+                 --host=[% c("arch") %]-w64-mingw32 --prefix=$distdir/[% c("arch") %]-w64-mingw32
 make -j[% c("buildconf/num_procs") %]
 make install
 
 mkdir -p /var/tmp/build/builddir/mingw-w64/widl32
 cd /var/tmp/build/builddir/mingw-w64/widl32
 /var/tmp/build/[% project %]-[% c("version") %]/mingw-w64-tools/widl/configure \
-                 --prefix=$distdir --target=i686-w64-mingw32
+                 --prefix=$distdir --target=[% c("arch") %]-w64-mingw32
 make -j[% c("buildconf/num_procs") %]
 make install
 
@@ -52,12 +52,26 @@ cd /var/tmp/build/gcc
 make -j[% c("buildconf/num_procs") %]
 make install
 mkdir -p $distdir/gcclibs
-cp i686-w64-mingw32/libssp/.libs/libssp-0.dll $distdir/gcclibs
-cp i686-w64-mingw32/libgcc/shlib/libgcc_s_sjlj-1.dll $distdir/gcclibs
+cp [% c("arch") %]-w64-mingw32/libssp/.libs/libssp-0.dll $distdir/gcclibs
+cp [% c("arch") %]-w64-mingw32/libgcc/shlib/[% c("var/libgcc_dll") %] $distdir/gcclibs
 
 mkdir -p $distdir/helpers
-mv $rootdir/i686-w64-mingw32-g++ $rootdir/i686-w64-mingw32-gcc \
-    $rootdir/i686-w64-mingw32-ld $distdir/helpers/
+
+cat > $distdir/helpers/[% c("arch") %]-w64-mingw32-g++ << 'EOF'
+#!/bin/sh
+/var/tmp/dist/mingw-w64/bin/[% c("arch") %]-w64-mingw32-g++ -Wl,--dynamicbase -Wl,--nxcompat -Wl,--enable-reloc-section -fstack-protector --param ssp-buffer-size=4 -fno-strict-overflow "$@"
+EOF
+
+cat > $distdir/helpers/[% c("arch") %]-w64-mingw32-gcc << 'EOF'
+#!/bin/sh
+/var/tmp/dist/mingw-w64/bin/[% c("arch") %]-w64-mingw32-gcc -Wl,--dynamicbase -Wl,--nxcompat -Wl,--enable-reloc-section -fstack-protector --param ssp-buffer-size=4 -fno-strict-overflow "$@"
+EOF
+
+cat > $distdir/helpers/[% c("arch") %]-w64-mingw32-ld << 'EOF'
+#!/bin/sh
+/var/tmp/dist/mingw-w64/bin/[% c("arch") %]-w64-mingw32-ld --dynamicbase --nxcompat --enable-reloc-section -lssp -L$gcclibs "$@"
+EOF
+
 chmod +x $distdir/helpers/*
 
 cd /var/tmp/dist
diff --git a/projects/mingw-w64/config b/projects/mingw-w64/config
index ac1caa9..bb66167 100644
--- a/projects/mingw-w64/config
+++ b/projects/mingw-w64/config
@@ -11,19 +11,26 @@ var:
     - automake
     - build-essential
     - libmpc-dev
-    - g++-mingw-w64-i686
   setup: |
     [% c("var/setarch") -%]
     mkdir -p /var/tmp/dist
     tar -C /var/tmp/dist -xf [% c("compiler_tarfile") %]
     export PATH="/var/tmp/dist/mingw-w64/helpers:/var/tmp/dist/mingw-w64/bin:$PATH"
     export gcclibs=/var/tmp/dist/mingw-w64/gcclibs
+targets:
+  windows-i686:
+    var:
+      libgcc_dll: libgcc_s_sjlj-1.dll
+      arch_deps:
+        - g++-mingw-w64-i686
+  windows-x86_64:
+    var:
+      libgcc_dll: libgcc_s_seh-1.dll
+      arch_deps:
+        - g++-mingw-w64-x86-64
 input_files:
   - project: container-image
   - URL: 'https://ftp.gnu.org/gnu/gcc/gcc-[% c("var/gcc_version") %]/gcc-[% c("var/gcc_version") %].tar.bz2'
     sha256sum: 608df76dec2d34de6558249d8af4cbee21eceddbcb580d666f7a5a583ca3303a
   - name: binutils
     project: binutils
-  - filename: i686-w64-mingw32-g++
-  - filename: i686-w64-mingw32-gcc
-  - filename: i686-w64-mingw32-ld
diff --git a/projects/mingw-w64/i686-w64-mingw32-g++ b/projects/mingw-w64/i686-w64-mingw32-g++
deleted file mode 100755
index c5421a2..0000000
--- a/projects/mingw-w64/i686-w64-mingw32-g++
+++ /dev/null
@@ -1,4 +0,0 @@
-#!/bin/sh
-# Hardened mingw gcc wrapper
-
-/var/tmp/dist/mingw-w64/bin/i686-w64-mingw32-g++ -Wl,--dynamicbase -Wl,--nxcompat -Wl,--enable-reloc-section -fstack-protector --param ssp-buffer-size=4 -fno-strict-overflow "$@"
diff --git a/projects/mingw-w64/i686-w64-mingw32-gcc b/projects/mingw-w64/i686-w64-mingw32-gcc
deleted file mode 100755
index 741ef8a..0000000
--- a/projects/mingw-w64/i686-w64-mingw32-gcc
+++ /dev/null
@@ -1,4 +0,0 @@
-#!/bin/sh
-# Hardened mingw gcc wrapper
-
-/var/tmp/dist/mingw-w64/bin/i686-w64-mingw32-gcc -Wl,--dynamicbase -Wl,--nxcompat -Wl,--enable-reloc-section -fstack-protector --param ssp-buffer-size=4 -fno-strict-overflow "$@"
diff --git a/projects/mingw-w64/i686-w64-mingw32-ld b/projects/mingw-w64/i686-w64-mingw32-ld
deleted file mode 100755
index bcf5e5b..0000000
--- a/projects/mingw-w64/i686-w64-mingw32-ld
+++ /dev/null
@@ -1,4 +0,0 @@
-#!/bin/sh
-# Hardened mingw gcc wrapper
-
-/var/tmp/dist/mingw-w64/bin/i686-w64-mingw32-ld --dynamicbase --nxcompat --enable-reloc-section -lssp -L$gcclibs "$@"
diff --git a/rbm.conf b/rbm.conf
index ab2a080..6e800f2 100644
--- a/rbm.conf
+++ b/rbm.conf
@@ -171,15 +171,36 @@ targets:
 
   torbrowser-windows-i686:
     - windows-i686
+    - windows
+  torbrowser-windows-x86_64:
+    - windows-x86_64
+    - windows
+  windows-x86_64:
+    arch: x86_64
+    var:
+      windows-x86_64: 1
+      osname: windows-x86_64
+      container:
+        arch: amd64
   windows-i686:
     arch: i686
     var:
-      windows: 1
+      windows-i686: 1
       osname: windows-i686
       container:
-        suite: precise
         arch: i386
-      configure_opt: '--host=i686-w64-mingw32 CFLAGS="[% c("var/CFLAGS") %]" LDFLAGS="[% c("var/LDFLAGS") %]"'
+      setarch: |
+        if test -z "$RBM_SETARCH"
+        then
+           export RBM_SETARCH=1
+           exec setarch i686 ./build
+        fi
+  windows:
+    var:
+      windows: 1
+      container:
+        suite: precise
+      configure_opt: '--host=[% c("arch") %]-w64-mingw32 CFLAGS="[% c("var/CFLAGS") %]" LDFLAGS="[% c("var/LDFLAGS") %]"'
       CFLAGS: '[% c("var/flag_mwindows") %] -fstack-protector-all -Wstack-protector --param ssp-buffer-size=4 -fno-strict-overflow -Wno-missing-field-initializers -Wformat -Wformat-security'
       LDFLAGS: '[% c("var/flag_mwindows") %] -Wl,--dynamicbase -Wl,--nxcompat -Wl,--enable-reloc-section -lssp -L$gcclibs'
       flag_mwindows: '-mwindows'
@@ -193,12 +214,6 @@ targets:
         - zip
         - unzip
       faketime_path: /usr/lib/faketime/libfaketime.so.1
-      setarch: |
-        if test -z "$RBM_SETARCH"
-        then
-           export RBM_SETARCH=1
-           exec setarch i686 ./build
-        fi
       fteproxy: 1
       install_wine_ppa: |
         # Install a Wine new enough to have a fix for



More information about the tor-commits mailing list