2018-05-06 21:58:06 +00:00
|
|
|
// SPDX-License-Identifier: GPL-2.0+
|
2016-06-05 00:43:00 +00:00
|
|
|
/*
|
|
|
|
* (C) Copyright 2014-2016, Freescale Semiconductor, Inc.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <common.h>
|
2019-11-14 19:57:32 +00:00
|
|
|
#include <cpu_func.h>
|
2020-05-10 17:40:02 +00:00
|
|
|
#include <init.h>
|
2020-05-10 17:39:56 +00:00
|
|
|
#include <asm/cache.h>
|
2016-06-05 00:43:00 +00:00
|
|
|
#include <asm/io.h>
|
|
|
|
#include <asm/system.h>
|
|
|
|
#include <asm/armv8/mmu.h>
|
|
|
|
#include <asm/io.h>
|
|
|
|
#include <asm/arch/mc_me_regs.h>
|
2020-05-10 17:40:13 +00:00
|
|
|
#include <linux/bitops.h>
|
2016-06-05 00:43:00 +00:00
|
|
|
#include "cpu.h"
|
|
|
|
|
|
|
|
u32 cpu_mask(void)
|
|
|
|
{
|
|
|
|
return readl(MC_ME_CS);
|
|
|
|
}
|
|
|
|
|
2019-05-03 13:41:00 +00:00
|
|
|
#if !CONFIG_IS_ENABLED(SYS_DCACHE_OFF)
|
2016-06-05 00:43:00 +00:00
|
|
|
|
|
|
|
#define S32V234_IRAM_BASE 0x3e800000UL
|
|
|
|
#define S32V234_IRAM_SIZE 0x800000UL
|
|
|
|
#define S32V234_DRAM_BASE1 0x80000000UL
|
|
|
|
#define S32V234_DRAM_SIZE1 0x40000000UL
|
|
|
|
#define S32V234_DRAM_BASE2 0xC0000000UL
|
|
|
|
#define S32V234_DRAM_SIZE2 0x20000000UL
|
|
|
|
#define S32V234_PERIPH_BASE 0x40000000UL
|
|
|
|
#define S32V234_PERIPH_SIZE 0x40000000UL
|
|
|
|
|
|
|
|
static struct mm_region s32v234_mem_map[] = {
|
|
|
|
{
|
2016-06-24 23:46:22 +00:00
|
|
|
.virt = S32V234_IRAM_BASE,
|
|
|
|
.phys = S32V234_IRAM_BASE,
|
2016-06-05 00:43:00 +00:00
|
|
|
.size = S32V234_IRAM_SIZE,
|
|
|
|
.attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
|
|
|
|
PTE_BLOCK_OUTER_SHARE
|
|
|
|
}, {
|
2016-06-24 23:46:22 +00:00
|
|
|
.virt = S32V234_DRAM_BASE1,
|
|
|
|
.phys = S32V234_DRAM_BASE1,
|
2016-06-05 00:43:00 +00:00
|
|
|
.size = S32V234_DRAM_SIZE1,
|
|
|
|
.attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
|
|
|
|
PTE_BLOCK_OUTER_SHARE
|
|
|
|
}, {
|
2016-06-24 23:46:22 +00:00
|
|
|
.virt = S32V234_PERIPH_BASE,
|
|
|
|
.phys = S32V234_PERIPH_BASE,
|
2016-06-05 00:43:00 +00:00
|
|
|
.size = S32V234_PERIPH_SIZE,
|
|
|
|
.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) |
|
|
|
|
PTE_BLOCK_NON_SHARE
|
|
|
|
/* TODO: Do we need these? */
|
|
|
|
/* | PTE_BLOCK_PXN | PTE_BLOCK_UXN */
|
|
|
|
}, {
|
2016-06-24 23:46:22 +00:00
|
|
|
.virt = S32V234_DRAM_BASE2,
|
|
|
|
.phys = S32V234_DRAM_BASE2,
|
2016-06-05 00:43:00 +00:00
|
|
|
.size = S32V234_DRAM_SIZE2,
|
|
|
|
.attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL_NC) |
|
|
|
|
PTE_BLOCK_OUTER_SHARE
|
|
|
|
}, {
|
|
|
|
/* List terminator */
|
|
|
|
0,
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
struct mm_region *mem_map = s32v234_mem_map;
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Return the number of cores on this SOC.
|
|
|
|
*/
|
|
|
|
int cpu_numcores(void)
|
|
|
|
{
|
|
|
|
int numcores;
|
|
|
|
u32 mask;
|
|
|
|
|
|
|
|
mask = cpu_mask();
|
|
|
|
numcores = hweight32(cpu_mask());
|
|
|
|
|
|
|
|
/* Verify if M4 is deactivated */
|
|
|
|
if (mask & 0x1)
|
|
|
|
numcores--;
|
|
|
|
|
|
|
|
return numcores;
|
|
|
|
}
|
|
|
|
|
|
|
|
#if defined(CONFIG_ARCH_EARLY_INIT_R)
|
|
|
|
int arch_early_init_r(void)
|
|
|
|
{
|
|
|
|
int rv;
|
|
|
|
asm volatile ("dsb sy");
|
|
|
|
rv = fsl_s32v234_wake_seconday_cores();
|
|
|
|
|
|
|
|
if (rv)
|
|
|
|
printf("Did not wake secondary cores\n");
|
|
|
|
|
|
|
|
asm volatile ("sev");
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
#endif /* CONFIG_ARCH_EARLY_INIT_R */
|