aboutsummaryrefslogtreecommitdiffstats
path: root/roms/u-boot/arch/arm/mach-omap2/omap3/emac.c
diff options
context:
space:
mode:
Diffstat (limited to 'roms/u-boot/arch/arm/mach-omap2/omap3/emac.c')
-rw-r--r--roms/u-boot/arch/arm/mach-omap2/omap3/emac.c28
1 files changed, 28 insertions, 0 deletions
diff --git a/roms/u-boot/arch/arm/mach-omap2/omap3/emac.c b/roms/u-boot/arch/arm/mach-omap2/omap3/emac.c
new file mode 100644
index 000000000..d0d0b7a75
--- /dev/null
+++ b/roms/u-boot/arch/arm/mach-omap2/omap3/emac.c
@@ -0,0 +1,28 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ *
+ * DaVinci EMAC initialization.
+ *
+ * (C) Copyright 2011, Ilya Yanok, Emcraft Systems
+ */
+
+#include <common.h>
+#include <net.h>
+#include <asm/io.h>
+#include <asm/arch/am35x_def.h>
+
+/*
+ * Initializes on-chip ethernet controllers.
+ * to override, implement board_eth_init()
+ */
+int cpu_eth_init(struct bd_info *bis)
+{
+ u32 reset;
+
+ /* ensure that the module is out of reset */
+ reset = readl(&am35x_scm_general_regs->ip_sw_reset);
+ reset &= ~CPGMACSS_SW_RST;
+ writel(reset, &am35x_scm_general_regs->ip_sw_reset);
+
+ return 0;
+}