mirror of
https://git.savannah.gnu.org/git/guix.git
synced 2025-01-19 05:57:04 +01:00
system: Add udev rule for /dev/kvm.
* gnu/services/base.scm (kvm-udev-rule): New procedure. (udev-service): Use it, and add it to RULES. (guix-build-accounts): Add "kvm" to the 'supplementary-groups' field. * gnu/system/shadow.scm (%base-groups): Add "kvm".
This commit is contained in:
parent
6c1df0819c
commit
7f28bf9a43
2 changed files with 25 additions and 3 deletions
|
@ -418,7 +418,7 @@ (define* (guix-build-accounts count #:key
|
||||||
;; guix-daemon expects GROUP to be listed as a
|
;; guix-daemon expects GROUP to be listed as a
|
||||||
;; supplementary group too:
|
;; supplementary group too:
|
||||||
;; <http://lists.gnu.org/archive/html/bug-guix/2013-01/msg00239.html>.
|
;; <http://lists.gnu.org/archive/html/bug-guix/2013-01/msg00239.html>.
|
||||||
(supplementary-groups (list group))
|
(supplementary-groups (list group "kvm"))
|
||||||
|
|
||||||
(comment (format #f "Guix Build User ~2d" n))
|
(comment (format #f "Guix Build User ~2d" n))
|
||||||
(home-directory "/var/empty")
|
(home-directory "/var/empty")
|
||||||
|
@ -526,10 +526,31 @@ (define (rules-sub-directory directory)
|
||||||
(guix build utils))
|
(guix build utils))
|
||||||
#:local-build? #t))
|
#:local-build? #t))
|
||||||
|
|
||||||
|
(define* (kvm-udev-rule)
|
||||||
|
"Return a directory with a udev rule that changes the group of
|
||||||
|
@file{/dev/kvm} to \"kvm\" and makes it #o660."
|
||||||
|
;; Apparently QEMU-KVM used to ship this rule, but now we have to add it by
|
||||||
|
;; ourselves.
|
||||||
|
(gexp->derivation "kvm-udev-rules"
|
||||||
|
#~(begin
|
||||||
|
(use-modules (guix build utils))
|
||||||
|
|
||||||
|
(define rules.d
|
||||||
|
(string-append #$output "/lib/udev/rules.d"))
|
||||||
|
|
||||||
|
(mkdir-p rules.d)
|
||||||
|
(call-with-output-file
|
||||||
|
(string-append rules.d "/90-kvm.rules")
|
||||||
|
(lambda (port)
|
||||||
|
(display "\
|
||||||
|
KERNEL==\"kvm\", GROUP=\"kvm\", MODE=\"0660\"\n" port))))
|
||||||
|
#:modules '((guix build utils))))
|
||||||
|
|
||||||
(define* (udev-service #:key (udev eudev) (rules '()))
|
(define* (udev-service #:key (udev eudev) (rules '()))
|
||||||
"Run @var{udev}, which populates the @file{/dev} directory dynamically. Get
|
"Run @var{udev}, which populates the @file{/dev} directory dynamically. Get
|
||||||
extra rules from the packages listed in @var{rules}."
|
extra rules from the packages listed in @var{rules}."
|
||||||
(mlet* %store-monad ((rules (udev-rules-union (cons udev rules)))
|
(mlet* %store-monad ((kvm (kvm-udev-rule))
|
||||||
|
(rules (udev-rules-union (cons* udev kvm rules)))
|
||||||
(udev.conf (text-file* "udev.conf"
|
(udev.conf (text-file* "udev.conf"
|
||||||
"udev_rules=\"" rules
|
"udev_rules=\"" rules
|
||||||
"/lib/udev/rules.d\"\n")))
|
"/lib/udev/rules.d\"\n")))
|
||||||
|
|
|
@ -103,7 +103,8 @@ (define %base-groups
|
||||||
(system-group (name "disk"))
|
(system-group (name "disk"))
|
||||||
(system-group (name "floppy"))
|
(system-group (name "floppy"))
|
||||||
(system-group (name "cdrom"))
|
(system-group (name "cdrom"))
|
||||||
(system-group (name "tape")))))
|
(system-group (name "tape"))
|
||||||
|
(system-group (name "kvm"))))) ; for /dev/kvm
|
||||||
|
|
||||||
(define (default-skeletons)
|
(define (default-skeletons)
|
||||||
"Return the default skeleton files for /etc/skel. These files are copied by
|
"Return the default skeleton files for /etc/skel. These files are copied by
|
||||||
|
|
Loading…
Reference in a new issue