diff options
author | Harald Krapfenbauer <Harald.Krapfenbauer@bluetechnix.at> | 2010-01-13 09:04:53 -0500 |
---|---|---|
committer | Mike Frysinger <vapier@gentoo.org> | 2010-01-17 09:17:27 -0500 |
commit | 2aeda2d054bb32027bed33d9c3a63d152164b5e0 (patch) | |
tree | 990dbe985a526b5887579f06349895f1eb802af4 /board/tcm-bf518/tcm-bf518.c | |
parent | c46a0ebf82d3fd27dd21ad7d4fe7f11c2b2b0b21 (diff) | |
download | u-boot-2aeda2d054bb32027bed33d9c3a63d152164b5e0.tar.gz |
Blackfin: tcm-bf518: new board port
Signed-off-by: Harald Krapfenbauer <Harald.Krapfenbauer@bluetechnix.at>
Signed-off-by: Mike Frysinger <vapier@gentoo.org>
Diffstat (limited to 'board/tcm-bf518/tcm-bf518.c')
-rw-r--r-- | board/tcm-bf518/tcm-bf518.c | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/board/tcm-bf518/tcm-bf518.c b/board/tcm-bf518/tcm-bf518.c new file mode 100644 index 0000000000..5964059dd1 --- /dev/null +++ b/board/tcm-bf518/tcm-bf518.c @@ -0,0 +1,78 @@ +/* + * U-boot - main board file + * + * Copyright (c) 2008-2009 Analog Devices Inc. + * + * Licensed under the GPL-2 or later. + */ + +#include <common.h> +#include <config.h> +#include <net.h> +#include <netdev.h> +#include <asm/blackfin.h> +#include <asm/net.h> +#include <asm/mach-common/bits/otp.h> +#include <asm/sdh.h> + +int checkboard(void) +{ + printf("Board: Bluetechnix TCM-BF518 board\n"); + printf(" Support: http://www.bluetechnix.com/\n"); + printf(" http://blackfin.uclinux.org/\n"); + return 0; +} + +#if defined(CONFIG_BFIN_MAC) +static void board_init_enetaddr(uchar *mac_addr) +{ + bool valid_mac = false; + +#if 0 + /* the MAC is stored in OTP memory page 0xDF */ + uint32_t ret; + uint64_t otp_mac; + + ret = bfrom_OtpRead(0xDF, OTP_LOWER_HALF, &otp_mac); + if (!(ret & OTP_MASTER_ERROR)) { + uchar *otp_mac_p = (uchar *)&otp_mac; + + for (ret = 0; ret < 6; ++ret) + mac_addr[ret] = otp_mac_p[5 - ret]; + + if (is_valid_ether_addr(mac_addr)) + valid_mac = true; + } +#endif + + if (!valid_mac) { + puts("Warning: Generating 'random' MAC address\n"); + bfin_gen_rand_mac(mac_addr); + } + + eth_setenv_enetaddr("ethaddr", mac_addr); +} + +int board_eth_init(bd_t *bis) +{ + return bfin_EMAC_initialize(bis); +} +#endif + +int misc_init_r(void) +{ +#ifdef CONFIG_BFIN_MAC + uchar enetaddr[6]; + if (!eth_getenv_enetaddr("ethaddr", enetaddr)) + board_init_enetaddr(enetaddr); +#endif + + return 0; +} + +#ifdef CONFIG_BFIN_SDH +int board_mmc_init(bd_t *bis) +{ + return bfin_mmc_init(bis); +} +#endif |