mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-27 13:09:23 -05:00
services: system-service-type: Add entries support for the Hurd.
When creating a disk-image using --save-provenance, "guix system describe" now works. * gnu/system.scm (operating-system-directory-base-entries): Add conditional "hurd" parameter, make "initrd" parameter conditional. (hurd-default-essential-services): Use them. (operating-system-boot-parameters-file): Only add 'initrd' when set.
This commit is contained in:
parent
12906d3e2a
commit
2b76179ecd
1 changed files with 41 additions and 30 deletions
|
@ -537,8 +537,11 @@ (define* (operating-system-directory-base-entries os)
|
|||
value of the SYSTEM-SERVICE-TYPE service."
|
||||
(let* ((locale (operating-system-locale-directory os))
|
||||
(kernel (operating-system-kernel os))
|
||||
(hurd (operating-system-hurd os))
|
||||
(modules (operating-system-kernel-loadable-modules os))
|
||||
(kernel (profile
|
||||
(kernel (if hurd
|
||||
kernel
|
||||
(profile
|
||||
(content (packages->manifest
|
||||
(cons kernel
|
||||
(map (lambda (module)
|
||||
|
@ -547,12 +550,13 @@ (define* (operating-system-directory-base-entries os)
|
|||
module)
|
||||
module))
|
||||
modules))))
|
||||
(hooks (list linux-module-database))))
|
||||
(initrd (operating-system-initrd-file os))
|
||||
(hooks (list linux-module-database)))))
|
||||
(initrd (and (not hurd) (operating-system-initrd-file os)))
|
||||
(params (operating-system-boot-parameters-file os)))
|
||||
`(("kernel" ,kernel)
|
||||
,@(if hurd `(("hurd" ,hurd)) '())
|
||||
("parameters" ,params)
|
||||
("initrd" ,initrd)
|
||||
,@(if initrd `(("initrd" ,initrd)) '())
|
||||
("locale" ,locale)))) ;used by libc
|
||||
|
||||
(define (operating-system-default-essential-services os)
|
||||
|
@ -604,7 +608,8 @@ (define known-fs
|
|||
(operating-system-firmware os)))))))
|
||||
|
||||
(define (hurd-default-essential-services os)
|
||||
(list (service system-service-type '())
|
||||
(let ((entries (operating-system-directory-base-entries os)))
|
||||
(list (service system-service-type entries)
|
||||
%boot-service
|
||||
%hurd-startup-service
|
||||
%activation-service
|
||||
|
@ -620,7 +625,7 @@ (define (hurd-default-essential-services os)
|
|||
(operating-system-file-systems os)))
|
||||
(pam-root-service (operating-system-pam-services os))
|
||||
(operating-system-etc-service os)
|
||||
(service profile-service-type (operating-system-packages os))))
|
||||
(service profile-service-type (operating-system-packages os)))))
|
||||
|
||||
(define* (operating-system-services os)
|
||||
"Return all the services of OS, including \"essential\" services."
|
||||
|
@ -1276,7 +1281,13 @@ (define* (operating-system-boot-parameters-file os
|
|||
(kernel #$(boot-parameters-kernel params))
|
||||
(kernel-arguments
|
||||
#$(boot-parameters-kernel-arguments params))
|
||||
(initrd #$(boot-parameters-initrd params))
|
||||
#$@(if (boot-parameters-initrd params)
|
||||
#~((initrd #$(boot-parameters-initrd params)))
|
||||
#~())
|
||||
#$@(if (pair? (boot-parameters-multiboot-modules params))
|
||||
#~((multiboot-modules
|
||||
#$(boot-parameters-multiboot-modules params)))
|
||||
#~())
|
||||
(bootloader-name #$(boot-parameters-bootloader-name params))
|
||||
(bootloader-menu-entries
|
||||
#$(map menu-entry->sexp
|
||||
|
|
Loading…
Reference in a new issue