mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-11 21:59:08 -05:00
image: Support generating GPT images via partition-table-type
.
* gnu/image.scm (<image>)[partition-table-type]: New field. * gnu/system/image.scm: Implement partition-table-type logic for genimage. Signed-off-by: Mathieu Othacehe <othacehe@gnu.org>
This commit is contained in:
parent
39754503e8
commit
096a2bf8c5
2 changed files with 47 additions and 17 deletions
|
@ -38,6 +38,7 @@ (define-module (gnu image)
|
||||||
image-platform
|
image-platform
|
||||||
image-size
|
image-size
|
||||||
image-operating-system
|
image-operating-system
|
||||||
|
image-partition-table-type
|
||||||
image-partitions
|
image-partitions
|
||||||
image-compression?
|
image-compression?
|
||||||
image-volatile-root?
|
image-volatile-root?
|
||||||
|
@ -86,6 +87,8 @@ (define-record-type* <image>
|
||||||
(default 'guess))
|
(default 'guess))
|
||||||
(operating-system image-operating-system ;<operating-system>
|
(operating-system image-operating-system ;<operating-system>
|
||||||
(default #f))
|
(default #f))
|
||||||
|
(partition-table-type image-partition-table-type ; 'mbr or 'gpt
|
||||||
|
(default 'mbr))
|
||||||
(partitions image-partitions ;list of <partition>
|
(partitions image-partitions ;list of <partition>
|
||||||
(default '()))
|
(default '()))
|
||||||
(compression? image-compression? ;boolean
|
(compression? image-compression? ;boolean
|
||||||
|
|
|
@ -298,6 +298,14 @@ (define (partition->dos-type partition)
|
||||||
((member 'esp flags) "0xEF")
|
((member 'esp flags) "0xEF")
|
||||||
(else "0x83"))))
|
(else "0x83"))))
|
||||||
|
|
||||||
|
(define (partition->gpt-type partition)
|
||||||
|
;; Return the genimage GPT partition type code corresponding to PARTITION.
|
||||||
|
;; See https://github.com/pengutronix/genimage/blob/master/README.rst
|
||||||
|
(let ((flags (partition-flags partition)))
|
||||||
|
(cond
|
||||||
|
((member 'esp flags) "U")
|
||||||
|
(else "L"))))
|
||||||
|
|
||||||
(define (partition-image partition)
|
(define (partition-image partition)
|
||||||
;; Return as a file-like object, an image of the given PARTITION. A
|
;; Return as a file-like object, an image of the given PARTITION. A
|
||||||
;; directory, filled by calling the PARTITION initializer procedure, is
|
;; directory, filled by calling the PARTITION initializer procedure, is
|
||||||
|
@ -347,26 +355,44 @@ (define (partition-image partition)
|
||||||
#:local-build? #f
|
#:local-build? #f
|
||||||
#:options `(#:references-graphs ,inputs))))
|
#:options `(#:references-graphs ,inputs))))
|
||||||
|
|
||||||
(define (partition->config partition)
|
(define (gpt-image? image)
|
||||||
|
(eq? 'gpt (image-partition-table-type image)))
|
||||||
|
|
||||||
|
(define (partition-type-values image partition)
|
||||||
|
(if (gpt-image? image)
|
||||||
|
(values "partition-type-uuid" (partition->gpt-type partition))
|
||||||
|
(values "partition-type" (partition->dos-type partition))))
|
||||||
|
|
||||||
|
(define (partition->config image partition)
|
||||||
;; Return the genimage partition configuration for PARTITION.
|
;; Return the genimage partition configuration for PARTITION.
|
||||||
(let ((label (partition-label partition))
|
(let-values (((partition-type-attribute partition-type-value)
|
||||||
(dos-type (partition->dos-type partition))
|
(partition-type-values image partition)))
|
||||||
(image (partition-image partition))
|
(let ((label (partition-label partition))
|
||||||
(offset (partition-offset partition)))
|
(image (partition-image partition))
|
||||||
#~(format #f "~/partition ~a {
|
(offset (partition-offset partition)))
|
||||||
~/~/partition-type = ~a
|
#~(format #f "~/partition ~a {
|
||||||
~/~/image = \"~a\"
|
~/~/~a = ~a
|
||||||
~/~/offset = \"~a\"
|
~/~/image = \"~a\"
|
||||||
~/}"
|
~/~/offset = \"~a\"
|
||||||
#$label
|
~/}"
|
||||||
#$dos-type
|
#$label
|
||||||
#$image
|
#$partition-type-attribute
|
||||||
#$offset)))
|
#$partition-type-value
|
||||||
|
#$image
|
||||||
|
#$offset))))
|
||||||
|
|
||||||
|
(define (genimage-type-options image-type image)
|
||||||
|
(cond
|
||||||
|
((equal? image-type "hdimage")
|
||||||
|
(format #f "~%~/~/gpt = ~a~%~/"
|
||||||
|
(if (gpt-image? image) "true" "false")))
|
||||||
|
(else "")))
|
||||||
|
|
||||||
(let* ((format (image-format image))
|
(let* ((format (image-format image))
|
||||||
(image-type (format->image-type format))
|
(image-type (format->image-type format))
|
||||||
|
(image-type-options (genimage-type-options image-type image))
|
||||||
(partitions (image-partitions image))
|
(partitions (image-partitions image))
|
||||||
(partitions-config (map partition->config partitions))
|
(partitions-config (map (cut partition->config image <>) partitions))
|
||||||
(builder
|
(builder
|
||||||
#~(begin
|
#~(begin
|
||||||
(let ((format (@ (ice-9 format) format)))
|
(let ((format (@ (ice-9 format) format)))
|
||||||
|
@ -375,9 +401,10 @@ (define (partition->config partition)
|
||||||
(format port
|
(format port
|
||||||
"\
|
"\
|
||||||
image ~a {
|
image ~a {
|
||||||
~/~a {}
|
~/~a {~a}
|
||||||
~{~a~^~%~}
|
~{~a~^~%~}
|
||||||
}~%" #$genimage-name #$image-type (list #$@partitions-config))))))))
|
}~%" #$genimage-name #$image-type #$image-type-options
|
||||||
|
(list #$@partitions-config))))))))
|
||||||
(computed-file "genimage.cfg" builder)))
|
(computed-file "genimage.cfg" builder)))
|
||||||
|
|
||||||
(let* ((image-name (image-name image))
|
(let* ((image-name (image-name image))
|
||||||
|
|
Loading…
Reference in a new issue