diff options
author | Maxim Cournoyer <maxim.cournoyer@gmail.com> | 2023-10-04 23:09:58 -0400 |
---|---|---|
committer | Maxim Cournoyer <maxim.cournoyer@gmail.com> | 2023-10-04 23:30:42 -0400 |
commit | 22d2f94eb23739280ad14aa49e18233c5d917c7e (patch) | |
tree | a289576f9a7e7f70de34a33958274bd3924c7596 /gnu | |
parent | 2d8aa104aaf9a2e229e31d13f6cdabf57a2e2e9a (diff) | |
download | guix-22d2f94eb23739280ad14aa49e18233c5d917c7e.tar.gz guix-22d2f94eb23739280ad14aa49e18233c5d917c7e.zip |
gnu: phoronix-test-suite: Do not propagate gcc-toolchain.
* gnu/packages/benchmark.scm (gcc-toolchain*): Replace gcc-toolchain-12
reference with gcc-toolchain.
* gnu/packages/benchmark.scm (phoronix-test-suite): Augment wrap-binary phase
with GCC variables.
[propagated-inputs]: Delete field, moving gcc-toolchain to...
[inputs]: ... here.
[search-paths]: New field.
Diffstat (limited to 'gnu')
-rw-r--r-- | gnu/packages/benchmark.scm | 37 |
1 files changed, 26 insertions, 11 deletions
diff --git a/gnu/packages/benchmark.scm b/gnu/packages/benchmark.scm index a1ffec7810..4d92457e59 100644 --- a/gnu/packages/benchmark.scm +++ b/gnu/packages/benchmark.scm @@ -34,6 +34,7 @@ #:use-module (guix download) #:use-module (guix gexp) #:use-module (guix git-download) + #:use-module (guix search-paths) #:use-module (guix build-system cmake) #:use-module (guix build-system gnu) #:use-module (guix build-system python) @@ -70,11 +71,10 @@ #:use-module (gnu packages xml) #:use-module (ice-9 match)) -;; Lazily resolve the gcc-toolchain to avoid a circular dependency. Always -;; use the latest available toolchain to avoid conflicts in user profiles. +;; Lazily resolve the gcc-toolchain to avoid a circular dependency. (define gcc-toolchain* (delay (module-ref (resolve-interface '(gnu packages commencement)) - 'gcc-toolchain-12))) + 'gcc-toolchain))) (define-public fio (package @@ -351,24 +351,39 @@ file metadata operations that can be performed per second.") (invoke "./install-sh" #$output "--free-software-only"))) (add-after 'install 'wrap-binary (lambda* (#:key inputs #:allow-other-keys) - (let ((pts (string-append #$output "/bin/phoronix-test-suite"))) + (let ((pts (string-append #$output "/bin/phoronix-test-suite")) + (gcc #$(this-package-input "gcc-toolchain"))) (wrap-program pts (list "PATH" 'prefix (map (lambda (binary) (dirname (search-input-file inputs (string-append "bin/" binary)))) '("bash" "cat" ;coreutils - "gzip" "make" "php" "sed" "tar" "which")))))))))) + "gcc" + "gzip" "make" "php" "sed" "tar" "which"))) + ;; Wrap the GCC compiler paths. + (list "C_INCLUDE_PATH" 'prefix + (list (string-append gcc "/include"))) + (list "CPLUS_INCLUDE_PATH" 'prefix + (list (string-append gcc "/include/c++") + (string-append gcc "/include"))) + (list "LIBRARY_PATH" 'prefix + (list (string-append gcc "/lib")))))))))) (build-system gnu-build-system) (native-inputs (list python which)) ;; Wrap the most basic build tools needed by Phoronix Test Suite to build ;; simple tests such as 'fio'. - (inputs (list bash coreutils gnu-make gzip php sed tar which)) - ;; Phoronix Test Suite builds and caches the benchmarking tools itself; - ;; the user is required to manually install extra libraries depending on - ;; the selected test; but at least a working C/C++ toolchain is assumed to - ;; be available. - (propagated-inputs (list (force gcc-toolchain*))) + (inputs + (list bash + coreutils + (force gcc-toolchain*) + gnu-make + gzip + php + sed + tar + which)) + (native-search-paths %gcc-search-paths) (home-page "https://www.phoronix-test-suite.com/") (synopsis "Automated testing/benchmarking software") (description |