GNU bug report logs - #77418
cross compile kernel to arm is stopped by GCC_PLUGIN_LATENT_ENTROPY

Previous Next

Package: guix;

Reported by: Tadhg McDonald-Jensen <tadhgmister <at> gmail.com>

Date: Mon, 31 Mar 2025 21:21:02 UTC

Severity: normal

To reply to this bug, email your comments to 77418 AT debbugs.gnu.org.

Toggle the display of automated, internal messages from the tracker.

View this report as an mbox folder, status mbox, maintainer mbox


Report forwarded to bug-guix <at> gnu.org:
bug#77418; Package guix. (Mon, 31 Mar 2025 21:21:02 GMT) Full text and rfc822 format available.

Acknowledgement sent to Tadhg McDonald-Jensen <tadhgmister <at> gmail.com>:
New bug report received and forwarded. Copy sent to bug-guix <at> gnu.org. (Mon, 31 Mar 2025 21:21:02 GMT) Full text and rfc822 format available.

Message #5 received at submit <at> debbugs.gnu.org (full text, mbox):

From: Tadhg McDonald-Jensen <tadhgmister <at> gmail.com>
To: bug-guix <at> gnu.org
Subject: cross compile kernel to arm is stopped by GCC_PLUGIN_LATENT_ENTROPY
Date: Mon, 31 Mar 2025 17:20:09 -0400
[Message part 1 (text/plain, inline)]
Hello,

if you try to run `guix build --target=arm-linux-gnueabihf --cores=1
linux-libre <at> 6.13` you will be greeted by an error that files under the
/gnu/store/...gcc-cross-arm... seem to have invalid syntax and are being
imported by `scripts/gcc-plugins/latent_entropy_plugin.c:78`

I'm trying to establish whether this is an upstream bug or a way that
guix deals with the cross compilation, I am not versed enough in C
pre-processor to be able to understand the exact issue.

and if you just disable that plugin the kernel can compile fine, for
instance if you copy the definition of linux-libre package and just add
a rule that disables that plugin (using customize-linux doesn't work as
it errors that the rule conflicts with the one specified by guix)

```scm
(use-modules (gnu packages linux))
;; get non exported helpers to replicate the exact notation used in
linux.scm
(define make-linux-libre* (@@ (gnu packages linux) make-linux-libre*))
(define default-extra-linux-options (@@ (gnu packages linux)
default-extra-linux-options))
(define kernel-config (@@ (gnu packages linux) kernel-config))
;; exact copy of linux-libre-6.13 from gnu/packages/linux.scm with one
extra-option
(define linux-libre-6.13-without-gcc-plugin-latent-entropy
  (make-linux-libre* linux-libre-6.13-version
                     linux-libre-6.13-gnu-revision
                     linux-libre-6.13-source
                     '("x86_64-linux" "i686-linux" "armhf-linux"
                       "aarch64-linux" "powerpc64le-linux" "riscv64-linux")
                     #:configuration-file kernel-config
                     #:extra-options
                     (append
                      `(("CONFIG_GCC_PLUGIN_LATENT_ENTROPY" . #f))
                      (default-extra-linux-options
linux-libre-6.13-version))
		     ))

linux-libre-6.13-without-gcc-plugin-latent-entropy
```

this compiles with `guix build --target=arm-linux-gnueabihf -f
that_file.scm` just fine.

Currently with the 'normal' kernel not cross compiling and
`linux-libre-arm-generic` not setting up the initrd modules in a way
guix expects, it is currently not at all clear how to deploy guix to an
arm device so fixing this would be ideal.

In the case that this is an upstream issue can you at least give me a
bit of context for why the error is pointing to files in the guix cross
compiler? I'd like to report this as precisely as possible and really
don't have a clear idea of what is going on.

Thanks,
Tadhg
[OpenPGP_0x85C0C8DCBBF44EE7.asc (application/pgp-keys, attachment)]
[OpenPGP_signature.asc (application/pgp-signature, attachment)]

Information forwarded to bug-guix <at> gnu.org:
bug#77418; Package guix. (Tue, 01 Apr 2025 20:24:03 GMT) Full text and rfc822 format available.

Message #8 received at 77418 <at> debbugs.gnu.org (full text, mbox):

From: Tadhg McDonald-Jensen <tadhgmister <at> gmail.com>
To: 77418 <at> debbugs.gnu.org
Subject: Re: bug#77418: Acknowledgement (cross compile kernel to arm is
 stopped by GCC_PLUGIN_LATENT_ENTROPY)
Date: Tue, 1 Apr 2025 16:23:31 -0400
[Message part 1 (text/plain, inline)]
It just occured to me that the gcc plugin shouldn't be compiled against
arm binaries at all, they are used in the build process. In the
configure phase files under scripts/kconfig are compiled with HOSTCC but
the gcc plugin is being compiled with CC, this is definitely not an
issue with guix.

I will file a bug report upstream.

On 2025-03-31 5:21 p.m., GNU bug Tracking System wrote:
> Thank you for filing a new bug report with debbugs.gnu.org.
> 
> This is an automatically generated reply to let you know your message
> has been received.
> 
> Your message is being forwarded to the package maintainers and other
> interested parties for their attention; they will reply in due course.
> 
> Your message has been sent to the package maintainer(s):
>  bug-guix <at> gnu.org
> 
> If you wish to submit further information on this problem, please
> send it to 77418 <at> debbugs.gnu.org.
> 
> Please do not send mail to help-debbugs <at> gnu.org unless you wish
> to report a problem with the Bug-tracking system.
> 
[OpenPGP_0x85C0C8DCBBF44EE7.asc (application/pgp-keys, attachment)]
[OpenPGP_signature.asc (application/pgp-signature, attachment)]

This bug report was last modified 3 days ago.

Previous Next


GNU bug tracking system
Copyright (C) 1999 Darren O. Benham, 1997,2003 nCipher Corporation Ltd, 1994-97 Ian Jackson.