bug-guix
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

bug#53296: Intermittent segfaults when parsing (?) custom package from r


From: Ludovic Courtès
Subject: bug#53296: Intermittent segfaults when parsing (?) custom package from repo.
Date: Mon, 17 Jan 2022 16:42:23 +0100
User-agent: Gnus/5.13 (Gnus v5.13) Emacs/27.2 (gnu/linux)

Hi,

elaexuotee@wilsonb.com skribis:

> Recently working on a package, I have been encounting intermittent segfault
> during a build.
>
> The segfault seems to only occur when I have some error in my code that causes
> a crash, and the segfaults tend to cluster, appearing unexpectedly for a few
> build attempts, and then disappearing right as I think they are reproducible
> and try to grab an strace or something. Unfortunately, that's about the extent
> of information I have been able to gleen.
>
> The latest segfault happened with the attached package definition. Note, the
> offending code is at line 77, where I forgot to remove a docstring from a
> variable that used to be a procedure.

Here’s how I tried (and failed) to reproduce the segfault:

--8<---------------cut here---------------start------------->8---
$ find /tmp/test
/tmp/test
/tmp/test/gnu
/tmp/test/gnu/packages
/tmp/test/gnu/packages/jsoftware.scm

$ guix build -L /tmp/test jsoftware
/tmp/test/gnu/packages/jsoftware.scm:76:0: warning: source expression failed to 
match any pattern
guix build: error: jsoftware: nekonata pako

$ guix build -f /tmp/test/gnu/packages/jsoftware.scm 
/tmp/test/gnu/packages/jsoftware.scm:76:0: error: (define ijconsole "G-exp 
script that detects AVX/AVX2 support at runtime and executes jconsole\n  with 
the appropriate libj.so and profile.ijs." (with-imported-modules (quote ((guix 
cpu) (guix memoization) (guix profiling) (guix sets) (srfi srfi-26))) 
(program-file "ijconsole" (gexp (begin (use-modules ((guix cpu) #:select 
(cpu-flags current-cpu)) ((guix sets) #:select (set-contains?)) ((srfi srfi-26) 
#:select (cute))) (define %basedir (dirname (dirname (current-filename)))) 
(let* ((jconsole (string-append %basedir "/libexec/j/jconsole")) (cpu-has-flag? 
(cute set-contains? (cpu-flags (current-cpu)) <>)) (libj (format #f 
"~a/lib/j/libj~a.so" %basedir (cond ((cpu-has-flag? "avx2") "-avx2") 
((cpu-has-flag? "avx") "-avx") (else "")))) (jprofile (string-append %basedir 
"/etc/j/profile.ijs"))) (apply execl jconsole "ijconsole" "-lib" libj 
"-jprofile" jprofile (cdr (command-line))))))))): source expression failed to 
match any pattern

$ guix describe
Generacio 201   Jan 12 2022 23:15:13    (nuna)
  guix 0052c3b
    repository URL: https://git.savannah.gnu.org/git/guix.git
    branch: master
    commit: 0052c3b0458fba32920a1cfb48b8311429f0d6b5
--8<---------------cut here---------------end--------------->8---

Is there another way to reproduce it?

Is the ‘LD_LIBRARY_PATH’ variable set on your system?

Thanks,
Ludo’.





reply via email to

[Prev in Thread] Current Thread [Next in Thread]