aboutsummaryrefslogtreecommitdiff
path: root/src/property/u-boot.lisp
blob: a39cb9eea11754549b8a8ba26eb2260d460fd0c1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
;;; Consfigurator -- Lisp declarative configuration management system

;;; Copyright (C) 2021-2022  Sean Whitton <spwhitton@spwhitton.name>

;;; This file is free software; you can redistribute it and/or modify
;;; it under the terms of the GNU General Public License as published by
;;; the Free Software Foundation; either version 3, or (at your option)
;;; any later version.

;;; This file is distributed in the hope that it will be useful,
;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
;;; GNU General Public License for more details.

;;; You should have received a copy of the GNU General Public License
;;; along with this program.  If not, see <http://www.gnu.org/licenses/>.

(in-package :consfigurator.property.u-boot)
(named-readtables:in-readtable :consfigurator)

;; Currently we have a distinct property for each (Debian-specific)
;; installation script.  Perhaps there is some sensible parameterisation of
;; these available instead.

(defmethod install-bootloader-propspec
    ((type (eql 'install-rockchip)) volume &rest args &key &allow-other-keys)
  `(installed-rockchip ,volume ,@args))

(defmethod install-bootloader-binaries-propspec
    ((type (eql 'install-rockchip)) volume &key &allow-other-keys)
  '(os:etypecase
       (debianlike
        (apt:installed "u-boot-rockchip"))))

(defprop installed-rockchip :posix (volume &key target)
  (:desc "Installed U-Boot using Debian scripts")
  (:hostattrs
   (os:required 'os:debianlike)
   (or (container:contained-p :physical-disks) target
       (inapplicable-property
        "Must specify TARGET for u-boot-install-rockchip(8) unless running on device.")))
  (:apply
   (let ((args (list "u-boot-install-rockchip" (device-file volume))))
     (if target
         (apply #'mrun :env `(:TARGET ,target) args)
         (apply #'mrun args)))))