spl_net.c 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. /*
  2. * (C) Copyright 2000-2004
  3. * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
  4. *
  5. * (C) Copyright 2012
  6. * Ilya Yanok <ilya.yanok@gmail.com>
  7. *
  8. * SPDX-License-Identifier: GPL-2.0+
  9. */
  10. #include <common.h>
  11. #include <errno.h>
  12. #include <spl.h>
  13. #include <net.h>
  14. #include <libfdt.h>
  15. DECLARE_GLOBAL_DATA_PTR;
  16. #if defined(CONFIG_SPL_ETH_SUPPORT) || defined(CONFIG_SPL_USBETH_SUPPORT)
  17. static ulong spl_net_load_read(struct spl_load_info *load, ulong sector,
  18. ulong count, void *buf)
  19. {
  20. debug("%s: sector %lx, count %lx, buf %lx\n",
  21. __func__, sector, count, (ulong)buf);
  22. memcpy(buf, (void *)(load_addr + sector), count);
  23. return count;
  24. }
  25. static int spl_net_load_image(struct spl_image_info *spl_image,
  26. struct spl_boot_device *bootdev)
  27. {
  28. struct image_header *header = (struct image_header *)load_addr;
  29. int rv;
  30. env_init();
  31. env_relocate();
  32. setenv("autoload", "yes");
  33. if (!IS_ENABLED(CONFIG_SPL_LOAD_FIT))
  34. load_addr = CONFIG_SYS_TEXT_BASE - sizeof(struct image_header);
  35. rv = eth_initialize();
  36. if (rv == 0) {
  37. printf("No Ethernet devices found\n");
  38. return -ENODEV;
  39. }
  40. if (bootdev->boot_device_name)
  41. setenv("ethact", bootdev->boot_device_name);
  42. rv = net_loop(BOOTP);
  43. if (rv < 0) {
  44. printf("Problem booting with BOOTP\n");
  45. return rv;
  46. }
  47. if (IS_ENABLED(CONFIG_SPL_LOAD_FIT) &&
  48. image_get_magic(header) == FDT_MAGIC) {
  49. struct spl_load_info load;
  50. debug("Found FIT\n");
  51. load.bl_len = 1;
  52. load.read = spl_net_load_read;
  53. rv = spl_load_simple_fit(spl_image, &load, 0, header);
  54. } else {
  55. debug("Legacy image\n");
  56. rv = spl_parse_image_header(spl_image, header);
  57. }
  58. return rv;
  59. }
  60. #endif
  61. #ifdef CONFIG_SPL_ETH_SUPPORT
  62. int spl_net_load_image_cpgmac(struct spl_image_info *spl_image,
  63. struct spl_boot_device *bootdev)
  64. {
  65. #ifdef CONFIG_SPL_ETH_DEVICE
  66. bootdev->boot_device_name = CONFIG_SPL_ETH_DEVICE;
  67. #endif
  68. return spl_net_load_image(spl_image, bootdev);
  69. }
  70. SPL_LOAD_IMAGE_METHOD("eth device", 0, BOOT_DEVICE_CPGMAC,
  71. spl_net_load_image_cpgmac);
  72. #endif
  73. #ifdef CONFIG_SPL_USBETH_SUPPORT
  74. int spl_net_load_image_usb(struct spl_image_info *spl_image,
  75. struct spl_boot_device *bootdev)
  76. {
  77. bootdev->boot_device_name = "usb_ether";
  78. return spl_net_load_image(spl_image, bootdev);
  79. }
  80. SPL_LOAD_IMAGE_METHOD("USB eth", 0, BOOT_DEVICE_USBETH, spl_net_load_image_usb);
  81. #endif