Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Openwrt/v2014.01 #4

Closed
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
VERSION = 2014
PATCHLEVEL = 01
SUBLEVEL =
EXTRAVERSION =
EXTRAVERSION = -openwrt1
ifneq "$(SUBLEVEL)" ""
U_BOOT_VERSION = $(VERSION).$(PATCHLEVEL).$(SUBLEVEL)$(EXTRAVERSION)
else
Expand Down
7 changes: 7 additions & 0 deletions board/lantiq/arv7519rw/Makefile
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
#
# Copyright (C) 2000-2011 Wolfgang Denk, DENX Software Engineering, wd@denx.de
#
# SPDX-License-Identifier: GPL-2.0+
#

obj-y = arv7519rw.o
118 changes: 118 additions & 0 deletions board/lantiq/arv7519rw/arv7519rw.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,118 @@
/*
* Copyright (C) 2011-2013 Daniel Schwierzeck, daniel.schwierzeck@gmail.com
*
* SPDX-License-Identifier: GPL-2.0+
*/

#include <common.h>
#include <asm/gpio.h>
#include <asm/lantiq/eth.h>
#include <asm/lantiq/chipid.h>
#include <asm/lantiq/cpu.h>
#include <asm/arch/gphy.h>

#if defined(CONFIG_SPL_BUILD)
#define do_gpio_init 1
#define do_pll_init 1
#define do_dcdc_init 0
#elif defined(CONFIG_SYS_BOOT_RAM)
#define do_gpio_init 1
#define do_pll_init 0
#define do_dcdc_init 1
#elif defined(CONFIG_SYS_BOOT_NOR)
#define do_gpio_init 1
#define do_pll_init 1
#define do_dcdc_init 1
#else
#define do_gpio_init 0
#define do_pll_init 0
#define do_dcdc_init 1
#endif

static void gpio_init(void)
{
/* Turn on power and alarm LEDs */

gpio_direction_output(14, 1);
gpio_direction_output(15, 1);

gpio_set_value(14, 0);
gpio_set_value(15, 0);

/* EBU.FL_A23 as output for NOR flash */

gpio_set_altfunc(24, GPIO_ALTSEL_SET, GPIO_ALTSEL_CLR, GPIO_DIR_OUT);

/* EBU.FL_A24 as output for NOR flash */
gpio_set_altfunc(13, GPIO_ALTSEL_SET, GPIO_ALTSEL_CLR, GPIO_DIR_OUT);

/* EBU.FL_A25 as output for NOR flash */
gpio_set_altfunc(31, GPIO_ALTSEL_SET, GPIO_ALTSEL_CLR, GPIO_DIR_OUT);

}

int board_early_init_f(void)
{
if (do_gpio_init)
gpio_init();

if (do_pll_init)
ltq_pll_init();

if (do_dcdc_init)
ltq_dcdc_init(0x7F);

return 0;
}

int checkboard(void)
{
puts("Board: " CONFIG_BOARD_NAME "\n");
ltq_chip_print_info();

return 0;
}

static const struct ltq_eth_port_config eth_port_config[] = {
/* GMAC0: external Lantiq PEF7071 v1.5 10/100/1000 PHY for LAN port 0 */
{ 0, 0x0, LTQ_ETH_PORT_PHY, PHY_INTERFACE_MODE_RGMII },
/* GMAC1: internal GPHY1 with 10/100/1000 firmware for LAN port 1 */
{ 2, 0x11, LTQ_ETH_PORT_PHY, PHY_INTERFACE_MODE_MII },
/* GMAC3: internal GPHY1 with 10/100/1000 firmware for LAN port 2 */
{ 3, 0x12, LTQ_ETH_PORT_PHY, PHY_INTERFACE_MODE_MII },
/* GMAC4: internal GPHY1 with 10/100/1000 firmware for LAN port 3 */
{ 4, 0x13, LTQ_ETH_PORT_PHY, PHY_INTERFACE_MODE_MII },
/* GMAC5: internal GPHY1 with 10/100/1000 firmware for LAN port 4 */
{ 5, 0x14, LTQ_ETH_PORT_PHY, PHY_INTERFACE_MODE_MII },
};

static const struct ltq_eth_board_config eth_board_config = {
.ports = eth_port_config,
.num_ports = ARRAY_SIZE(eth_port_config),
};

