[PATCH 1/4] lib: Add system config option to enable kexec_file_load

Samuel Mendoza-Jonas sam at mendozajonas.com
Fri Mar 24 13:28:54 AEDT 2017


On Thu, 2017-03-23 at 11:46 -0500, Eric Richter wrote:
> Currently, pb-discover only supports one method (syscall) for loading the
> next kernel for kexec: kexec_load. This patch adds a system configuration
> option for toggling between using kexec_load (false), and
> kexec_file_load (true).
> 
> This will be used in subsequent patches for determining the argument to
> kexec-lite/kexec-tools, and modified by a menu option.
> 
> Signed-off-by: Eric Richter <erichte at linux.vnet.ibm.com>
> ---
>  lib/pb-protocol/pb-protocol.c | 9 +++++++++
>  lib/types/types.h             | 2 ++
>  2 files changed, 11 insertions(+)
> 
> diff --git a/lib/pb-protocol/pb-protocol.c b/lib/pb-protocol/pb-protocol.c
> index 18edf57..a20bba9 100644
> --- a/lib/pb-protocol/pb-protocol.c
> +++ b/lib/pb-protocol/pb-protocol.c
> @@ -322,6 +322,8 @@ int pb_protocol_config_len(const struct config *config)
>  
>  	len += 4; /* allow_writes */
>  
> +	len += 4; /* kexec_method */
> +
>  	len += 4; /* n_consoles */
>  	for (i = 0; i < config->n_consoles; i++)
>  		len += 4 + optional_strlen(config->consoles[i]);
> @@ -582,6 +584,9 @@ int pb_protocol_serialise_config(const struct config *config,
>  	*(uint32_t *)pos = config->allow_writes;
>  	pos += 4;
>  
> +	*(uint32_t *)pos = config->kexec_method;
> +	pos += 4;
> +
>  	*(uint32_t *)pos = __cpu_to_be32(config->n_consoles);
>  	pos += 4;
>  	for (i = 0; i < config->n_consoles; i++)
> @@ -1121,6 +1126,10 @@ int pb_protocol_deserialise_config(struct config *config,
>  		goto out;
>  	config->allow_writes = !!tmp;
>  
> +	if (read_u32(&pos, &len, &tmp))
> +		goto out;
> +	config->kexec_method = !!tmp;
> +
>  	if (read_u32(&pos, &len, &config->n_consoles))
>  		goto out;
>  
> diff --git a/lib/types/types.h b/lib/types/types.h
> index 7f4ae1f..b21b2b2 100644
> --- a/lib/types/types.h
> +++ b/lib/types/types.h
> @@ -171,6 +171,8 @@ struct config {
>  
>  	bool			allow_writes;
>  
> +	bool			kexec_method;

A name like "kexec_secure" or "kexec_file_load" may be better - my
"kexec_method" being "true" sounds a bit confusing.

Patch 4 can probably also be squashed into this.

> +
>  	char			*boot_console;
>  	bool			manual_console;
>  	char			*lang;



More information about the Petitboot mailing list