mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-25 20:19:18 -05:00
gnu: mingw: Add x86_64 support.
This patch parameterizes previously hard-coded instances of i686-w64-mingw32, adding support for x86_64-w64-mingw32. * gnu/packages/mingw.scm (make-mingw-w64): New procedure. (mingw-w64-i686, mingw-w64-x86_64): New variables. (%mingw-triplet): Remove. (mingw-w64): Update to point to 'mingw-w64-i686'. * gnu/packages/cross-base.scm (cross-gcc): Use 'libc' keyword argument if specified, instead of treating it as a boolean. (native-libc): Return the correct mingw-w64 depending on machine specified in target. * gnu/packages/bootstrap.scm (glibc-dynamic-linker): Add "x86_64-mingw". * gnu/build/cross-toolchain.scm (set-cross-path/mingw): Replace hardcoded 'i686-w64-mingw32' instances with 'target' keyword argument. (cross-gcc-build-phases): Update accordingly; use 'target-mingw?' implementation of target checking and add commentary. * gnu/ci.scm (%cross-targets): Add "x86_64-w64-mingw32".
This commit is contained in:
parent
4afdb79249
commit
67dac6b892
5 changed files with 78 additions and 59 deletions
|
@ -3,6 +3,7 @@
|
||||||
;;; Copyright © 2014, 2015, 2018 Mark H Weaver <mhw@netris.org>
|
;;; Copyright © 2014, 2015, 2018 Mark H Weaver <mhw@netris.org>
|
||||||
;;; Copyright © 2016 Jan Nieuwenhuizen <janneke@gnu.org>
|
;;; Copyright © 2016 Jan Nieuwenhuizen <janneke@gnu.org>
|
||||||
;;; Copyright © 2016 Manolis Fragkiskos Ragkousis <manolis837@gmail.com>
|
;;; Copyright © 2016 Manolis Fragkiskos Ragkousis <manolis837@gmail.com>
|
||||||
|
;;; Copyright © 2019 Carl Dong <contact@carldong.me>
|
||||||
;;;
|
;;;
|
||||||
;;; This file is part of GNU Guix.
|
;;; This file is part of GNU Guix.
|
||||||
;;;
|
;;;
|
||||||
|
@ -95,7 +96,7 @@ (define (cross? x)
|
||||||
;; We're building the sans-libc cross-compiler, so nothing to do.
|
;; We're building the sans-libc cross-compiler, so nothing to do.
|
||||||
#t)))
|
#t)))
|
||||||
|
|
||||||
(define* (set-cross-path/mingw #:key inputs #:allow-other-keys)
|
(define* (set-cross-path/mingw #:key inputs target #:allow-other-keys)
|
||||||
"Add the cross MinGW headers to CROSS_C_*_INCLUDE_PATH, and remove them from
|
"Add the cross MinGW headers to CROSS_C_*_INCLUDE_PATH, and remove them from
|
||||||
C_*INCLUDE_PATH."
|
C_*INCLUDE_PATH."
|
||||||
(let ((libc (assoc-ref inputs "libc"))
|
(let ((libc (assoc-ref inputs "libc"))
|
||||||
|
@ -112,7 +113,7 @@ (define (unpacked-mingw-dir)
|
||||||
|
|
||||||
(if libc
|
(if libc
|
||||||
(let ((cpath (string-append libc "/include"
|
(let ((cpath (string-append libc "/include"
|
||||||
":" libc "/i686-w64-mingw32/include")))
|
":" libc "/" target "/include")))
|
||||||
(for-each (cut setenv <> cpath)
|
(for-each (cut setenv <> cpath)
|
||||||
%gcc-cross-include-paths))
|
%gcc-cross-include-paths))
|
||||||
|
|
||||||
|
@ -142,7 +143,7 @@ (define (unpacked-mingw-dir)
|
||||||
(when libc
|
(when libc
|
||||||
(setenv "CROSS_LIBRARY_PATH"
|
(setenv "CROSS_LIBRARY_PATH"
|
||||||
(string-append libc "/lib"
|
(string-append libc "/lib"
|
||||||
":" libc "/i686-w64-mingw32/lib")))
|
":" libc "/" target "/lib")))
|
||||||
|
|
||||||
(setenv "CPP" (string-append gcc "/bin/cpp"))
|
(setenv "CPP" (string-append gcc "/bin/cpp"))
|
||||||
(for-each (lambda (var)
|
(for-each (lambda (var)
|
||||||
|
@ -168,8 +169,12 @@ (define* (cross-gcc-build-phases target
|
||||||
a target triplet."
|
a target triplet."
|
||||||
(modify-phases phases
|
(modify-phases phases
|
||||||
(add-before 'configure 'set-cross-path
|
(add-before 'configure 'set-cross-path
|
||||||
(if (string-contains target "mingw")
|
;; This mingw32 target checking logic should match that of target-mingw?
|
||||||
set-cross-path/mingw
|
;; in (guix utils), but (guix utils) is too large too copy over to the
|
||||||
|
;; build side entirely and for now we have no way to select variables to
|
||||||
|
;; copy over. See (gnu packages cross-base) for more details.
|
||||||
|
(if (string-suffix? "-mingw32" target)
|
||||||
|
(cut set-cross-path/mingw #:target target <...>)
|
||||||
set-cross-path))
|
set-cross-path))
|
||||||
(add-after 'install 'make-cross-binutils-visible
|
(add-after 'install 'make-cross-binutils-visible
|
||||||
(cut make-cross-binutils-visible #:target target <...>))
|
(cut make-cross-binutils-visible #:target target <...>))
|
||||||
|
|
|
@ -130,7 +130,8 @@ (define %cross-targets
|
||||||
"aarch64-linux-gnu"
|
"aarch64-linux-gnu"
|
||||||
"powerpc-linux-gnu"
|
"powerpc-linux-gnu"
|
||||||
"i586-pc-gnu" ;aka. GNU/Hurd
|
"i586-pc-gnu" ;aka. GNU/Hurd
|
||||||
"i686-w64-mingw32"))
|
"i686-w64-mingw32"
|
||||||
|
"x86_64-w64-mingw32"))
|
||||||
|
|
||||||
(define %guixsd-supported-systems
|
(define %guixsd-supported-systems
|
||||||
'("x86_64-linux" "i686-linux" "armhf-linux"))
|
'("x86_64-linux" "i686-linux" "armhf-linux"))
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
;;; Copyright © 2012, 2013, 2014, 2015, 2016, 2017, 2018, 2019 Ludovic Courtès <ludo@gnu.org>
|
;;; Copyright © 2012, 2013, 2014, 2015, 2016, 2017, 2018, 2019 Ludovic Courtès <ludo@gnu.org>
|
||||||
;;; Copyright © 2014, 2015, 2018 Mark H Weaver <mhw@netris.org>
|
;;; Copyright © 2014, 2015, 2018 Mark H Weaver <mhw@netris.org>
|
||||||
;;; Copyright © 2017 Efraim Flashner <efraim@flashner.co.il>
|
;;; Copyright © 2017 Efraim Flashner <efraim@flashner.co.il>
|
||||||
|
;;; Copyright © 2019 Carl Dong <contact@carldong.me>
|
||||||
;;;
|
;;;
|
||||||
;;; This file is part of GNU Guix.
|
;;; This file is part of GNU Guix.
|
||||||
;;;
|
;;;
|
||||||
|
@ -187,6 +188,7 @@ (define* (glibc-dynamic-linker
|
||||||
((string=? system "avr") "no-ld.so")
|
((string=? system "avr") "no-ld.so")
|
||||||
((string=? system "propeller-elf") "no-ld.so")
|
((string=? system "propeller-elf") "no-ld.so")
|
||||||
((string=? system "i686-mingw") "no-ld.so")
|
((string=? system "i686-mingw") "no-ld.so")
|
||||||
|
((string=? system "x86_64-mingw") "no-ld.so")
|
||||||
((string=? system "vc4-elf") "no-ld.so")
|
((string=? system "vc4-elf") "no-ld.so")
|
||||||
|
|
||||||
(else (error "dynamic linker name not known for this system"
|
(else (error "dynamic linker name not known for this system"
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
;;; Copyright © 2016 Jan Nieuwenhuizen <janneke@gnu.org>
|
;;; Copyright © 2016 Jan Nieuwenhuizen <janneke@gnu.org>
|
||||||
;;; Copyright © 2016 Manolis Fragkiskos Ragkousis <manolis837@gmail.com>
|
;;; Copyright © 2016 Manolis Fragkiskos Ragkousis <manolis837@gmail.com>
|
||||||
;;; Copyright © 2018 Tobias Geerinckx-Rice <me@tobias.gr>
|
;;; Copyright © 2018 Tobias Geerinckx-Rice <me@tobias.gr>
|
||||||
|
;;; Copyright © 2019 Carl Dong <contact@carldong.me>
|
||||||
;;;
|
;;;
|
||||||
;;; This file is part of GNU Guix.
|
;;; This file is part of GNU Guix.
|
||||||
;;;
|
;;;
|
||||||
|
@ -249,7 +250,7 @@ (define* (cross-gcc target
|
||||||
(cond
|
(cond
|
||||||
((target-mingw? target)
|
((target-mingw? target)
|
||||||
(if libc
|
(if libc
|
||||||
`(("libc" ,mingw-w64)
|
`(("libc" ,libc)
|
||||||
,@inputs)
|
,@inputs)
|
||||||
`(("mingw-source" ,(package-source mingw-w64))
|
`(("mingw-source" ,(package-source mingw-w64))
|
||||||
,@inputs)))
|
,@inputs)))
|
||||||
|
@ -509,7 +510,8 @@ (define* (native-libc target
|
||||||
#:optional
|
#:optional
|
||||||
(libc glibc))
|
(libc glibc))
|
||||||
(if (target-mingw? target)
|
(if (target-mingw? target)
|
||||||
mingw-w64
|
(let ((machine (substring target 0 (string-index target #\-))))
|
||||||
|
(make-mingw-w64 machine))
|
||||||
libc))
|
libc))
|
||||||
|
|
||||||
(define* (cross-newlib? target
|
(define* (cross-newlib? target
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
;;; GNU Guix --- Functional package management for GNU
|
;;; GNU Guix --- Functional package management for GNU
|
||||||
;;; Copyright © 2016 Jan Nieuwenhuizen <janneke@gnu.org>
|
;;; Copyright © 2016 Jan Nieuwenhuizen <janneke@gnu.org>
|
||||||
;;; Copyright © 2018 Tobias Geerinckx-Rice <me@tobias.gr>
|
;;; Copyright © 2018 Tobias Geerinckx-Rice <me@tobias.gr>
|
||||||
|
;;; Copyright © 2019 Carl Dong <contact@carldong.me>
|
||||||
;;;
|
;;;
|
||||||
;;; This file is part of GNU Guix.
|
;;; This file is part of GNU Guix.
|
||||||
;;;
|
;;;
|
||||||
|
@ -31,56 +32,56 @@ (define-module (gnu packages mingw)
|
||||||
#:use-module (guix utils)
|
#:use-module (guix utils)
|
||||||
#:use-module (ice-9 match))
|
#:use-module (ice-9 match))
|
||||||
|
|
||||||
(define %mingw-triplet
|
(define-public (make-mingw-w64 machine)
|
||||||
"i686-w64-mingw32")
|
(let ((triplet (string-append machine "-" "w64-mingw32")))
|
||||||
|
(package
|
||||||
(define-public mingw-w64
|
(name (string-append "mingw-w64" "-" machine))
|
||||||
(package
|
(version "5.0.4")
|
||||||
(name "mingw-w64")
|
(source (origin
|
||||||
(version "5.0.4")
|
(method url-fetch)
|
||||||
(source (origin
|
(uri (string-append
|
||||||
(method url-fetch)
|
"https://sourceforge.net/projects/mingw-w64/files/mingw-w64/"
|
||||||
(uri (string-append
|
"mingw-w64-release/mingw-w64-v" version ".tar.bz2"))
|
||||||
"https://sourceforge.net/projects/mingw-w64/files/mingw-w64/"
|
(sha256
|
||||||
"mingw-w64-release/mingw-w64-v" version ".tar.bz2"))
|
(base32 "00zq3z1hbzd5yzmskskjg79xrzwsqx7ihyprfaxy4hb897vf29sm"))
|
||||||
(sha256
|
(patches (search-patches "mingw-w64-5.0rc2-gcc-4.9.3.patch"))))
|
||||||
(base32 "00zq3z1hbzd5yzmskskjg79xrzwsqx7ihyprfaxy4hb897vf29sm"))
|
(native-inputs `(("xgcc-core" ,(cross-gcc triplet))
|
||||||
(patches (search-patches "mingw-w64-5.0rc2-gcc-4.9.3.patch"))))
|
("xbinutils" ,(cross-binutils triplet))))
|
||||||
(native-inputs `(("xgcc-core" ,(cross-gcc %mingw-triplet))
|
(build-system gnu-build-system)
|
||||||
("xbinutils" ,(cross-binutils %mingw-triplet))))
|
(search-paths
|
||||||
(build-system gnu-build-system)
|
(list (search-path-specification
|
||||||
(search-paths
|
(variable "CROSS_C_INCLUDE_PATH")
|
||||||
(list (search-path-specification
|
(files `("include" ,(string-append triplet "/include"))))
|
||||||
(variable "CROSS_C_INCLUDE_PATH")
|
(search-path-specification
|
||||||
(files '("include" "i686-w64-mingw32/include")))
|
(variable "CROSS_LIBRARY_PATH")
|
||||||
(search-path-specification
|
(files
|
||||||
(variable "CROSS_LIBRARY_PATH")
|
`("lib" "lib64"
|
||||||
(files
|
,(string-append triplet "/lib")
|
||||||
'("lib" "lib64" "i686-w64-mingw32/lib" "i686-w64-mingw32/lib64")))))
|
,(string-append triplet "/lib64"))))))
|
||||||
(arguments
|
(arguments
|
||||||
`(#:configure-flags '("--host=i686-w64-mingw32")
|
`(#:configure-flags '(,(string-append "--host=" triplet))
|
||||||
#:phases
|
#:phases
|
||||||
(modify-phases %standard-phases
|
(modify-phases %standard-phases
|
||||||
(add-before 'configure 'setenv
|
(add-before 'configure 'setenv
|
||||||
(lambda* (#:key inputs #:allow-other-keys)
|
(lambda* (#:key inputs #:allow-other-keys)
|
||||||
(let ((xgcc-core (assoc-ref inputs "xgcc-core"))
|
(let ((xgcc-core (assoc-ref inputs "xgcc-core"))
|
||||||
(mingw-headers (string-append (getcwd) "/mingw-w64-headers")))
|
(mingw-headers (string-append (getcwd) "/mingw-w64-headers")))
|
||||||
(setenv "CPP"
|
(setenv "CPP"
|
||||||
(string-append xgcc-core "/bin/i686-w64-mingw32-cpp"))
|
(string-append xgcc-core ,(string-append "/bin/" triplet "-cpp")))
|
||||||
(setenv "CROSS_C_INCLUDE_PATH"
|
(setenv "CROSS_C_INCLUDE_PATH"
|
||||||
(string-append
|
(string-append
|
||||||
mingw-headers
|
mingw-headers
|
||||||
":" mingw-headers "/include"
|
":" mingw-headers "/include"
|
||||||
":" mingw-headers "/crt"
|
":" mingw-headers "/crt"
|
||||||
":" mingw-headers "/defaults/include"
|
":" mingw-headers "/defaults/include"
|
||||||
":" mingw-headers "/direct-x/include"))))))
|
":" mingw-headers "/direct-x/include"))))))
|
||||||
#:make-flags (list "DEFS=-DHAVE_CONFIG_H -D__MINGW_HAS_DXSDK=1")
|
#:make-flags (list "DEFS=-DHAVE_CONFIG_H -D__MINGW_HAS_DXSDK=1")
|
||||||
#:tests? #f ; compiles and includes glibc headers
|
#:tests? #f ; compiles and includes glibc headers
|
||||||
#:strip-binaries? #f))
|
#:strip-binaries? #f))
|
||||||
(home-page "https://mingw-w64.org")
|
(home-page "https://mingw-w64.org")
|
||||||
(synopsis "Minimalist GNU for Windows")
|
(synopsis "Minimalist GNU for Windows")
|
||||||
(description
|
(description
|
||||||
"Minimalist GNU for Windows (@dfn{MinGW}) is a complete software
|
"Minimalist GNU for Windows (@dfn{MinGW}) is a complete software
|
||||||
development environment for creating native Microsoft Windows applications.
|
development environment for creating native Microsoft Windows applications.
|
||||||
|
|
||||||
It includes a set of Windows-specific header files and static import libraries
|
It includes a set of Windows-specific header files and static import libraries
|
||||||
|
@ -89,4 +90,12 @@ (define-public mingw-w64
|
||||||
|
|
||||||
Mingw-w64 is an advancement of the original mingw.org project and provides
|
Mingw-w64 is an advancement of the original mingw.org project and provides
|
||||||
several new APIs such as DirectX and DDK, and 64-bit support.")
|
several new APIs such as DirectX and DDK, and 64-bit support.")
|
||||||
(license license:fdl1.3+)))
|
(license license:fdl1.3+))))
|
||||||
|
|
||||||
|
(define-public mingw-w64-i686
|
||||||
|
(make-mingw-w64 "i686"))
|
||||||
|
|
||||||
|
(define-public mingw-w64-x86_64
|
||||||
|
(make-mingw-w64 "x86_64"))
|
||||||
|
|
||||||
|
(define-public mingw-w64 mingw-w64-i686)
|
||||||
|
|
Loading…
Reference in a new issue