cuboot-85xx.c 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Old U-boot compatibility for 85xx
  4. *
  5. * Author: Scott Wood <[email protected]>
  6. *
  7. * Copyright (c) 2007 Freescale Semiconductor, Inc.
  8. */
  9. #include "ops.h"
  10. #include "stdio.h"
  11. #include "cuboot.h"
  12. #define TARGET_85xx
  13. #define TARGET_HAS_ETH3
  14. #include "ppcboot.h"
  15. static bd_t bd;
  16. static void platform_fixups(void)
  17. {
  18. void *soc;
  19. dt_fixup_memory(bd.bi_memstart, bd.bi_memsize);
  20. dt_fixup_mac_address_by_alias("ethernet0", bd.bi_enetaddr);
  21. dt_fixup_mac_address_by_alias("ethernet1", bd.bi_enet1addr);
  22. dt_fixup_mac_address_by_alias("ethernet2", bd.bi_enet2addr);
  23. dt_fixup_mac_address_by_alias("ethernet3", bd.bi_enet3addr);
  24. dt_fixup_cpu_clocks(bd.bi_intfreq, bd.bi_busfreq / 8, bd.bi_busfreq);
  25. /* Unfortunately, the specific model number is encoded in the
  26. * soc node name in existing dts files -- once that is fixed,
  27. * this can do a simple path lookup.
  28. */
  29. soc = find_node_by_devtype(NULL, "soc");
  30. if (soc) {
  31. void *serial = NULL;
  32. setprop(soc, "bus-frequency", &bd.bi_busfreq,
  33. sizeof(bd.bi_busfreq));
  34. while ((serial = find_node_by_devtype(serial, "serial"))) {
  35. if (get_parent(serial) != soc)
  36. continue;
  37. setprop(serial, "clock-frequency", &bd.bi_busfreq,
  38. sizeof(bd.bi_busfreq));
  39. }
  40. }
  41. }
  42. void platform_init(unsigned long r3, unsigned long r4, unsigned long r5,
  43. unsigned long r6, unsigned long r7)
  44. {
  45. CUBOOT_INIT();
  46. fdt_init(_dtb_start);
  47. serial_console_init();
  48. platform_ops.fixups = platform_fixups;
  49. }