int board_eth_init(bd_t * bis)
{
const enum ltq_gphy_clk clk = LTQ_GPHY_CLK_25MHZ_PLL0;
const ulong fw_addr = 0x80FE0000;

switch ( ltq_chip_version_get() ) {

case 1:
ltq_gphy_phy22f_a1x_load(fw_addr);
break;

case 2:
ltq_gphy_phy22f_a2x_load(fw_addr);
break;

}

ltq_cgu_gphy_clk_src(clk);

ltq_rcu_gphy_boot(0, fw_addr);
ltq_rcu_gphy_boot(1, fw_addr);

return ltq_eth_initialize(&eth_board_config);
}

7 changes: 7 additions & 0 deletions board/lantiq/arv7519rw/config.mk
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
#
# Copyright (C) 2011-2013 Daniel Schwierzeck, daniel.schwierzeck@gmail.com
#
# SPDX-License-Identifier: GPL-2.0+
#

PLATFORM_CPPFLAGS += -I$(TOPDIR)/board/$(BOARDDIR)
69 changes: 69 additions & 0 deletions board/lantiq/arv7519rw/ddr_settings.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
/*
* Copyright (C) 2007-2010 Lantiq Deutschland GmbH
* Copyright (C) 2011-2013 Daniel Schwierzeck, daniel.schwierzeck@gmail.com
*
* SPDX-License-Identifier: GPL-2.0+
*/

#define MC_CCR00_VALUE 0x101
#define MC_CCR01_VALUE 0x1000100
#define MC_CCR02_VALUE 0x1010000
#define MC_CCR03_VALUE 0x101
#define MC_CCR04_VALUE 0x1000000
#define MC_CCR05_VALUE 0x1000101
#define MC_CCR06_VALUE 0x1000100
#define MC_CCR07_VALUE 0x1010000
#define MC_CCR08_VALUE 0x1000101
#define MC_CCR09_VALUE 0x0
#define MC_CCR10_VALUE 0x2000100
#define MC_CCR11_VALUE 0x2000401
#define MC_CCR12_VALUE 0x30000
#define MC_CCR13_VALUE 0x202
#define MC_CCR14_VALUE 0x7080A0F
#define MC_CCR15_VALUE 0x2040F
#define MC_CCR16_VALUE 0x40000
#define MC_CCR17_VALUE 0x70102
#define MC_CCR18_VALUE 0x4020002
#define MC_CCR19_VALUE 0x30302
#define MC_CCR20_VALUE 0x8000700
#define MC_CCR21_VALUE 0x40F020A
#define MC_CCR22_VALUE 0x0
#define MC_CCR23_VALUE 0xC020000
#define MC_CCR24_VALUE 0x4401B04
#define MC_CCR25_VALUE 0x0
#define MC_CCR26_VALUE 0x0
#define MC_CCR27_VALUE 0x6420000
#define MC_CCR28_VALUE 0x0
#define MC_CCR29_VALUE 0x0
#define MC_CCR30_VALUE 0x798
#define MC_CCR31_VALUE 0x0
#define MC_CCR32_VALUE 0x0
#define MC_CCR33_VALUE 0x650000
#define MC_CCR34_VALUE 0x200C8
#define MC_CCR35_VALUE 0x1D445D
#define MC_CCR36_VALUE 0xC8
#define MC_CCR37_VALUE 0xC351
#define MC_CCR38_VALUE 0x0
#define MC_CCR39_VALUE 0x141F04
#define MC_CCR40_VALUE 0x142704
#define MC_CCR41_VALUE 0x141b42
#define MC_CCR42_VALUE 0x141b42
#define MC_CCR43_VALUE 0x566504
#define MC_CCR44_VALUE 0x566504
#define MC_CCR45_VALUE 0x565F17
#define MC_CCR46_VALUE 0x565F17
#define MC_CCR47_VALUE 0x0
#define MC_CCR48_VALUE 0x0
#define MC_CCR49_VALUE 0x0
#define MC_CCR50_VALUE 0x0
#define MC_CCR51_VALUE 0x0
#define MC_CCR52_VALUE 0x133
#define MC_CCR53_VALUE 0xF3014B27
#define MC_CCR54_VALUE 0xF3014B27
#define MC_CCR55_VALUE 0xF3014B27
#define MC_CCR56_VALUE 0xF3014B27
#define MC_CCR57_VALUE 0x7800301
#define MC_CCR58_VALUE 0x7800301
#define MC_CCR59_VALUE 0x7800301
#define MC_CCR60_VALUE 0x7800301
#define MC_CCR61_VALUE 0x4
2 changes: 2 additions & 0 deletions boards.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -570,6 +570,8 @@ Active mips mips32 vrx200 lantiq easy80920
Active mips mips32 vrx200 lantiq easy80920 easy80920_norspl easy80920:SYS_BOOT_NORSPL Daniel Schwierzeck <daniel.schwierzeck@gmail.com>
Active mips mips32 vrx200 lantiq easy80920 easy80920_ram easy80920:SYS_BOOT_RAM Daniel Schwierzeck <daniel.schwierzeck@gmail.com>
Active mips mips32 vrx200 lantiq easy80920 easy80920_sfspl easy80920:SYS_BOOT_SFSPL Daniel Schwierzeck <daniel.schwierzeck@gmail.com>
Active mips mips32 vrx200 lantiq arv7519rw arv7519rw_ram arv7519rw:SYS_BOOT_RAM Esteban Benito <estebanjbs@gmail.com>
Active mips mips32 vrx200 lantiq arv7519rw arv7519rw_nor arv7519rw:SYS_BOOT_NOR Esteban Benito <estebanjbs@gmail.com>
Active mips mips32 vrx200 zte zxhnh367n zxhnh367n_nandspl zxhnh367n:SYS_BOOT_NANDSPL Luka Perkov <luka@openwrt.org>
Active mips mips32 vrx200 zte zxhnh367n zxhnh367n_ram zxhnh367n:SYS_BOOT_RAM Luka Perkov <luka@openwrt.org>
Active mips mips32 vrx200 zte zxhnh367n zxhnh367n_zte zxhnh367n:SYS_BOOT_ZTE Luka Perkov <luka@openwrt.org>
Expand Down
74 changes: 74 additions & 0 deletions include/configs/arv7519rw.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,74 @@
/*
* Copyright (C) 2011-2013 Daniel Schwierzeck, daniel.schwierzeck@gmail.com
*
* SPDX-License-Identifier: GPL-2.0+
*/

