diff options
author | Daniil Baturin <daniil@vyos.io> | 2024-01-23 19:10:20 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-01-23 19:10:20 +0000 |
commit | d736a9b70ca897bdf1e0237b64ab5c7eb958b520 (patch) | |
tree | eb4c7c191a126ecd6c4e9dec1da224c0b60b60fe /python/vyos/system/grub_util.py | |
parent | 4c2d4519277bc4cbe964a37160b93c31cdc77309 (diff) | |
parent | 256346a66cc3bb20e93c68245ebca2f68f42e7b5 (diff) | |
download | vyos-1x-d736a9b70ca897bdf1e0237b64ab5c7eb958b520.tar.gz vyos-1x-d736a9b70ca897bdf1e0237b64ab5c7eb958b520.zip |
Merge pull request #2886 from jestabro/add-kernel-boot-options
system-option: T5979: Add configurable kernel boot options
Diffstat (limited to 'python/vyos/system/grub_util.py')
-rw-r--r-- | python/vyos/system/grub_util.py | 30 |
1 files changed, 29 insertions, 1 deletions
diff --git a/python/vyos/system/grub_util.py b/python/vyos/system/grub_util.py index 9e79d41d4..4a3d8795e 100644 --- a/python/vyos/system/grub_util.py +++ b/python/vyos/system/grub_util.py @@ -13,7 +13,7 @@ # You should have received a copy of the GNU Lesser General Public License # along with this library. If not, see <http://www.gnu.org/licenses/>. -from vyos.system import disk, grub, compat +from vyos.system import disk, grub, image, compat @compat.grub_cfg_update def set_console_speed(console_speed: str, root_dir: str = '') -> None: @@ -29,6 +29,7 @@ def set_console_speed(console_speed: str, root_dir: str = '') -> None: grub.set_console_speed(console_speed, root_dir) +@image.if_not_live_boot def update_console_speed(console_speed: str, root_dir: str = '') -> None: """Update console_speed if different from current value""" @@ -40,3 +41,30 @@ def update_console_speed(console_speed: str, root_dir: str = '') -> None: console_speed_current = vars_current.get('console_speed', None) if console_speed != console_speed_current: set_console_speed(console_speed, root_dir) + +@compat.grub_cfg_update +def set_kernel_cmdline_options(cmdline_options: str, version: str = '', + root_dir: str = '') -> None: + """Write Kernel CLI cmdline options to GRUB configuration""" + if not root_dir: + root_dir = disk.find_persistence() + + if not version: + version = image.get_running_image() + + grub.set_kernel_cmdline_options(cmdline_options, version, root_dir) + +@image.if_not_live_boot +def update_kernel_cmdline_options(cmdline_options: str, + root_dir: str = '') -> None: + """Update Kernel custom cmdline options""" + if not root_dir: + root_dir = disk.find_persistence() + + version = image.get_running_image() + + boot_opts_current = grub.get_boot_opts(version, root_dir) + boot_opts_proposed = grub.BOOT_OPTS_STEM + f'{version} {cmdline_options}' + + if boot_opts_proposed != boot_opts_current: + set_kernel_cmdline_options(cmdline_options, version, root_dir) |