blob: 4d6ac7264ccde6ab1b69ad7aeb5865684f3242bb [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Neil Armstrongcade8652017-10-12 15:50:32 +02002/*
3 * Copyright (C) 2016 BayLibre, SAS
4 * Author: Neil Armstrong <narmstrong@baylibre.com>
Neil Armstrongcade8652017-10-12 15:50:32 +02005 */
6
7#include <common.h>
8#include <dm.h>
Simon Glass9fb625c2019-08-01 09:46:51 -06009#include <env.h>
Alex Kiernan9925f1d2018-04-01 09:22:38 +000010#include <environment.h>
Neil Armstrongcade8652017-10-12 15:50:32 +020011#include <asm/io.h>
Neil Armstrongf0f37622018-04-11 17:13:45 +020012#include <asm/arch/gx.h>
Neil Armstrongae0d82f2017-10-18 10:02:12 +020013#include <asm/arch/sm.h>
Neil Armstrongf49638e2017-11-27 10:16:18 +010014#include <asm/arch/eth.h>
Neil Armstrongc7be3e52017-11-27 10:35:46 +010015#include <asm/arch/mem.h>
Neil Armstrongae0d82f2017-10-18 10:02:12 +020016
17#define EFUSE_SN_OFFSET 20
18#define EFUSE_SN_SIZE 16
19#define EFUSE_MAC_OFFSET 52
20#define EFUSE_MAC_SIZE 6
Neil Armstrongcade8652017-10-12 15:50:32 +020021
Neil Armstrongcade8652017-10-12 15:50:32 +020022int misc_init_r(void)
23{
Neil Armstrongae0d82f2017-10-18 10:02:12 +020024 u8 mac_addr[EFUSE_MAC_SIZE];
25 char serial[EFUSE_SN_SIZE];
26 ssize_t len;
27
Jerome Brunet33e33782018-10-05 17:00:37 +020028 meson_eth_init(PHY_INTERFACE_MODE_RMII,
29 MESON_USE_INTERNAL_RMII_PHY);
Neil Armstrongae0d82f2017-10-18 10:02:12 +020030
31 if (!eth_env_get_enetaddr("ethaddr", mac_addr)) {
32 len = meson_sm_read_efuse(EFUSE_MAC_OFFSET,
33 mac_addr, EFUSE_MAC_SIZE);
34 if (len == EFUSE_MAC_SIZE && is_valid_ethaddr(mac_addr))
35 eth_env_set_enetaddr("ethaddr", mac_addr);
Neil Armstrong3f1f9f02019-06-12 11:49:08 +020036 else
37 meson_generate_serial_ethaddr();
Neil Armstrongae0d82f2017-10-18 10:02:12 +020038 }
39
40 if (!env_get("serial#")) {
41 len = meson_sm_read_efuse(EFUSE_SN_OFFSET, serial,
42 EFUSE_SN_SIZE);
43 if (len == EFUSE_SN_SIZE)
44 env_set("serial#", serial);
45 }
46
47 return 0;
Neil Armstrongcade8652017-10-12 15:50:32 +020048}