guix: combine and document enable_werror

Combine into hardened-glibc.
Document why we don't use --disable-werror directly.

https://www.gnu.org/software/libc/manual/html_node/Configuring-and-compiling.html
> By default, the GNU C Library is built with -Werror. If you wish
> to build without this option (for example, if building with a
> newer version of GCC than this version of the GNU C Library was
> tested with, so new warnings cause the build with -Werror to fail),
> you can configure with --disable-werror.
This commit is contained in:
fanquake 2023-03-24 15:23:33 +00:00
parent e352f5ab6b
commit 4becee396f
No known key found for this signature in database
GPG key ID: 2EEB9F5CC09526C1

View file

@ -150,7 +150,7 @@ chain for " target " development."))
#:key #:key
(base-gcc-for-libc base-gcc) (base-gcc-for-libc base-gcc)
(base-kernel-headers base-linux-kernel-headers) (base-kernel-headers base-linux-kernel-headers)
(base-libc (hardened-glibc (make-glibc-without-werror glibc-2.27))) (base-libc (hardened-glibc glibc-2.27))
(base-gcc (make-gcc-rpath-link (hardened-gcc base-gcc)))) (base-gcc (make-gcc-rpath-link (hardened-gcc base-gcc))))
"Convenience wrapper around MAKE-CROSS-TOOLCHAIN with default values "Convenience wrapper around MAKE-CROSS-TOOLCHAIN with default values
desirable for building Bitcoin Core release binaries." desirable for building Bitcoin Core release binaries."
@ -530,13 +530,14 @@ and endian independent.")
inspecting signatures in Mach-O binaries.") inspecting signatures in Mach-O binaries.")
(license license:expat)))) (license license:expat))))
(define (make-glibc-without-werror glibc)
(package-with-extra-configure-variable glibc "enable_werror" "no"))
;; https://www.gnu.org/software/libc/manual/html_node/Configuring-and-compiling.html ;; https://www.gnu.org/software/libc/manual/html_node/Configuring-and-compiling.html
;; We don't use --disable-werror directly, as that would be passed through to bash,
;; and cause it's build to fail.
(define (hardened-glibc glibc) (define (hardened-glibc glibc)
(package-with-extra-configure-variable ( (package-with-extra-configure-variable (
package-with-extra-configure-variable (
package-with-extra-configure-variable glibc package-with-extra-configure-variable glibc
"enable_werror" "no")
"--enable-stack-protector" "all") "--enable-stack-protector" "all")
"--enable-bind-now" "yes")) "--enable-bind-now" "yes"))