vm: 'expression->derivation-in-linux-vm' code can now use dlopen.
* gnu/system/vm.scm (expression->derivation-in-linux-vm) [user-builder]: Define in non-monadic style as 'program-file'. [loader]: Likewise, and 'execl' USER-BUILDER instead of loading it. (system-docker-image): Pass BUILD as the second argument to 'expression->derivation-in-linux-vm'. (make-iso9660-image, qemu-image): Remove call to 'reboot'.
This commit is contained in:
parent
49c393ccaa
commit
be43c08b17
@ -151,12 +151,24 @@ based on the size of the closure of REFERENCES-GRAPHS.
|
|||||||
When REFERENCES-GRAPHS is true, it must be a list of file name/store path
|
When REFERENCES-GRAPHS is true, it must be a list of file name/store path
|
||||||
pairs, as for `derivation'. The files containing the reference graphs are
|
pairs, as for `derivation'. The files containing the reference graphs are
|
||||||
made available under the /xchg CIFS share."
|
made available under the /xchg CIFS share."
|
||||||
|
(define user-builder
|
||||||
|
(program-file "builder-in-linux-vm" exp))
|
||||||
|
|
||||||
|
(define loader
|
||||||
|
;; Invoke USER-BUILDER instead using 'primitive-load'. The reason for
|
||||||
|
;; this is to allow USER-BUILDER to dlopen stuff by using a full-featured
|
||||||
|
;; Guile, which it couldn't do using the statically-linked guile used in
|
||||||
|
;; the initrd. See example at
|
||||||
|
;; <https://lists.gnu.org/archive/html/guix-devel/2017-10/msg00233.html>.
|
||||||
|
(program-file "linux-vm-loader"
|
||||||
|
;; When USER-BUILDER succeeds, reboot (indicating a
|
||||||
|
;; success), otherwise die, which causes a kernel panic
|
||||||
|
;; ("Attempted to kill init!").
|
||||||
|
#~(when (zero? (system* #$user-builder))
|
||||||
|
(reboot))))
|
||||||
|
|
||||||
(mlet* %store-monad
|
(mlet* %store-monad
|
||||||
((user-builder (gexp->file "builder-in-linux-vm" exp))
|
((initrd (if initrd ; use the default initrd?
|
||||||
(loader (gexp->file "linux-vm-loader"
|
|
||||||
#~(primitive-load #$user-builder)))
|
|
||||||
(coreutils -> (canonical-package coreutils))
|
|
||||||
(initrd (if initrd ; use the default initrd?
|
|
||||||
(return initrd)
|
(return initrd)
|
||||||
(base-initrd file-systems
|
(base-initrd file-systems
|
||||||
#:on-error 'backtrace
|
#:on-error 'backtrace
|
||||||
@ -257,8 +269,7 @@ INPUTS is a list of inputs (as for packages)."
|
|||||||
#:closures graphs
|
#:closures graphs
|
||||||
#:volume-id #$file-system-label
|
#:volume-id #$file-system-label
|
||||||
#:volume-uuid #$(and=> file-system-uuid
|
#:volume-uuid #$(and=> file-system-uuid
|
||||||
uuid-bytevector))
|
uuid-bytevector)))))
|
||||||
(reboot))))
|
|
||||||
#:system system
|
#:system system
|
||||||
|
|
||||||
;; Keep a local file system for /tmp so that we can populate it directly as
|
;; Keep a local file system for /tmp so that we can populate it directly as
|
||||||
@ -384,8 +395,7 @@ the image."
|
|||||||
#:bootcfg-location
|
#:bootcfg-location
|
||||||
#$(bootloader-configuration-file bootloader)
|
#$(bootloader-configuration-file bootloader)
|
||||||
#:bootloader-installer
|
#:bootloader-installer
|
||||||
#$(bootloader-installer bootloader))
|
#$(bootloader-installer bootloader))))))
|
||||||
(reboot)))))
|
|
||||||
#:system system
|
#:system system
|
||||||
#:make-disk-image? #t
|
#:make-disk-image? #t
|
||||||
#:disk-image-size disk-image-size
|
#:disk-image-size disk-image-size
|
||||||
@ -475,20 +485,7 @@ should set REGISTER-CLOSURES? to #f."
|
|||||||
#:creation-time (make-time time-utc 0 1)
|
#:creation-time (make-time time-utc 0 1)
|
||||||
#:transformations `((,root-directory -> ""))))))))
|
#:transformations `((,root-directory -> ""))))))))
|
||||||
(expression->derivation-in-linux-vm
|
(expression->derivation-in-linux-vm
|
||||||
name
|
name build
|
||||||
;; The VM's initrd Guile doesn't support dlopen, but our "build" gexp
|
|
||||||
;; needs to be run by a Guile that can dlopen libgcrypt. The following
|
|
||||||
;; hack works around that problem by putting the "build" gexp into an
|
|
||||||
;; executable script (created by program-file) which, when executed, will
|
|
||||||
;; run using a Guile that supports dlopen. That way, the VM's initrd
|
|
||||||
;; Guile can just execute it via invoke, without using dlopen. See:
|
|
||||||
;; https://lists.gnu.org/archive/html/guix-devel/2017-10/msg00233.html
|
|
||||||
(with-imported-modules `((guix build utils))
|
|
||||||
#~(begin
|
|
||||||
(use-modules (guix build utils))
|
|
||||||
;; If we use execl instead of invoke here, the VM will crash with a
|
|
||||||
;; kernel panic.
|
|
||||||
(invoke #$(program-file "build-docker-image" build))))
|
|
||||||
#:make-disk-image? #f
|
#:make-disk-image? #f
|
||||||
#:single-file-output? #t
|
#:single-file-output? #t
|
||||||
#:references-graphs `((,graph ,os-drv)))))
|
#:references-graphs `((,graph ,os-drv)))))
|
||||||
|
Loading…
Reference in New Issue
Block a user