mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-13 06:36:37 -05:00
file-systems: Always use (guix build syscalls).
* gnu/build/file-systems.scm: Use (guix build syscalls) unconditionally. Override the 'mount' and 'umount' bindings when (guile) provides them. (MS_RDONLY, MS_NOSUID, MS_NODEV, MS_NOEXEC, MS_REMOUNT) (MS_BIND, MS_MOVE): Remove. * guix/build/syscalls.scm (%libc-errno-pointer): Add 'false-if-exception' around 'dynamic-func'.
This commit is contained in:
parent
14d5ca2e2e
commit
2ff0da0257
2 changed files with 14 additions and 23 deletions
|
@ -19,6 +19,7 @@
|
||||||
(define-module (gnu build file-systems)
|
(define-module (gnu build file-systems)
|
||||||
#:use-module (guix build utils)
|
#:use-module (guix build utils)
|
||||||
#:use-module (guix build bournish)
|
#:use-module (guix build bournish)
|
||||||
|
#:use-module (guix build syscalls)
|
||||||
#:use-module (rnrs io ports)
|
#:use-module (rnrs io ports)
|
||||||
#:use-module (rnrs bytevectors)
|
#:use-module (rnrs bytevectors)
|
||||||
#:use-module (ice-9 match)
|
#:use-module (ice-9 match)
|
||||||
|
@ -41,17 +42,16 @@ (define-module (gnu build file-systems)
|
||||||
uuid->string
|
uuid->string
|
||||||
string->uuid
|
string->uuid
|
||||||
|
|
||||||
MS_RDONLY
|
|
||||||
MS_NOSUID
|
|
||||||
MS_NODEV
|
|
||||||
MS_NOEXEC
|
|
||||||
MS_BIND
|
|
||||||
MS_MOVE
|
|
||||||
bind-mount
|
bind-mount
|
||||||
|
|
||||||
mount-flags->bit-mask
|
mount-flags->bit-mask
|
||||||
check-file-system
|
check-file-system
|
||||||
mount-file-system))
|
mount-file-system)
|
||||||
|
#:re-export (mount
|
||||||
|
umount
|
||||||
|
MS_BIND
|
||||||
|
MS_MOVE
|
||||||
|
MS_RDONLY))
|
||||||
|
|
||||||
;;; Commentary:
|
;;; Commentary:
|
||||||
;;;
|
;;;
|
||||||
|
@ -61,21 +61,11 @@ (define-module (gnu build file-systems)
|
||||||
;;; Code:
|
;;; Code:
|
||||||
|
|
||||||
;; 'mount' is already defined in the statically linked Guile used for initial
|
;; 'mount' is already defined in the statically linked Guile used for initial
|
||||||
;; RAM disks, but in all other cases the (guix build syscalls) module contains
|
;; RAM disks, in which case the bindings in (guix build syscalls) do not work
|
||||||
;; the mount binding.
|
;; (the FFI bindings do not work there). Override them in that case.
|
||||||
(eval-when (expand load eval)
|
(when (module-defined? the-scm-module 'mount)
|
||||||
(unless (defined? 'mount)
|
(set! mount (@ (guile) mount))
|
||||||
(module-use! (current-module)
|
(set! umount (@ (guile) umount)))
|
||||||
(resolve-interface '(guix build syscalls)))))
|
|
||||||
|
|
||||||
;; Linux mount flags, from libc's <sys/mount.h>.
|
|
||||||
(define MS_RDONLY 1)
|
|
||||||
(define MS_NOSUID 2)
|
|
||||||
(define MS_NODEV 4)
|
|
||||||
(define MS_NOEXEC 8)
|
|
||||||
(define MS_REMOUNT 32)
|
|
||||||
(define MS_BIND 4096)
|
|
||||||
(define MS_MOVE 8192)
|
|
||||||
|
|
||||||
(define (bind-mount source target)
|
(define (bind-mount source target)
|
||||||
"Bind-mount SOURCE at TARGET."
|
"Bind-mount SOURCE at TARGET."
|
||||||
|
|
|
@ -283,7 +283,8 @@ (define* (read bv #:optional (offset 0))
|
||||||
|
|
||||||
(define %libc-errno-pointer
|
(define %libc-errno-pointer
|
||||||
;; Glibc's 'errno' pointer.
|
;; Glibc's 'errno' pointer.
|
||||||
(let ((errno-loc (dynamic-func "__errno_location" (dynamic-link))))
|
(let ((errno-loc (false-if-exception
|
||||||
|
(dynamic-func "__errno_location" (dynamic-link)))))
|
||||||
(and errno-loc
|
(and errno-loc
|
||||||
(let ((proc (pointer->procedure '* errno-loc '())))
|
(let ((proc (pointer->procedure '* errno-loc '())))
|
||||||
(proc)))))
|
(proc)))))
|
||||||
|
|
Loading…
Reference in a new issue