adding new bootloader job
options are to use grub for BIOS, gummiboot for efi set extra mountpoint when efi is found
This commit is contained in:
parent
a58857baa6
commit
c1a1399958
8
src/modules/bootloader/bootloader.conf
Normal file
8
src/modules/bootloader/bootloader.conf
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
---
|
||||||
|
# Gummiboot configuration files settings, set preffered distribution name and amount of time before
|
||||||
|
# default selection boots
|
||||||
|
distribution: KaOS
|
||||||
|
|
||||||
|
timeout: 10
|
||||||
|
|
||||||
|
|
102
src/modules/bootloader/main.py
Normal file
102
src/modules/bootloader/main.py
Normal file
@ -0,0 +1,102 @@
|
|||||||
|
#!/usr/bin/env python3
|
||||||
|
# encoding: utf-8
|
||||||
|
# === This file is part of Calamares - <http://github.com/calamares> ===
|
||||||
|
#
|
||||||
|
# Copyright 2014, Aurélien Gâteau <agateau@kde.org>
|
||||||
|
# Copyright 2014, Anke Boersma <demm@kaosx.us>
|
||||||
|
# Copyright 2014, Daniel Hillenbrand <codeworkx@bbqlinux.org>
|
||||||
|
# Copyright 2014, Benjamin Vaudour <benjamin.vaudour@yahoo.fr>
|
||||||
|
#
|
||||||
|
# Calamares 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 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# Calamares 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 Calamares. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
import libcalamares
|
||||||
|
|
||||||
|
import os
|
||||||
|
import shutil
|
||||||
|
import subprocess
|
||||||
|
|
||||||
|
from libcalamares.utils import check_chroot_call
|
||||||
|
|
||||||
|
def detect_firmware_type():
|
||||||
|
# Check for EFI variables support
|
||||||
|
if(os.path.exists("/sys/firmware/efi/efivars")):
|
||||||
|
fw_type = 'efi'
|
||||||
|
else:
|
||||||
|
fw_type = 'bios'
|
||||||
|
|
||||||
|
libcalamares.globalstorage.insert("firmwareType", fw_type)
|
||||||
|
libcalamares.utils.debug("Firmware type: {!s}".format(fw_type))
|
||||||
|
|
||||||
|
def get_uuid():
|
||||||
|
root_mount_point = libcalamares.globalstorage.value("rootMountPoint")
|
||||||
|
print(root_mount_point)
|
||||||
|
partitions = libcalamares.globalstorage.value("partitions")
|
||||||
|
print(partitions)
|
||||||
|
for partition in partitions:
|
||||||
|
if partition["mountPoint"] == "/":
|
||||||
|
print(partition["uuid"])
|
||||||
|
return partition["uuid"]
|
||||||
|
return ""
|
||||||
|
|
||||||
|
def create_conf(uuid, conf_path):
|
||||||
|
distribution = libcalamares.job.configuration["distribution"]
|
||||||
|
lines = [
|
||||||
|
'## This is just an exmaple config file.\n',
|
||||||
|
'## Please edit the paths and kernel parameters according to your system.\n',
|
||||||
|
'\n',
|
||||||
|
'title %s GNU/Linux, with Linux core repo kernel\n' % distribution,
|
||||||
|
'linux /vmlinuz-linux\n',
|
||||||
|
'initrd /initramfs-linux.img\n',
|
||||||
|
'options root=UUID=%s quiet rw\n' % uuid,
|
||||||
|
]
|
||||||
|
|
||||||
|
with open(conf_path, 'w') as f:
|
||||||
|
for l in lines:
|
||||||
|
f.write(l)
|
||||||
|
f.close()
|
||||||
|
|
||||||
|
def create_loader(loader_path):
|
||||||
|
distribution = libcalamares.job.configuration["distribution"]
|
||||||
|
timeout = libcalamares.job.configuration["timeout"]
|
||||||
|
lines = [
|
||||||
|
'timeout %s\n' % timeout,
|
||||||
|
'default %s\n' % distribution,
|
||||||
|
]
|
||||||
|
|
||||||
|
with open(loader_path, 'w') as f:
|
||||||
|
for l in lines:
|
||||||
|
f.write(l)
|
||||||
|
f.close()
|
||||||
|
|
||||||
|
def install_grub(boot_loader, fw_type):
|
||||||
|
if fw_type == 'efi':
|
||||||
|
install_path = libcalamares.globalstorage.value( "rootMountPoint" )
|
||||||
|
uuid = get_uuid()
|
||||||
|
distribution = libcalamares.job.configuration["distribution"]
|
||||||
|
conf_path = os.path.join(install_path, "boot", "loader", "entries", "%s.conf" % distribution)
|
||||||
|
loader_path = os.path.join(install_path, "boot", "loader", "loader.conf")
|
||||||
|
subprocess.call(["gummiboot", "--path=%s/boot" % install_path, "install"])
|
||||||
|
create_conf(uuid, conf_path)
|
||||||
|
create_loader(loader_path)
|
||||||
|
else:
|
||||||
|
install_path = boot_loader["installPath"]
|
||||||
|
check_chroot_call(["grub-install", install_path])
|
||||||
|
check_chroot_call(["grub-mkconfig", "-o", "/boot/grub/grub.cfg"])
|
||||||
|
|
||||||
|
def run():
|
||||||
|
detect_firmware_type()
|
||||||
|
boot_loader = libcalamares.globalstorage.value("bootLoader")
|
||||||
|
fw_type = libcalamares.globalstorage.value("firmwareType")
|
||||||
|
install_grub(boot_loader, fw_type)
|
||||||
|
return None
|
5
src/modules/bootloader/module.desc
Normal file
5
src/modules/bootloader/module.desc
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
---
|
||||||
|
type: "job"
|
||||||
|
name: "bootloader"
|
||||||
|
interface: "python"
|
||||||
|
script: "main.py"
|
3
src/modules/bootloader/test.yaml
Normal file
3
src/modules/bootloader/test.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
rootMountPoint: /tmp/mount
|
||||||
|
bootLoader:
|
||||||
|
installPath: /dev/sdb
|
@ -48,6 +48,7 @@ def run():
|
|||||||
root_mount_point = tempfile.mkdtemp(prefix="calamares-root-")
|
root_mount_point = tempfile.mkdtemp(prefix="calamares-root-")
|
||||||
partitions = libcalamares.globalstorage.value("partitions")
|
partitions = libcalamares.globalstorage.value("partitions")
|
||||||
extra_mounts = libcalamares.job.configuration["extraMounts"]
|
extra_mounts = libcalamares.job.configuration["extraMounts"]
|
||||||
|
extra_mounts_efi = libcalamares.job.configuration["extraMountsEfi"]
|
||||||
|
|
||||||
# Sort by mount points to ensure / is mounted before the rest
|
# Sort by mount points to ensure / is mounted before the rest
|
||||||
partitions.sort(key=lambda x: x["mountPoint"])
|
partitions.sort(key=lambda x: x["mountPoint"])
|
||||||
@ -55,5 +56,8 @@ def run():
|
|||||||
|
|
||||||
mount_partitions(root_mount_point, extra_mounts)
|
mount_partitions(root_mount_point, extra_mounts)
|
||||||
|
|
||||||
|
if(os.path.exists("/sys/firmware/efi/efivars")):
|
||||||
|
mount_partitions(root_mount_point, extra_mounts_efi)
|
||||||
|
|
||||||
libcalamares.globalstorage.insert("rootMountPoint", root_mount_point)
|
libcalamares.globalstorage.insert("rootMountPoint", root_mount_point)
|
||||||
return None
|
return None
|
||||||
|
@ -9,3 +9,9 @@ extraMounts:
|
|||||||
- device: /dev
|
- device: /dev
|
||||||
mountPoint: /dev
|
mountPoint: /dev
|
||||||
options: bind
|
options: bind
|
||||||
|
|
||||||
|
extraMountsEfi:
|
||||||
|
- device: /sys/firmware/efi
|
||||||
|
mountPoint: /sys/firmware/efi
|
||||||
|
options: bind
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user