blob: b2c901b554b81fa02cebd0f897af221782311700 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Ilya Yanokf7a2c552012-09-18 00:22:50 +00002/*
3 * (C) Copyright 2000-2004
4 * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
5 *
6 * (C) Copyright 2012
7 * Ilya Yanok <ilya.yanok@gmail.com>
Ilya Yanokf7a2c552012-09-18 00:22:50 +00008 */
9#include <common.h>
Simon Glass79fd2142019-08-01 09:46:43 -060010#include <env.h>
Nikita Kiryanov33eefe42015-11-08 17:11:49 +020011#include <errno.h>
Simon Glass2dc9c342020-05-10 11:40:01 -060012#include <image.h>
Simon Glass0f2af882020-05-10 11:40:05 -060013#include <log.h>
Ilya Yanokf7a2c552012-09-18 00:22:50 +000014#include <spl.h>
15#include <net.h>
Masahiro Yamada75f82d02018-03-05 01:20:11 +090016#include <linux/libfdt.h>
Ilya Yanokf7a2c552012-09-18 00:22:50 +000017
Simon Glasse5cd9a42021-07-10 21:14:26 -060018#if defined(CONFIG_SPL_ETH) || defined(CONFIG_SPL_USB_ETHER)
Andrew F. Davis0a88c802017-04-07 14:29:36 -050019static ulong spl_net_load_read(struct spl_load_info *load, ulong sector,
20 ulong count, void *buf)
21{
22 debug("%s: sector %lx, count %lx, buf %lx\n",
23 __func__, sector, count, (ulong)buf);
Simon Glass892265d2019-12-28 10:45:02 -070024 memcpy(buf, (void *)(image_load_addr + sector), count);
Andrew F. Davis0a88c802017-04-07 14:29:36 -050025 return count;
26}
27
Simon Glassee306792016-09-24 18:20:13 -060028static int spl_net_load_image(struct spl_image_info *spl_image,
29 struct spl_boot_device *bootdev)
Ilya Yanokf7a2c552012-09-18 00:22:50 +000030{
Simon Glassbb7d3bb2022-09-06 20:26:52 -060031 struct legacy_img_hdr *header = (struct legacy_img_hdr *)image_load_addr;
Ilya Yanokf7a2c552012-09-18 00:22:50 +000032 int rv;
33
34 env_init();
35 env_relocate();
Simon Glass6a38e412017-08-03 12:22:09 -060036 env_set("autoload", "yes");
Joe Hershberger3dbe17e2015-03-22 17:09:06 -050037 rv = eth_initialize();
Ilya Yanokf7a2c552012-09-18 00:22:50 +000038 if (rv == 0) {
39 printf("No Ethernet devices found\n");
Nikita Kiryanov33eefe42015-11-08 17:11:49 +020040 return -ENODEV;
Ilya Yanokf7a2c552012-09-18 00:22:50 +000041 }
Simon Glassc0b6c9b2016-09-24 18:19:57 -060042 if (bootdev->boot_device_name)
Simon Glass6a38e412017-08-03 12:22:09 -060043 env_set("ethact", bootdev->boot_device_name);
Joe Hershbergerc80b41b02015-04-08 01:41:21 -050044 rv = net_loop(BOOTP);
Ilya Yanokf7a2c552012-09-18 00:22:50 +000045 if (rv < 0) {
46 printf("Problem booting with BOOTP\n");
Nikita Kiryanov33eefe42015-11-08 17:11:49 +020047 return rv;
Ilya Yanokf7a2c552012-09-18 00:22:50 +000048 }
Andrew F. Davis0a88c802017-04-07 14:29:36 -050049
50 if (IS_ENABLED(CONFIG_SPL_LOAD_FIT) &&
51 image_get_magic(header) == FDT_MAGIC) {
52 struct spl_load_info load;
53
54 debug("Found FIT\n");
55 load.bl_len = 1;
56 load.read = spl_net_load_read;
57 rv = spl_load_simple_fit(spl_image, &load, 0, header);
58 } else {
59 debug("Legacy image\n");
60
Pali Rohárdda8f882022-01-14 14:31:38 +010061 rv = spl_parse_image_header(spl_image, bootdev, header);
Andrew F. Davis0a88c802017-04-07 14:29:36 -050062 if (rv)
63 return rv;
64
65 memcpy((void *)spl_image->load_addr, header, spl_image->size);
66 }
67
68 return rv;
Ilya Yanokf7a2c552012-09-18 00:22:50 +000069}
Simon Glassd9aefcb2016-09-24 18:20:11 -060070#endif
71
Simon Glasse5cd9a42021-07-10 21:14:26 -060072#ifdef CONFIG_SPL_ETH
Simon Glassee306792016-09-24 18:20:13 -060073int spl_net_load_image_cpgmac(struct spl_image_info *spl_image,
74 struct spl_boot_device *bootdev)
Simon Glassd9aefcb2016-09-24 18:20:11 -060075{
76#ifdef CONFIG_SPL_ETH_DEVICE
77 bootdev->boot_device_name = CONFIG_SPL_ETH_DEVICE;
78#endif
79
Simon Glassee306792016-09-24 18:20:13 -060080 return spl_net_load_image(spl_image, bootdev);
Simon Glassd9aefcb2016-09-24 18:20:11 -060081}
Simon Glass4fc1f252016-11-30 15:30:50 -070082SPL_LOAD_IMAGE_METHOD("eth device", 0, BOOT_DEVICE_CPGMAC,
83 spl_net_load_image_cpgmac);
Simon Glassd9aefcb2016-09-24 18:20:11 -060084#endif
85
Faiz Abbasc01553b2018-02-16 21:17:44 +053086#ifdef CONFIG_SPL_USB_ETHER
Simon Glassee306792016-09-24 18:20:13 -060087int spl_net_load_image_usb(struct spl_image_info *spl_image,
88 struct spl_boot_device *bootdev)
Simon Glassd9aefcb2016-09-24 18:20:11 -060089{
90 bootdev->boot_device_name = "usb_ether";
Jean-Jacques Hiblot2c753142018-12-04 11:30:48 +010091#if CONFIG_IS_ENABLED(DM_USB_GADGET)
92 usb_ether_init();
93#endif
Simon Glassee306792016-09-24 18:20:13 -060094 return spl_net_load_image(spl_image, bootdev);
Simon Glassd9aefcb2016-09-24 18:20:11 -060095}
Simon Glass4fc1f252016-11-30 15:30:50 -070096SPL_LOAD_IMAGE_METHOD("USB eth", 0, BOOT_DEVICE_USBETH, spl_net_load_image_usb);
Simon Glassd9aefcb2016-09-24 18:20:11 -060097#endif