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:
Stefan Roese 2015-04-25 06:29:51 +02:00 committed by Luka Perkov
parent 880b15a37b
commit 9c6d3b7b66
3 changed files with 73 additions and 16 deletions

View file

@ -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

View file

@ -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

View file

@ -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))