2 * (C) Copyright 2000-2004
8 * SPDX-License-Identifier: GPL-2.0+
16 DECLARE_GLOBAL_DATA_PTR;
18 #if defined(CONFIG_SPL_ETH_SUPPORT) || defined(CONFIG_SPL_USBETH_SUPPORT)
19 static ulong spl_net_load_read(struct spl_load_info *load, ulong sector,
20 ulong count, void *buf)
22 debug("%s: sector %lx, count %lx, buf %lx\n",
23 __func__, sector, count, (ulong)buf);
24 memcpy(buf, (void *)(load_addr + sector), count);
28 static int spl_net_load_image(struct spl_image_info *spl_image,
29 struct spl_boot_device *bootdev)
31 struct image_header *header = (struct image_header *)load_addr;
36 setenv("autoload", "yes");
37 rv = eth_initialize();
39 printf("No Ethernet devices found\n");
42 if (bootdev->boot_device_name)
43 setenv("ethact", bootdev->boot_device_name);
46 printf("Problem booting with BOOTP\n");
50 if (IS_ENABLED(CONFIG_SPL_LOAD_FIT) &&
51 image_get_magic(header) == FDT_MAGIC) {
52 struct spl_load_info load;
56 load.read = spl_net_load_read;
57 rv = spl_load_simple_fit(spl_image, &load, 0, header);
59 debug("Legacy image\n");
61 rv = spl_parse_image_header(spl_image, header);
65 memcpy((void *)spl_image->load_addr, header, spl_image->size);
72 #ifdef CONFIG_SPL_ETH_SUPPORT
73 int spl_net_load_image_cpgmac(struct spl_image_info *spl_image,
74 struct spl_boot_device *bootdev)
76 #ifdef CONFIG_SPL_ETH_DEVICE
77 bootdev->boot_device_name = CONFIG_SPL_ETH_DEVICE;
80 return spl_net_load_image(spl_image, bootdev);
82 SPL_LOAD_IMAGE_METHOD("eth device", 0, BOOT_DEVICE_CPGMAC,
83 spl_net_load_image_cpgmac);
86 #ifdef CONFIG_SPL_USBETH_SUPPORT
87 int spl_net_load_image_usb(struct spl_image_info *spl_image,
88 struct spl_boot_device *bootdev)
90 bootdev->boot_device_name = "usb_ether";
92 return spl_net_load_image(spl_image, bootdev);
94 SPL_LOAD_IMAGE_METHOD("USB eth", 0, BOOT_DEVICE_USBETH, spl_net_load_image_usb);