ARM: sunxi: smp: Move assembly code into a file
Move the assembly code for cluster cache enabling and resuming into an assembly file instead of having it directly in C code. Remove the CFLAGS because we are using the ARM directive "arch" instead. Signed-off-by: Mylène Josserand <mylene.josserand@bootlin.com> Acked-by: Maxime Ripard <maxime.ripard@bootlin.com> Signed-off-by: Maxime Ripard <maxime.ripard@bootlin.com>
This commit is contained in:

committad av
Maxime Ripard

förälder
17e49a9e90
incheckning
dff052ccf3
@@ -72,6 +72,9 @@ static void __iomem *cpucfg_base;
|
||||
static void __iomem *prcm_base;
|
||||
static void __iomem *sram_b_smp_base;
|
||||
|
||||
extern void sunxi_mc_smp_secondary_startup(void);
|
||||
extern void sunxi_mc_smp_resume(void);
|
||||
|
||||
static bool sunxi_core_is_cortex_a15(unsigned int core, unsigned int cluster)
|
||||
{
|
||||
struct device_node *node;
|
||||
@@ -300,74 +303,7 @@ static void sunxi_cluster_cache_disable_without_axi(void)
|
||||
}
|
||||
|
||||
static int sunxi_mc_smp_cpu_table[SUNXI_NR_CLUSTERS][SUNXI_CPUS_PER_CLUSTER];
|
||||
static int sunxi_mc_smp_first_comer;
|
||||
|
||||
/*
|
||||
* Enable cluster-level coherency, in preparation for turning on the MMU.
|
||||
*
|
||||
* Also enable regional clock gating and L2 data latency settings for
|
||||
* Cortex-A15. These settings are from the vendor kernel.
|
||||
*/
|
||||
static void __naked sunxi_mc_smp_cluster_cache_enable(void)
|
||||
{
|
||||
asm volatile (
|
||||
"mrc p15, 0, r1, c0, c0, 0\n"
|
||||
"movw r2, #" __stringify(ARM_CPU_PART_MASK & 0xffff) "\n"
|
||||
"movt r2, #" __stringify(ARM_CPU_PART_MASK >> 16) "\n"
|
||||
"and r1, r1, r2\n"
|
||||
"movw r2, #" __stringify(ARM_CPU_PART_CORTEX_A15 & 0xffff) "\n"
|
||||
"movt r2, #" __stringify(ARM_CPU_PART_CORTEX_A15 >> 16) "\n"
|
||||
"cmp r1, r2\n"
|
||||
"bne not_a15\n"
|
||||
|
||||
/* The following is Cortex-A15 specific */
|
||||
|
||||
/* ACTLR2: Enable CPU regional clock gates */
|
||||
"mrc p15, 1, r1, c15, c0, 4\n"
|
||||
"orr r1, r1, #(0x1<<31)\n"
|
||||
"mcr p15, 1, r1, c15, c0, 4\n"
|
||||
|
||||
/* L2ACTLR */
|
||||
"mrc p15, 1, r1, c15, c0, 0\n"
|
||||
/* Enable L2, GIC, and Timer regional clock gates */
|
||||
"orr r1, r1, #(0x1<<26)\n"
|
||||
/* Disable clean/evict from being pushed to external */
|
||||
"orr r1, r1, #(0x1<<3)\n"
|
||||
"mcr p15, 1, r1, c15, c0, 0\n"
|
||||
|
||||
/* L2CTRL: L2 data RAM latency */
|
||||
"mrc p15, 1, r1, c9, c0, 2\n"
|
||||
"bic r1, r1, #(0x7<<0)\n"
|
||||
"orr r1, r1, #(0x3<<0)\n"
|
||||
"mcr p15, 1, r1, c9, c0, 2\n"
|
||||
|
||||
/* End of Cortex-A15 specific setup */
|
||||
"not_a15:\n"
|
||||
|
||||
/* Get value of sunxi_mc_smp_first_comer */
|
||||
"adr r1, first\n"
|
||||
"ldr r0, [r1]\n"
|
||||
"ldr r0, [r1, r0]\n"
|
||||
|
||||
/* Skip cci_enable_port_for_self if not first comer */
|
||||
"cmp r0, #0\n"
|
||||
"bxeq lr\n"
|
||||
"b cci_enable_port_for_self\n"
|
||||
|
||||
".align 2\n"
|
||||
"first: .word sunxi_mc_smp_first_comer - .\n"
|
||||
);
|
||||
}
|
||||
|
||||
static void __naked sunxi_mc_smp_secondary_startup(void)
|
||||
{
|
||||
asm volatile(
|
||||
"bl sunxi_mc_smp_cluster_cache_enable\n"
|
||||
"b secondary_startup"
|
||||
/* Let compiler know about sunxi_mc_smp_cluster_cache_enable */
|
||||
:: "i" (sunxi_mc_smp_cluster_cache_enable)
|
||||
);
|
||||
}
|
||||
int sunxi_mc_smp_first_comer;
|
||||
|
||||
static DEFINE_SPINLOCK(boot_lock);
|
||||
|
||||
@@ -637,16 +573,6 @@ static bool __init sunxi_mc_smp_cpu_table_init(void)
|
||||
*/
|
||||
typedef typeof(cpu_reset) phys_reset_t;
|
||||
|
||||
static void __init __naked sunxi_mc_smp_resume(void)
|
||||
{
|
||||
asm volatile(
|
||||
"bl sunxi_mc_smp_cluster_cache_enable\n"
|
||||
"b cpu_resume"
|
||||
/* Let compiler know about sunxi_mc_smp_cluster_cache_enable */
|
||||
:: "i" (sunxi_mc_smp_cluster_cache_enable)
|
||||
);
|
||||
}
|
||||
|
||||
static int __init nocache_trampoline(unsigned long __unused)
|
||||
{
|
||||
phys_reset_t phys_reset;
|
||||
|
Referens i nytt ärende
Block a user