[U-Boot] [PATCH 1/1] at91: Update MEESC board support
Daniel Gorsulowski
Daniel.Gorsulowski at esd.eu
Fri Sep 4 14:29:51 CEST 2009
This patch implements several updates:
-Write the ethernet address to the EMAC module
-Disable CONFIG_ENV_OVERWRITE
-Add new hardware style variants and set the arch numbers appropriate (autodetect)
-Pass the serial# and hardware revision to the kernel
Signed-off-by: Daniel Gorsulowski <Daniel.Gorsulowski at esd.eu>
---
board/esd/meesc/meesc.c | 97 +++++++++++++++++++++++++++++++++++++++++++++--
include/configs/meesc.h | 9 ++++-
2 files changed, 101 insertions(+), 5 deletions(-)
diff --git a/board/esd/meesc/meesc.c b/board/esd/meesc/meesc.c
index 636d0ed..54a310a 100644
--- a/board/esd/meesc/meesc.c
+++ b/board/esd/meesc/meesc.c
@@ -38,6 +38,9 @@
#include <asm/arch/hardware.h>
#include <asm/arch/io.h>
#include <netdev.h>
+#ifdef CONFIG_MACB
+#include <net.h>
+#endif
DECLARE_GLOBAL_DATA_PTR;
@@ -46,6 +49,7 @@ DECLARE_GLOBAL_DATA_PTR;
*/
static int hw_rev = -1; /* hardware revision */
+static u_char hw_type; /* hardware type */
int get_hw_rev(void)
{
@@ -63,6 +67,30 @@ int get_hw_rev(void)
return hw_rev;
}
+static void meesc_set_arch_number(void)
+{
+ /* read the "Type" register of the ET1100 controller */
+ hw_type = readb(CONFIG_ET1100_BASE);
+
+ switch (hw_type) {
+ case 0x11:
+ case 0x3F:
+ /* ET1100 present,
+ arch number of MEESC-Board */
+ gd->bd->bi_arch_number = MACH_TYPE_MEESC;
+ break;
+ case 0xFF:
+ /* no ET1100 present,
+ arch number of EtherCAN/2-Board */
+ gd->bd->bi_arch_number = MACH_TYPE_ETHERCAN2;
+ break;
+ default:
+ /* assume, no ET1100 present,
+ arch number of EtherCAN/2-Board */
+ gd->bd->bi_arch_number = MACH_TYPE_ETHERCAN2;
+ break;
+ }
+}
#ifdef CONFIG_CMD_NAND
static void meesc_nand_hw_init(void)
{
@@ -157,7 +185,19 @@ int checkboard(void)
{
char str[32];
- puts("Board: esd CAN-EtherCAT Gateway");
+ switch (hw_type) {
+ case 0x11:
+ case 0x3F:
+ puts("Board: CAN-EtherCAT Gateway");
+ break;
+ case 0xFF:
+ puts("Board: EtherCAN/2 Gateway");
+ break;
+ default:
+ printf("FATAL! Read invalid hw_type: %02X\n", hw_type);
+ puts("Board: EtherCAN/2 Gateway");
+ break;
+ }
if (getenv_r("serial#", str, sizeof(str)) > 0) {
puts(", serial# ");
puts(str);
@@ -167,6 +207,49 @@ int checkboard(void)
return 0;
}
+#ifdef CONFIG_SERIAL_TAG
+void get_board_serial(struct tag_serialnr *serialnr)
+{
+ char *str;
+
+ str = strchr(getenv("serial#"), '_');
+ if (str) {
+ serialnr->high = (*(str + 1) << 8) | *(str + 2);
+ serialnr->low = simple_strtoul(str + 3, NULL, 16);
+ } else {
+ serialnr->high = 0;
+ serialnr->low = 0;
+ }
+}
+#endif
+
+#ifdef CONFIG_REVISION_TAG
+u32 get_board_rev(void)
+{
+ return hw_rev | 0x100;
+}
+#endif
+
+int misc_init_r(void)
+{
+#ifdef CONFIG_MACB
+ u32 hwaddr_btm;
+ u16 hwaddr_top;
+ u8 mac[6];
+
+ /* Set ethernet address */
+ if (!eth_getenv_enetaddr("ethaddr", mac)) {
+ puts("Missing environment variable 'ethaddr'\n");
+ } else {
+ hwaddr_btm = mac[0] | mac[1] << 8 | mac[2] << 16 | mac[3] << 24;
+ hwaddr_top = mac[4] | mac[5] << 8;
+ writel(hwaddr_btm, (void *)(AT91SAM9263_BASE_EMAC + MACB_SA1B));
+ writel(hwaddr_top, (void *)(AT91SAM9263_BASE_EMAC + MACB_SA1T));
+ }
+#endif
+ return 0;
+}
+
int board_init(void)
{
/* Peripheral Clock Enable Register */
@@ -174,8 +257,15 @@ int board_init(void)
1 << AT91SAM9263_ID_PIOB |
1 << AT91SAM9263_ID_PIOCDE);
- /* arch number of MEESC-Board */
- gd->bd->bi_arch_number = MACH_TYPE_MEESC;
+ /* initialize ET1100 Controller */
+ meesc_ethercat_hw_init();
+
+ /* set arch number by hardware type */
+ meesc_set_arch_number();
+
+ /* switch on LED1D, if running on EtherCAN/2 hardware */
+ if (hw_type == 0xFF)
+ at91_set_gpio_output(AT91_PIN_PB12, 1);
/* adress of boot parameters */
gd->bd->bi_boot_params = PHYS_SDRAM + 0x100;
@@ -184,7 +274,6 @@ int board_init(void)
#ifdef CONFIG_CMD_NAND
meesc_nand_hw_init();
#endif
- meesc_ethercat_hw_init();
#ifdef CONFIG_HAS_DATAFLASH
at91_spi0_hw_init(1 << 0);
#endif
diff --git a/include/configs/meesc.h b/include/configs/meesc.h
index 8253172..8495e3a 100644
--- a/include/configs/meesc.h
+++ b/include/configs/meesc.h
@@ -36,17 +36,19 @@
#define CONFIG_MEESC 1 /* Board is esd MEESC */
#define CONFIG_ARM926EJS 1 /* This is an ARM926EJS Core */
#define CONFIG_AT91SAM9263 1 /* It's an AT91SAM9263 SoC */
-#define CONFIG_ENV_OVERWRITE 1 /* necessary on prototypes */
#define CONFIG_DISPLAY_BOARDINFO 1
#define CONFIG_DISPLAY_CPUINFO 1 /* display cpu info and speed */
#define CONFIG_PREBOOT /* enable preboot variable */
#define CONFIG_CMDLINE_TAG 1 /* enable passing of ATAGs */
#define CONFIG_SETUP_MEMORY_TAGS 1
#define CONFIG_INITRD_TAG 1
+#define CONFIG_SERIAL_TAG 1
+#define CONFIG_REVISION_TAG 1
#undef CONFIG_USE_IRQ /* don't need IRQ/FIQ stuff */
#define CONFIG_SKIP_LOWLEVEL_INIT
#define CONFIG_SKIP_RELOCATE_UBOOT
+#define CONFIG_MISC_INIT_R 1 /* Call misc_init_r */
#define CONFIG_ARCH_CPU_INIT
@@ -143,6 +145,11 @@
/* CAN */
#define CONFIG_AT91_CAN 1
+/* hw-controller addresses */
+#define MACB_SA1B 0x0098
+#define MACB_SA1T 0x009c
+#define CONFIG_ET1100_BASE 0x70000000
+
/* bootstrap + u-boot + env + linux in dataflash on CS0 */
#define CONFIG_ENV_IS_IN_DATAFLASH 1
#define CONFIG_SYS_MONITOR_BASE (CONFIG_SYS_DATAFLASH_LOGIC_ADDR_CS0 + \
--
1.5.3
More information about the U-Boot
mailing list