mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-14 08:57:58 +00:00
arm: mvebu: Add basic Armada 38x support
This patch adds support for the Marvell Armada 38x SoC family. Supported peripherals are: - UART - Ethernet (mvneta) - I2C - SPI (including SPI NOR flash) Tested on Marvell DB-88F6820-GP evaluation board. Signed-off-by: Stefan Roese <sr@denx.de> Tested-by: Kevin Smith <kevin.smith@elecsyscorp.com> Tested-by: Dirk Eibach <dirk.eibach@gdsys.cc>
This commit is contained in:
parent
880b15a37b
commit
9c6d3b7b66
3 changed files with 73 additions and 16 deletions
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2014 Stefan Roese <sr@denx.de>
|
* Copyright (C) 2014-2015 Stefan Roese <sr@denx.de>
|
||||||
*
|
*
|
||||||
* SPDX-License-Identifier: GPL-2.0+
|
* SPDX-License-Identifier: GPL-2.0+
|
||||||
*/
|
*/
|
||||||
|
@ -40,6 +40,20 @@ void reset_cpu(unsigned long ignored)
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int mvebu_soc_family(void)
|
||||||
|
{
|
||||||
|
u16 devid = (readl(MVEBU_REG_PCIE_DEVID) >> 16) & 0xffff;
|
||||||
|
|
||||||
|
if (devid == SOC_MV78460_ID)
|
||||||
|
return MVEBU_SOC_AXP;
|
||||||
|
|
||||||
|
if (devid == SOC_88F6810_ID || devid == SOC_88F6820_ID ||
|
||||||
|
devid == SOC_88F6828_ID)
|
||||||
|
return MVEBU_SOC_A38X;
|
||||||
|
|
||||||
|
return MVEBU_SOC_UNKNOWN;
|
||||||
|
}
|
||||||
|
|
||||||
#if defined(CONFIG_DISPLAY_CPUINFO)
|
#if defined(CONFIG_DISPLAY_CPUINFO)
|
||||||
int print_cpuinfo(void)
|
int print_cpuinfo(void)
|
||||||
{
|
{
|
||||||
|
@ -52,11 +66,21 @@ int print_cpuinfo(void)
|
||||||
case SOC_MV78460_ID:
|
case SOC_MV78460_ID:
|
||||||
puts("MV78460-");
|
puts("MV78460-");
|
||||||
break;
|
break;
|
||||||
|
case SOC_88F6810_ID:
|
||||||
|
puts("MV88F6810-");
|
||||||
|
break;
|
||||||
|
case SOC_88F6820_ID:
|
||||||
|
puts("MV88F6820-");
|
||||||
|
break;
|
||||||
|
case SOC_88F6828_ID:
|
||||||
|
puts("MV88F6828-");
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
puts("Unknown-");
|
puts("Unknown-");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (mvebu_soc_family() == MVEBU_SOC_AXP) {
|
||||||
switch (revid) {
|
switch (revid) {
|
||||||
case 1:
|
case 1:
|
||||||
puts("A0\n");
|
puts("A0\n");
|
||||||
|
@ -65,9 +89,24 @@ int print_cpuinfo(void)
|
||||||
puts("B0\n");
|
puts("B0\n");
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
puts("??\n");
|
printf("?? (%x)\n", revid);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mvebu_soc_family() == MVEBU_SOC_A38X) {
|
||||||
|
switch (revid) {
|
||||||
|
case MV_88F68XX_Z1_ID:
|
||||||
|
puts("Z1\n");
|
||||||
|
break;
|
||||||
|
case MV_88F68XX_A0_ID:
|
||||||
|
puts("A0\n");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
printf("?? (%x)\n", revid);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -145,11 +184,13 @@ int arch_cpu_init(void)
|
||||||
*/
|
*/
|
||||||
mvebu_mbus_probe(NULL, 0);
|
mvebu_mbus_probe(NULL, 0);
|
||||||
|
|
||||||
|
if (mvebu_soc_family() == MVEBU_SOC_AXP) {
|
||||||
/*
|
/*
|
||||||
* Now the SDRAM access windows can be reconfigured using
|
* Now the SDRAM access windows can be reconfigured using
|
||||||
* the information in the SDRAM scratch pad registers
|
* the information in the SDRAM scratch pad registers
|
||||||
*/
|
*/
|
||||||
update_sdram_window_sizes();
|
update_sdram_window_sizes();
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Finally the mbus windows can be configured with the
|
* Finally the mbus windows can be configured with the
|
||||||
|
|
|
@ -56,6 +56,12 @@ enum cpu_attrib {
|
||||||
CPU_ATTR_DEV_CS3 = 0x37,
|
CPU_ATTR_DEV_CS3 = 0x37,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum {
|
||||||
|
MVEBU_SOC_AXP,
|
||||||
|
MVEBU_SOC_A38X,
|
||||||
|
MVEBU_SOC_UNKNOWN,
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Default Device Address MAP BAR values
|
* Default Device Address MAP BAR values
|
||||||
*/
|
*/
|
||||||
|
@ -106,6 +112,7 @@ unsigned int mvebu_sdram_bar(enum memory_bank bank);
|
||||||
unsigned int mvebu_sdram_bs(enum memory_bank bank);
|
unsigned int mvebu_sdram_bs(enum memory_bank bank);
|
||||||
void mvebu_sdram_size_adjust(enum memory_bank bank);
|
void mvebu_sdram_size_adjust(enum memory_bank bank);
|
||||||
int mvebu_mbus_probe(struct mbus_win windows[], int count);
|
int mvebu_mbus_probe(struct mbus_win windows[], int count);
|
||||||
|
int mvebu_soc_family(void);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Highspeed SERDES PHY config init, ported from bin_hdr
|
* Highspeed SERDES PHY config init, ported from bin_hdr
|
||||||
|
|
|
@ -12,6 +12,13 @@
|
||||||
#define _MVEBU_SOC_H
|
#define _MVEBU_SOC_H
|
||||||
|
|
||||||
#define SOC_MV78460_ID 0x7846
|
#define SOC_MV78460_ID 0x7846
|
||||||
|
#define SOC_88F6810_ID 0x6810
|
||||||
|
#define SOC_88F6820_ID 0x6820
|
||||||
|
#define SOC_88F6828_ID 0x6828
|
||||||
|
|
||||||
|
/* A38x revisions */
|
||||||
|
#define MV_88F68XX_Z1_ID 0x0
|
||||||
|
#define MV_88F68XX_A0_ID 0x4
|
||||||
|
|
||||||
/* TCLK Core Clock definition */
|
/* TCLK Core Clock definition */
|
||||||
#ifndef CONFIG_SYS_TCLK
|
#ifndef CONFIG_SYS_TCLK
|
||||||
|
@ -25,6 +32,8 @@
|
||||||
#define MVEBU_REGISTER(x) (SOC_REGS_PHY_BASE + x)
|
#define MVEBU_REGISTER(x) (SOC_REGS_PHY_BASE + x)
|
||||||
|
|
||||||
#define MVEBU_SDRAM_SCRATCH (MVEBU_REGISTER(0x01504))
|
#define MVEBU_SDRAM_SCRATCH (MVEBU_REGISTER(0x01504))
|
||||||
|
#define MVEBU_L2_CACHE_BASE (MVEBU_REGISTER(0x08000))
|
||||||
|
#define CONFIG_SYS_PL310_BASE MVEBU_L2_CACHE_BASE
|
||||||
#define MVEBU_SPI_BASE (MVEBU_REGISTER(0x10600))
|
#define MVEBU_SPI_BASE (MVEBU_REGISTER(0x10600))
|
||||||
#define MVEBU_TWSI_BASE (MVEBU_REGISTER(0x11000))
|
#define MVEBU_TWSI_BASE (MVEBU_REGISTER(0x11000))
|
||||||
#define MVEBU_UART0_BASE (MVEBU_REGISTER(0x12000))
|
#define MVEBU_UART0_BASE (MVEBU_REGISTER(0x12000))
|
||||||
|
|
Loading…
Reference in a new issue