blob: b0f60c40a5c840bd0799d7747836d0e51aafccc7 [file] [log] [blame]
Michal Simek014d3042019-01-21 15:25:02 +01001// SPDX-License-Identifier: GPL-2.0+
2/*
3 * (C) Copyright 2014 - 2019 Xilinx, Inc.
4 * Michal Simek <michal.simek@xilinx.com>
5 */
6
7#include <common.h>
Simon Glassed38aef2020-05-10 11:40:03 -06008#include <env.h>
Simon Glass0f2af882020-05-10 11:40:05 -06009#include <log.h>
Michal Simek878ba362019-12-19 17:45:15 +010010#include <asm/sections.h>
Michal Simek014d3042019-01-21 15:25:02 +010011#include <dm/uclass.h>
12#include <i2c.h>
Michal Simekb90b97e2020-04-08 10:51:36 +020013#include <linux/sizes.h>
Michal Simek705d44a2020-03-31 12:39:37 +020014#include "board.h"
Michal Simek014d3042019-01-21 15:25:02 +010015
Michal Simekaee22b32020-08-03 12:59:28 +020016#if defined(CONFIG_ZYNQ_GEM_I2C_MAC_OFFSET)
Michal Simek014d3042019-01-21 15:25:02 +010017int zynq_board_read_rom_ethaddr(unsigned char *ethaddr)
18{
Michal Simek13db6162019-01-21 16:29:07 +010019 int ret = -EINVAL;
Michal Simek13db6162019-01-21 16:29:07 +010020 struct udevice *dev;
21 ofnode eeprom;
22
23 eeprom = ofnode_get_chosen_node("xlnx,eeprom");
24 if (!ofnode_valid(eeprom))
25 return -ENODEV;
26
27 debug("%s: Path to EEPROM %s\n", __func__,
Simon Glassf3455962020-01-27 08:49:43 -070028 ofnode_read_chosen_string("xlnx,eeprom"));
Michal Simek13db6162019-01-21 16:29:07 +010029
30 ret = uclass_get_device_by_ofnode(UCLASS_I2C_EEPROM, eeprom, &dev);
31 if (ret)
32 return ret;
33
34 ret = dm_i2c_read(dev, CONFIG_ZYNQ_GEM_I2C_MAC_OFFSET, ethaddr, 6);
35 if (ret)
36 debug("%s: I2C EEPROM MAC address read failed\n", __func__);
37 else
38 debug("%s: I2C EEPROM MAC %pM\n", __func__, ethaddr);
Michal Simek13db6162019-01-21 16:29:07 +010039
40 return ret;
41}
Michal Simekaee22b32020-08-03 12:59:28 +020042#endif
Ibai Erkiaga6f658202019-10-02 15:57:36 +010043
Michal Simek878ba362019-12-19 17:45:15 +010044#if defined(CONFIG_OF_BOARD) || defined(CONFIG_OF_SEPARATE)
Ibai Erkiaga6f658202019-10-02 15:57:36 +010045void *board_fdt_blob_setup(void)
46{
Michal Simekddf69ae2020-09-04 16:21:47 +020047 void *fdt_blob;
Michal Simekc89f4292020-03-19 10:23:56 +010048
49#if !defined(CONFIG_VERSAL_NO_DDR) && !defined(CONFIG_ZYNQMP_NO_DDR)
50 fdt_blob = (void *)CONFIG_XILINX_OF_BOARD_DTB_ADDR;
Ibai Erkiaga6f658202019-10-02 15:57:36 +010051
Michal Simek878ba362019-12-19 17:45:15 +010052 if (fdt_magic(fdt_blob) == FDT_MAGIC)
53 return fdt_blob;
54
55 debug("DTB is not passed via %p\n", fdt_blob);
Michal Simekc89f4292020-03-19 10:23:56 +010056#endif
Michal Simek878ba362019-12-19 17:45:15 +010057
58#ifdef CONFIG_SPL_BUILD
59 /* FDT is at end of BSS unless it is in a different memory region */
60 if (IS_ENABLED(CONFIG_SPL_SEPARATE_BSS))
61 fdt_blob = (ulong *)&_image_binary_end;
62 else
63 fdt_blob = (ulong *)&__bss_end;
64#else
65 /* FDT is at end of image */
66 fdt_blob = (ulong *)&_end;
67#endif
68
69 if (fdt_magic(fdt_blob) == FDT_MAGIC)
70 return fdt_blob;
71
72 debug("DTB is also not passed via %p\n", fdt_blob);
Ibai Erkiaga6f658202019-10-02 15:57:36 +010073
Michal Simek878ba362019-12-19 17:45:15 +010074 return NULL;
Ibai Erkiaga6f658202019-10-02 15:57:36 +010075}
76#endif
Michal Simek705d44a2020-03-31 12:39:37 +020077
78int board_late_init_xilinx(void)
79{
Michal Simekbd07b5d2020-08-12 12:16:49 +020080 u32 ret = 0;
Michal Simekc86ce0c2020-08-12 12:17:53 +020081 phys_size_t bootm_size = gd->ram_size;
82
83 if (CONFIG_IS_ENABLED(ARCH_ZYNQ))
84 bootm_size = min(bootm_size, (phys_size_t)(SZ_512M + SZ_256M));
Michal Simekbd07b5d2020-08-12 12:16:49 +020085
86 ret |= env_set_hex("script_offset_f", CONFIG_BOOT_SCRIPT_OFFSET);
87
88 ret |= env_set_addr("bootm_low", (void *)gd->ram_base);
Michal Simekc86ce0c2020-08-12 12:17:53 +020089 ret |= env_set_addr("bootm_size", (void *)bootm_size);
Michal Simek705d44a2020-03-31 12:39:37 +020090
Michal Simekbd07b5d2020-08-12 12:16:49 +020091 if (ret)
92 printf("%s: Saving run time variables FAILED\n", __func__);
Michal Simek8ba62d22020-07-09 15:57:56 +020093
Michal Simek705d44a2020-03-31 12:39:37 +020094 return 0;
95}