[PATCH 1/3] fastboot: lift restrictions on !NET_LWIP for USB
Michael Walle
mwalle at kernel.org
Fri Mar 28 10:06:12 CET 2025
Hi Mattijs,
> > Fastboot works either over TCP, UDP or USB. The latter doesn't have
> > anything to do with networking, thus should work just fine with
> > regardless which network stack is selected. In practice, header symbols
> > are used inside common code paths. Add some ifdeffery to guard against
> > that.
> >
> > This will make fastboot over USB work with the new LWIP stack.
> >
> > Signed-off-by: Michael Walle <mwalle at kernel.org>
>
> checkpatch.pl reports some issues with this:
>
> $ ./scripts/checkpatch.pl --strict --u-boot --git HEAD^..HEAD
>
> <snip>
> WARNING: Use 'if (IS_ENABLED(CONFIG...))' instead of '#if or #ifdef' where possible
> <snip>
>
> Some occurences below could be fixed. Could you please have a look?
I've seen these. More below.
>
> > ---
> > Alternatively, we could add the defines and stub functions to the lwip
> > header.
This is relevant :)
> > ---
> > cmd/fastboot.c | 4 ++++
> > drivers/fastboot/Kconfig | 1 -
> > drivers/fastboot/fb_common.c | 4 ++++
> > 3 files changed, 8 insertions(+), 1 deletion(-)
> >
> > diff --git a/cmd/fastboot.c b/cmd/fastboot.c
> > index d4cfc0c7a28..be84a482b81 100644
> > --- a/cmd/fastboot.c
> > +++ b/cmd/fastboot.c
> > @@ -16,6 +16,7 @@
> > #include <linux/printk.h>
> > #include <linux/stringify.h>
> >
> > +#if CONFIG_IS_ENABLED(NET)
>
> I think this can be dropped. I hope that since it's a static function,
> -if there are no users in the file- the compiler will optimize it out.
> Note: I have not verified this, so I might be wrong.
>
> If you measure and see size changes between keeping the #if and not
> keeping it, please ignore this comment.
No, because net_loop(), net_set_state() and NETLOOP_SUCCESS is only
defined in net-legacy.h. Thus we need this ifdeffery.. Unless of
course, we add the enums and function stubs to the new lwip net
inlcude. I don't know if that's a good idea though.
-michael
>
> > static int do_fastboot_udp(int argc, char *const argv[],
> > uintptr_t buf_addr, size_t buf_size)
> > {
> > @@ -55,6 +56,7 @@ static int do_fastboot_tcp(int argc, char *const argv[],
> >
> > return CMD_RET_SUCCESS;
> > }
> > +#endif
> >
> > static int do_fastboot_usb(int argc, char *const argv[],
> > uintptr_t buf_addr, size_t buf_size)
> > @@ -160,10 +162,12 @@ NXTARG:
> >
> > fastboot_init((void *)buf_addr, buf_size);
> >
> > +#if CONFIG_IS_ENABLED(NET)
> > if (!strcmp(argv[1], "udp"))
> > return do_fastboot_udp(argc, argv, buf_addr, buf_size);
> > if (!strcmp(argv[1], "tcp"))
> > return do_fastboot_tcp(argc, argv, buf_addr, buf_size);
> > +#endif
>
> This can be replaced with:
>
> if (IS_ENABLED(CONFIG_NET)) {
> if (!strcmp(argv[1], "udp"))
> return do_fastboot_udp(argc, argv, buf_addr, buf_size);
> if (!strcmp(argv[1], "tcp"))
> return do_fastboot_tcp(argc, argv, buf_addr, buf_size);
> }
>
> > if (!strcmp(argv[1], "usb")) {
> > argv++;
> > argc--;
> > diff --git a/drivers/fastboot/Kconfig b/drivers/fastboot/Kconfig
> > index 1eb460f5a02..70207573de2 100644
> > --- a/drivers/fastboot/Kconfig
> > +++ b/drivers/fastboot/Kconfig
> > @@ -1,6 +1,5 @@
> > menu "Fastboot support"
> > depends on CMDLINE
> > - depends on !NET_LWIP
> >
> > config FASTBOOT
> > bool
> > diff --git a/drivers/fastboot/fb_common.c b/drivers/fastboot/fb_common.c
> > index 12ffb463deb..68f92c4b887 100644
> > --- a/drivers/fastboot/fb_common.c
> > +++ b/drivers/fastboot/fb_common.c
> > @@ -183,11 +183,15 @@ void fastboot_handle_boot(int command, bool success)
> > switch (command) {
> > case FASTBOOT_COMMAND_BOOT:
> > fastboot_boot();
> > +#if CONFIG_IS_ENABLED(NET)
> > net_set_state(NETLOOP_SUCCESS);
> > +#endif
>
> This can be replaced with:
>
> if (IS_ENABLED((CONFIG_NET))
> net_set_state(NETLOOP_SUCCESS);
>
> > break;
> >
> > case FASTBOOT_COMMAND_CONTINUE:
> > +#if CONFIG_IS_ENABLED(NET)
> > net_set_state(NETLOOP_SUCCESS);
> > +#endif
>
> Same here.
>
> > break;
> >
> > case FASTBOOT_COMMAND_REBOOT:
> > --
> > 2.39.5
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 297 bytes
Desc: not available
URL: <https://lists.denx.de/pipermail/u-boot/attachments/20250328/2fa4e9a2/attachment.sig>
More information about the U-Boot
mailing list