X-Git-Url: https://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=lib%2Fpb-protocol%2Fpb-protocol.h;h=f4975bc85aa6cd729f34b39d0a8cd5c33a8a7608;hp=0390f6661fe55e73e5c0035749dea1528d67a5f4;hb=HEAD;hpb=6b87c9c7776796c766e3dcbdb32f5d292f7125d5 diff --git a/lib/pb-protocol/pb-protocol.h b/lib/pb-protocol/pb-protocol.h index 0390f66..f4975bc 100644 --- a/lib/pb-protocol/pb-protocol.h +++ b/lib/pb-protocol/pb-protocol.h @@ -18,6 +18,16 @@ enum pb_protocol_action { /* PB_PROTOCOL_ACTION_BOOT_OPTION_REMOVE = 0x4, */ PB_PROTOCOL_ACTION_BOOT = 0x5, PB_PROTOCOL_ACTION_STATUS = 0x6, + PB_PROTOCOL_ACTION_CANCEL_DEFAULT = 0x7, + PB_PROTOCOL_ACTION_SYSTEM_INFO = 0x8, + PB_PROTOCOL_ACTION_CONFIG = 0x9, + PB_PROTOCOL_ACTION_REINIT = 0xa, + PB_PROTOCOL_ACTION_ADD_URL = 0xb, + PB_PROTOCOL_ACTION_PLUGIN_OPTION_ADD = 0xc, + PB_PROTOCOL_ACTION_PLUGINS_REMOVE = 0xd, + PB_PROTOCOL_ACTION_PLUGIN_INSTALL = 0xe, + PB_PROTOCOL_ACTION_TEMP_AUTOBOOT = 0xf, + PB_PROTOCOL_ACTION_AUTHENTICATE = 0x10, }; struct pb_protocol_message { @@ -26,12 +36,41 @@ struct pb_protocol_message { char payload[]; }; +enum auth_msg_type { + AUTH_MSG_REQUEST, + AUTH_MSG_RESPONSE, + AUTH_MSG_SET, + AUTH_MSG_DECRYPT, +}; + +struct auth_message { + enum auth_msg_type op; + union { + bool authenticated; + char *password; + struct { + char *password; + char *new_password; + } set_password; + struct { + char *password; + char *device_id; + } decrypt_dev; + }; +}; + void pb_protocol_dump_device(const struct device *dev, const char *text, FILE *stream); int pb_protocol_device_len(const struct device *dev); int pb_protocol_boot_option_len(const struct boot_option *opt); int pb_protocol_boot_len(const struct boot_command *boot); -int pb_protocol_boot_status_len(const struct boot_status *status); +int pb_protocol_boot_status_len(const struct status *status); +int pb_protocol_system_info_len(const struct system_info *sysinfo); +int pb_protocol_config_len(const struct config *config); +int pb_protocol_url_len(const char *url); +int pb_protocol_plugin_option_len(const struct plugin_option *opt); +int pb_protocol_temp_autoboot_len(const struct autoboot_option *opt); +int pb_protocol_authenticate_len(struct auth_message *msg); int pb_protocol_device_cmp(const struct device *a, const struct device *b); int pb_protocol_boot_option_cmp(const struct boot_option *a, @@ -47,7 +86,18 @@ int pb_protocol_serialise_boot_option(const struct boot_option *opt, char *buf, int buf_len); int pb_protocol_serialise_boot_command(const struct boot_command *boot, char *buf, int buf_len); -int pb_protocol_serialise_boot_status(const struct boot_status *status, +int pb_protocol_serialise_boot_status(const struct status *status, + char *buf, int buf_len); +int pb_protocol_serialise_system_info(const struct system_info *sysinfo, + char *buf, int buf_len); +int pb_protocol_serialise_config(const struct config *config, + char *buf, int buf_len); +int pb_protocol_serialise_url(const char *url, char *buf, int buf_len); +int pb_protocol_serialise_plugin_option(const struct plugin_option *opt, + char *buf, int buf_len); +int pb_protocol_serialise_temp_autoboot(const struct autoboot_option *opt, + char *buf, int buf_len); +int pb_protocol_serialise_authenticate(struct auth_message *msg, char *buf, int buf_len); int pb_protocol_write_message(int fd, struct pb_protocol_message *message); @@ -66,7 +116,21 @@ int pb_protocol_deserialise_boot_option(struct boot_option *opt, int pb_protocol_deserialise_boot_command(struct boot_command *cmd, const struct pb_protocol_message *message); -int pb_protocol_deserialise_boot_status(struct boot_status *status, +int pb_protocol_deserialise_boot_status(struct status *status, const struct pb_protocol_message *message); +int pb_protocol_deserialise_system_info(struct system_info *sysinfo, + const struct pb_protocol_message *message); + +int pb_protocol_deserialise_config(struct config *config, + const struct pb_protocol_message *message); + +int pb_protocol_deserialise_plugin_option(struct plugin_option *opt, + const struct pb_protocol_message *message); + +int pb_protocol_deserialise_temp_autoboot(struct autoboot_option *opt, + const struct pb_protocol_message *message); + +int pb_protocol_deserialise_authenticate(struct auth_message *msg, + const struct pb_protocol_message *message); #endif /* _PB_PROTOCOL_H */