[PATCH] efi_loader: fix ipv4 device path node conversion
Ilias Apalodimas
ilias.apalodimas at linaro.org
Wed Mar 26 08:31:36 CET 2025
Thanks Vincent!
On Mon, 24 Mar 2025 at 10:35, Vincent Stehlé <vincent.stehle at arm.com> wrote:
>
> When converting an IPv4 device path node to text, the
> EFI_DEVICE_PATH_TO_TEXT_PROTOCOL will produce the following string:
>
> IPv4(5.6.7.8,TCP,UDP,0x6,DHCP,1.2.3.4,9.10.11.12,255.255.255.0)
>
> This string erroneously contains multiple protocols: TCP, UDP and 0x6.
>
> Add the missing `break' statements in the dp_msging() function to fix this
> and obtain the following expected string instead:
>
> IPv4(5.6.7.8,TCP,DHCP,1.2.3.4,9.10.11.12,255.255.255.0)
>
> Fixes: aaf63429a112 ("efi_loader: add IPv4() to device path to text protocol")
> Signed-off-by: Vincent Stehlé <vincent.stehle at arm.com>
> Cc: Heinrich Schuchardt <xypron.glpk at gmx.de>
> Cc: Ilias Apalodimas <ilias.apalodimas at linaro.org>
> Cc: Adriano Cordova <adrianox at gmail.com>
> Cc: Tom Rini <trini at konsulko.com>
Reviewed-by: Ilias Apalodimas <ilias.apalodimas at linaro.org>
> ---
> lib/efi_loader/efi_device_path_to_text.c | 3 +++
> 1 file changed, 3 insertions(+)
>
> diff --git a/lib/efi_loader/efi_device_path_to_text.c b/lib/efi_loader/efi_device_path_to_text.c
> index f6889cb7399..452ec1b2e8b 100644
> --- a/lib/efi_loader/efi_device_path_to_text.c
> +++ b/lib/efi_loader/efi_device_path_to_text.c
> @@ -181,10 +181,13 @@ static char *dp_msging(char *s, struct efi_device_path *dp)
> switch (idp->protocol) {
> case IPPROTO_TCP:
> s += sprintf(s, "TCP,");
> + break;
> case IPPROTO_UDP:
> s += sprintf(s, "UDP,");
> + break;
> default:
> s += sprintf(s, "0x%x,", idp->protocol);
> + break;
> }
> s += sprintf(s, idp->static_ip_address ? "Static" : "DHCP");
> s += sprintf(s, ",%pI4", &idp->local_ip_address);
> --
> 2.47.2
>
More information about the U-Boot
mailing list