blob: 7c191e53fb71f402eeb9a3e5c1ac90f5ca5a4204 [file] [log] [blame]
Michal Simek9755e3d2019-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>
Michal Simekfc274a52019-12-19 17:45:15 +01008#include <asm/sections.h>
Michal Simek9755e3d2019-01-21 15:25:02 +01009#include <dm/uclass.h>
10#include <i2c.h>
Michal Simek80fdef12020-03-31 12:39:37 +020011#include "board.h"
Michal Simek9755e3d2019-01-21 15:25:02 +010012
Michal Simek829e8c72019-01-21 16:29:07 +010013int zynq_board_read_rom_ethaddr(unsigned char *ethaddr)
14{
15 int ret = -EINVAL;
16
17#if defined(CONFIG_ZYNQ_GEM_I2C_MAC_OFFSET)
18 struct udevice *dev;
19 ofnode eeprom;
20
21 eeprom = ofnode_get_chosen_node("xlnx,eeprom");
22 if (!ofnode_valid(eeprom))
23 return -ENODEV;
24
25 debug("%s: Path to EEPROM %s\n", __func__,
Simon Glass14ca9f72020-01-27 08:49:43 -070026 ofnode_read_chosen_string("xlnx,eeprom"));
Michal Simek829e8c72019-01-21 16:29:07 +010027
28 ret = uclass_get_device_by_ofnode(UCLASS_I2C_EEPROM, eeprom, &dev);
29 if (ret)
30 return ret;
31
32 ret = dm_i2c_read(dev, CONFIG_ZYNQ_GEM_I2C_MAC_OFFSET, ethaddr, 6);
33 if (ret)
34 debug("%s: I2C EEPROM MAC address read failed\n", __func__);
35 else
36 debug("%s: I2C EEPROM MAC %pM\n", __func__, ethaddr);
37#endif
38
39 return ret;
40}
Ibai Erkiagafec657b2019-10-02 15:57:36 +010041
Michal Simekfc274a52019-12-19 17:45:15 +010042#if defined(CONFIG_OF_BOARD) || defined(CONFIG_OF_SEPARATE)
Ibai Erkiagafec657b2019-10-02 15:57:36 +010043void *board_fdt_blob_setup(void)
44{
Michal Simek453bb772020-03-19 10:23:56 +010045 static void *fdt_blob;
46
47#if !defined(CONFIG_VERSAL_NO_DDR) && !defined(CONFIG_ZYNQMP_NO_DDR)
48 fdt_blob = (void *)CONFIG_XILINX_OF_BOARD_DTB_ADDR;
Ibai Erkiagafec657b2019-10-02 15:57:36 +010049
Michal Simekfc274a52019-12-19 17:45:15 +010050 if (fdt_magic(fdt_blob) == FDT_MAGIC)
51 return fdt_blob;
Ibai Erkiagafec657b2019-10-02 15:57:36 +010052
Michal Simekfc274a52019-12-19 17:45:15 +010053 debug("DTB is not passed via %p\n", fdt_blob);
Michal Simek453bb772020-03-19 10:23:56 +010054#endif
Michal Simekfc274a52019-12-19 17:45:15 +010055
56#ifdef CONFIG_SPL_BUILD
57 /* FDT is at end of BSS unless it is in a different memory region */
58 if (IS_ENABLED(CONFIG_SPL_SEPARATE_BSS))
59 fdt_blob = (ulong *)&_image_binary_end;
60 else
61 fdt_blob = (ulong *)&__bss_end;
62#else
63 /* FDT is at end of image */
64 fdt_blob = (ulong *)&_end;
65#endif
66
67 if (fdt_magic(fdt_blob) == FDT_MAGIC)
68 return fdt_blob;
69
70 debug("DTB is also not passed via %p\n", fdt_blob);
71
72 return NULL;
Ibai Erkiagafec657b2019-10-02 15:57:36 +010073}
74#endif
Michal Simek80fdef12020-03-31 12:39:37 +020075
76int board_late_init_xilinx(void)
77{
78 env_set_hex("script_offset_f", CONFIG_BOOT_SCRIPT_OFFSET);
79
80 return 0;
81}