Merge "Debian: support multi kernels in single image"

This commit is contained in:
Zuul 2022-05-31 13:46:02 +00:00 committed by Gerrit Code Review
commit c2c96ce2f0

View File

@ -19,6 +19,7 @@ import discovery
import getopt import getopt
import logging import logging
import os import os
import re
import repo_manage import repo_manage
import shutil import shutil
import subprocess import subprocess
@ -109,6 +110,53 @@ def update_ostree_osname(img_yaml):
return True return True
def change_default_kernel(img_yaml, ktype):
rt_kernel = std_kernel = None
try:
with open(img_yaml) as f:
yaml_doc = yaml.safe_load(f)
multi_kernels = yaml_doc["multiple-kernels"].split(" ")
default_kernel = yaml_doc["default-kernel"]
if len(multi_kernels) == 1:
return False
for kernel in multi_kernels:
if re.search("-rt-", kernel):
rt_kernel = kernel
else:
std_kernel = kernel
if ktype == "rt":
if re.search("-rt-", default_kernel):
return True
elif rt_kernel != None:
yaml_doc["default-kernel"] = rt_kernel
else:
logger.error(f"No rt kernel is found in {multiple-kernels}")
return False
elif ktype == "std":
if not re.search("-rt-", default_kernel):
return True
elif std_kernel != None:
yaml_doc["default-kernel"] = std_kernel
else:
logger.error(f"No std kernel is found in {multiple-kernels}")
return False
logger.debug(f'Set default kernel as {yaml_doc["default-kernel"]}')
try:
with open(img_yaml, 'w') as f:
yaml.safe_dump(yaml_doc, f, default_flow_style=False, sort_keys=False)
except IOError as e:
logger.error(str(e))
return False
except IOError as e:
logger.error(str(e))
return False
return True
def replace_in_yaml(dst_yaml, field, field_type, src_str, dst_str): def replace_in_yaml(dst_yaml, field, field_type, src_str, dst_str):
logger.debug("Start to replace %s in field %s of yaml %s", src_str, field, dst_yaml) logger.debug("Start to replace %s in field %s of yaml %s", src_str, field, dst_yaml)
@ -364,10 +412,10 @@ if __name__ == "__main__":
base_bins_ready = check_base_os_binaries(repo_manager) base_bins_ready = check_base_os_binaries(repo_manager)
logger.info("\nchecking STX binary packages ......") logger.info("\nchecking STX binary packages ......")
stx_bins_ready = check_stx_binaries(repo_manager, kernel_type) stx_bins_ready = check_stx_binaries(repo_manager, "std")
logger.info("\nchecking STX patched packages ......") logger.info("\nchecking STX patched packages ......")
stx_patched_ready = check_stx_patched(repo_manager, kernel_type) stx_patched_ready = check_stx_patched(repo_manager, "std")
if not base_bins_ready or not stx_bins_ready or not stx_patched_ready: if not base_bins_ready or not stx_bins_ready or not stx_patched_ready:
logger.error("Fail to get prepared to build image") logger.error("Fail to get prepared to build image")
@ -420,13 +468,9 @@ if __name__ == "__main__":
update_ostree_osname(lat_yaml) update_ostree_osname(lat_yaml)
if kernel_type == 'rt': if not change_default_kernel(lat_yaml, kernel_type):
if not update_rt_kernel_in_main_yaml(lat_yaml): logger.error("Failed to change the default boot kernel")
logger.error("Failed to update LAT yaml file for rt type") sys.exit(1)
sys.exit(1)
if not update_rt_kernel_in_initramfs_yaml(lat_initramfs_yaml):
logger.error("Failed to update LAT initramfs yaml file for rt type")
sys.exit(1)
if add_lat_packages(lat_yaml, img_pkgs): if add_lat_packages(lat_yaml, img_pkgs):
os.system(' '.join(['latc --file=' + lat_yaml, '-t', kernel_type, 'build'])) os.system(' '.join(['latc --file=' + lat_yaml, '-t', kernel_type, 'build']))