#ifndef __CONFIG_H
#define __CONFIG_H

#define CONFIG_MACH_TYPE "arv7519rw"
#define CONFIG_IDENT_STRING " "CONFIG_MACH_TYPE
#define CONFIG_BOARD_NAME "Lantiq ARV7519RW VRX200 Family Board"

/* Configure SoC */
#define CONFIG_LTQ_SUPPORT_UART /* Enable ASC and UART */

#define CONFIG_LTQ_SUPPORT_ETHERNET /* Enable ethernet */

#define CONFIG_LTQ_SUPPORT_NOR_FLASH /* Have a parallel NOR flash */

#define CONFIG_LTQ_SUPPORT_SPL_NOR_FLASH /* Build NOR flash SPL */

#define CONFIG_LTQ_SPL_COMP_LZO
#define CONFIG_LTQ_SPL_CONSOLE

#define CONFIG_SYS_DRAM_PROBE

/* Environment */

#if defined(CONFIG_SYS_BOOT_NOR)
#define CONFIG_ENV_IS_IN_FLASH
#define CONFIG_ENV_OVERWRITE
#define CONFIG_ENV_OFFSET (384 * 1024)
#define CONFIG_ENV_SECT_SIZE (128 * 1024)
#elif defined(CONFIG_SYS_BOOT_NORSPL)
#define CONFIG_ENV_IS_IN_FLASH
#define CONFIG_ENV_OVERWRITE
#define CONFIG_ENV_OFFSET (384 * 1024)
#define CONFIG_ENV_SECT_SIZE (128 * 1024)
#else
#define CONFIG_ENV_IS_NOWHERE
#endif

#define CONFIG_ENV_SIZE (8 * 1024)

#define CONFIG_LOADADDR CONFIG_SYS_LOAD_ADDR

/* Console */
#define CONFIG_LTQ_ADVANCED_CONSOLE
#define CONFIG_BAUDRATE 115200
#define CONFIG_CONSOLE_ASC 1
#define CONFIG_CONSOLE_DEV "ttyLTQ1"

/* Pull in default board configs for Lantiq XWAY VRX200 */
#include <asm/lantiq/config.h>
#include <asm/arch/config.h>

/* Pull in default OpenWrt configs for Lantiq SoC */
#include "openwrt-lantiq-common.h"

#define CONFIG_ENV_UPDATE_UBOOT_NOR \
"update-uboot-nor=run load-uboot-norspl-lzo write-uboot-nor\0"

#define CONFIG_ENV_UPDATE_UBOOT_SF \
"update-uboot-sf=run load-uboot-sfspl-lzo write-uboot-sf\0"

#define CONFIG_ENV_UPDATE_UBOOT_NAND \
"update-uboot-nand=run load-uboot-nandspl-lzo write-uboot-nand\0"

#define CONFIG_EXTRA_ENV_SETTINGS \
CONFIG_ENV_LANTIQ_DEFAULTS \
CONFIG_ENV_UPDATE_UBOOT_NOR

#endif /* __CONFIG_H */