system: Install /var/guix/profiles/system-1-link on new systems.

* guix/build/install.scm (directives): Add /var/guix/profiles/system.
  (populate-root-file-system): Add 'system' parameter.  Create
  /var/guix/profiles/system-1-link.
* guix/scripts/system.scm (install): Pass OS-DIR to
  'populate-root-file-system'.
* guix/build/vm.scm (initialize-root-partition): Add #:system-directory
  parameter, and pass it to 'populate-root-file-system'.
  (initialize-hard-disk): Add #:system-directory parameter, and pass it
  to 'initialize-root-partition'.
* gnu/system/vm.scm (qemu-image): Add #:os-derivation parameter and pass
  it to 'initialize-hard-disk'.
  (system-disk-image, system-qemu-image,
  system-qemu-image/shared-store): Pass #:os-derivation to 'qemu-image.
This commit is contained in:
Ludovic Courtès 2014-06-27 17:54:29 +02:00
parent dff624230a
commit f2c403eab6
4 changed files with 30 additions and 13 deletions

View File

@ -197,6 +197,7 @@ made available under the /xchg CIFS share."
(disk-image-format "qcow2") (disk-image-format "qcow2")
(file-system-type "ext4") (file-system-type "ext4")
file-system-label file-system-label
os-derivation
grub-configuration grub-configuration
(register-closures? #t) (register-closures? #t)
(inputs '()) (inputs '())
@ -204,9 +205,9 @@ made available under the /xchg CIFS share."
"Return a bootable, stand-alone QEMU image of type DISK-IMAGE-FORMAT (e.g., "Return a bootable, stand-alone QEMU image of type DISK-IMAGE-FORMAT (e.g.,
'qcow2' or 'raw'), with a root partition of type FILE-SYSTEM-TYPE. 'qcow2' or 'raw'), with a root partition of type FILE-SYSTEM-TYPE.
Optionally, FILE-SYSTEM-LABEL can be specified as the volume name for the root Optionally, FILE-SYSTEM-LABEL can be specified as the volume name for the root
partition. The returned image is a full disk image, with a GRUB installation partition. The returned image is a full disk image that runs OS-DERIVATION,
that uses GRUB-CONFIGURATION as its configuration file (GRUB-CONFIGURATION with a GRUB installation that uses GRUB-CONFIGURATION as its configuration
must be the name of a file in the VM.) file (GRUB-CONFIGURATION must be the name of a file in the VM.)
INPUTS is a list of inputs (as for packages). When COPY-INPUTS? is true, copy INPUTS is a list of inputs (as for packages). When COPY-INPUTS? is true, copy
all of INPUTS into the image being built. When REGISTER-CLOSURES? is true, all of INPUTS into the image being built. When REGISTER-CLOSURES? is true,
@ -240,6 +241,7 @@ the image."
(((names . _) ...) (((names . _) ...)
names)))) names))))
(initialize-hard-disk "/dev/vda" (initialize-hard-disk "/dev/vda"
#:system-directory #$os-derivation
#:grub.cfg #$grub-configuration #:grub.cfg #$grub-configuration
#:closures graphs #:closures graphs
#:copy-closures? #$copy-inputs? #:copy-closures? #$copy-inputs?
@ -298,6 +300,7 @@ to USB sticks meant to be read-only."
(mlet* %store-monad ((os-drv (operating-system-derivation os)) (mlet* %store-monad ((os-drv (operating-system-derivation os))
(grub.cfg (operating-system-grub.cfg os))) (grub.cfg (operating-system-grub.cfg os)))
(qemu-image #:name name (qemu-image #:name name
#:os-derivation os-drv
#:grub-configuration grub.cfg #:grub-configuration grub.cfg
#:disk-image-size disk-image-size #:disk-image-size disk-image-size
#:disk-image-format "raw" #:disk-image-format "raw"
@ -334,7 +337,8 @@ of the GNU system as described by OS."
(mlet* %store-monad (mlet* %store-monad
((os-drv (operating-system-derivation os)) ((os-drv (operating-system-derivation os))
(grub.cfg (operating-system-grub.cfg os))) (grub.cfg (operating-system-grub.cfg os)))
(qemu-image #:grub-configuration grub.cfg (qemu-image #:os-derivation os-drv
#:grub-configuration grub.cfg
#:disk-image-size disk-image-size #:disk-image-size disk-image-size
#:file-system-type file-system-type #:file-system-type file-system-type
#:inputs `(("system" ,os-drv) #:inputs `(("system" ,os-drv)
@ -376,7 +380,8 @@ with the host."
(mlet* %store-monad (mlet* %store-monad
((os-drv (operating-system-derivation os)) ((os-drv (operating-system-derivation os))
(grub.cfg (operating-system-grub.cfg os))) (grub.cfg (operating-system-grub.cfg os)))
(qemu-image #:grub-configuration grub.cfg (qemu-image #:os-derivation os-drv
#:grub-configuration grub.cfg
#:disk-image-size disk-image-size #:disk-image-size disk-image-size
#:inputs `(("system" ,os-drv)) #:inputs `(("system" ,os-drv))

View File

@ -83,21 +83,30 @@ STORE."
(directory "/var/empty") ; for no-login accounts (directory "/var/empty") ; for no-login accounts
(directory "/var/run") (directory "/var/run")
(directory "/run") (directory "/run")
(directory "/var/guix/profiles/per-user/root" 0 0)
;; Link to the initial system generation.
("/var/guix/profiles/system" -> "system-1-link")
("/var/guix/gcroots/booted-system" -> "/run/booted-system") ("/var/guix/gcroots/booted-system" -> "/run/booted-system")
("/var/guix/gcroots/current-system" -> "/run/current-system") ("/var/guix/gcroots/current-system" -> "/run/current-system")
(directory "/bin") (directory "/bin")
("/bin/sh" -> "/run/current-system/profile/bin/bash") ("/bin/sh" -> "/run/current-system/profile/bin/bash")
(directory "/tmp" 0 0 #o1777) ; sticky bit (directory "/tmp" 0 0 #o1777) ; sticky bit
(directory "/var/guix/profiles/per-user/root" 0 0)
(directory "/root" 0 0) ; an exception (directory "/root" 0 0) ; an exception
(directory "/home" 0 0))) (directory "/home" 0 0)))
(define (populate-root-file-system target) (define (populate-root-file-system system target)
"Make the essential non-store files and directories on TARGET. This "Make the essential non-store files and directories on TARGET. This
includes /etc, /var, /run, /bin/sh, etc." includes /etc, /var, /run, /bin/sh, etc., and all the symlinks to SYSTEM."
(for-each (cut evaluate-populate-directive <> target) (for-each (cut evaluate-populate-directive <> target)
(directives (%store-directory)))) (directives (%store-directory)))
;; Add system generation 1.
(symlink system
(string-append target "/var/guix/profiles/system-1-link")))
(define (reset-timestamps directory) (define (reset-timestamps directory)
"Reset the timestamps of all the files under DIRECTORY, so that they appear "Reset the timestamps of all the files under DIRECTORY, so that they appear

View File

@ -172,7 +172,7 @@ volume name."
(define* (initialize-root-partition target-directory (define* (initialize-root-partition target-directory
#:key copy-closures? register-closures? #:key copy-closures? register-closures?
closures) closures system-directory)
"Initialize the root partition mounted at TARGET-DIRECTORY." "Initialize the root partition mounted at TARGET-DIRECTORY."
(define target-store (define target-store
(string-append target-directory (%store-directory))) (string-append target-directory (%store-directory)))
@ -203,10 +203,11 @@ volume name."
;; Add the non-store directories and files. ;; Add the non-store directories and files.
(display "populating...\n") (display "populating...\n")
(populate-root-file-system target-directory)) (populate-root-file-system system-directory target-directory))
(define* (initialize-hard-disk device (define* (initialize-hard-disk device
#:key #:key
system-directory
grub.cfg grub.cfg
disk-image-size disk-image-size
(file-system-type "ext4") (file-system-type "ext4")
@ -218,7 +219,8 @@ volume name."
partition with (optionally) FILE-SYSTEM-LABEL as its volume name, and with partition with (optionally) FILE-SYSTEM-LABEL as its volume name, and with
GRUB installed. If REGISTER-CLOSURES? is true, register all of CLOSURES is GRUB installed. If REGISTER-CLOSURES? is true, register all of CLOSURES is
the partition's store. If COPY-CLOSURES? is true, copy all of CLOSURES to the the partition's store. If COPY-CLOSURES? is true, copy all of CLOSURES to the
partition." partition. SYSTEM-DIRECTORY is the name of the directory of the 'system'
derivation."
(define target-directory (define target-directory
"/fs") "/fs")
@ -236,6 +238,7 @@ partition."
(mount partition target-directory file-system-type) (mount partition target-directory file-system-type)
(initialize-root-partition target-directory (initialize-root-partition target-directory
#:system-directory system-directory
#:copy-closures? copy-closures? #:copy-closures? copy-closures?
#:register-closures? register-closures? #:register-closures? register-closures?
#:closures closures) #:closures closures)

View File

@ -116,7 +116,7 @@ When GRUB? is true, install GRUB on DEVICE, using GRUB.CFG."
;; Create a bunch of additional files. ;; Create a bunch of additional files.
(format log-port "populating '~a'...~%" target) (format log-port "populating '~a'...~%" target)
(populate-root-file-system target) (populate-root-file-system os-dir target)
(when grub? (when grub?
(unless (false-if-exception (install-grub grub.cfg device target)) (unless (false-if-exception (install-grub grub.cfg device target))