mirror of
https://github.com/morgan9e/systemd
synced 2026-04-15 17:06:39 +09:00
For now, just super basic functionality: return the list of boot menu entries, and read/write the reboot to firmware flag
60 lines
2.9 KiB
C
60 lines
2.9 KiB
C
/* SPDX-License-Identifier: LGPL-2.1-or-later */
|
|
|
|
#include "varlink-io.systemd.BootControl.h"
|
|
|
|
static VARLINK_DEFINE_ENUM_TYPE(
|
|
BootEntryType,
|
|
VARLINK_DEFINE_ENUM_VALUE(type1),
|
|
VARLINK_DEFINE_ENUM_VALUE(type2),
|
|
VARLINK_DEFINE_ENUM_VALUE(loader),
|
|
VARLINK_DEFINE_ENUM_VALUE(auto));
|
|
|
|
static VARLINK_DEFINE_STRUCT_TYPE(
|
|
BootEntry,
|
|
VARLINK_DEFINE_FIELD_BY_TYPE(type, BootEntryType, 0),
|
|
VARLINK_DEFINE_FIELD(id, VARLINK_STRING, VARLINK_NULLABLE),
|
|
VARLINK_DEFINE_FIELD(path, VARLINK_STRING, VARLINK_NULLABLE),
|
|
VARLINK_DEFINE_FIELD(root, VARLINK_STRING, VARLINK_NULLABLE),
|
|
VARLINK_DEFINE_FIELD(title, VARLINK_STRING, VARLINK_NULLABLE),
|
|
VARLINK_DEFINE_FIELD(showTitle, VARLINK_STRING, VARLINK_NULLABLE),
|
|
VARLINK_DEFINE_FIELD(sortKey, VARLINK_STRING, VARLINK_NULLABLE),
|
|
VARLINK_DEFINE_FIELD(version, VARLINK_STRING, VARLINK_NULLABLE),
|
|
VARLINK_DEFINE_FIELD(machineId, VARLINK_STRING, VARLINK_NULLABLE),
|
|
VARLINK_DEFINE_FIELD(architecture, VARLINK_STRING, VARLINK_NULLABLE),
|
|
VARLINK_DEFINE_FIELD(options, VARLINK_STRING, VARLINK_NULLABLE),
|
|
VARLINK_DEFINE_FIELD(linux, VARLINK_STRING, VARLINK_NULLABLE),
|
|
VARLINK_DEFINE_FIELD(efi, VARLINK_STRING, VARLINK_NULLABLE),
|
|
VARLINK_DEFINE_FIELD(initrd, VARLINK_STRING, VARLINK_NULLABLE|VARLINK_ARRAY),
|
|
VARLINK_DEFINE_FIELD(devicetree, VARLINK_STRING, VARLINK_NULLABLE),
|
|
VARLINK_DEFINE_FIELD(devicetreeOverlay, VARLINK_STRING, VARLINK_NULLABLE|VARLINK_ARRAY),
|
|
VARLINK_DEFINE_FIELD(isReported, VARLINK_BOOL, 0),
|
|
VARLINK_DEFINE_FIELD(triesLeft, VARLINK_INT, VARLINK_NULLABLE),
|
|
VARLINK_DEFINE_FIELD(triesDone, VARLINK_INT, VARLINK_NULLABLE),
|
|
VARLINK_DEFINE_FIELD(isDefault, VARLINK_BOOL, VARLINK_NULLABLE),
|
|
VARLINK_DEFINE_FIELD(isSelected, VARLINK_BOOL, VARLINK_NULLABLE));
|
|
|
|
static VARLINK_DEFINE_METHOD(
|
|
ListBootEntries,
|
|
VARLINK_DEFINE_OUTPUT_BY_TYPE(entry, BootEntry, VARLINK_NULLABLE));
|
|
|
|
static VARLINK_DEFINE_METHOD(
|
|
SetRebootToFirmware,
|
|
VARLINK_DEFINE_INPUT(state, VARLINK_BOOL, 0));
|
|
|
|
static VARLINK_DEFINE_METHOD(
|
|
GetRebootToFirmware,
|
|
VARLINK_DEFINE_OUTPUT(state, VARLINK_BOOL, 0));
|
|
|
|
static VARLINK_DEFINE_ERROR(
|
|
RebootToFirmwareNotSupported);
|
|
|
|
VARLINK_DEFINE_INTERFACE(
|
|
io_systemd_BootControl,
|
|
"io.systemd.BootControl",
|
|
&vl_type_BootEntryType,
|
|
&vl_type_BootEntry,
|
|
&vl_method_ListBootEntries,
|
|
&vl_method_SetRebootToFirmware,
|
|
&vl_method_GetRebootToFirmware,
|
|
&vl_error_RebootToFirmwareNotSupported);
|