mirror of https://gitee.com/openkylin/linux.git
57 lines
1.5 KiB
C
57 lines
1.5 KiB
C
/*
|
|
* Copyright (C) 2009-2010 Pengutronix
|
|
* Sascha Hauer <s.hauer@pengutronix.de>
|
|
* Juergen Beisert <j.beisert@pengutronix.de>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it under
|
|
* the terms of the GNU General Public License version 2 as published by the
|
|
* Free Software Foundation.
|
|
*/
|
|
|
|
#include <linux/init.h>
|
|
#include <linux/err.h>
|
|
#include <linux/kernel.h>
|
|
|
|
#include <asm/hardware/cache-l2x0.h>
|
|
|
|
#include <mach/hardware.h>
|
|
|
|
static int mxc_init_l2x0(void)
|
|
{
|
|
void __iomem *l2x0_base;
|
|
void __iomem *clkctl_base;
|
|
|
|
if (!cpu_is_mx31() && !cpu_is_mx35())
|
|
return 0;
|
|
|
|
/*
|
|
* First of all, we must repair broken chip settings. There are some
|
|
* i.MX35 CPUs in the wild, comming with bogus L2 cache settings. These
|
|
* misconfigured CPUs will run amok immediately when the L2 cache gets enabled.
|
|
* Workaraound is to setup the correct register setting prior enabling the
|
|
* L2 cache. This should not hurt already working CPUs, as they are using the
|
|
* same value.
|
|
*/
|
|
#define L2_MEM_VAL 0x10
|
|
|
|
clkctl_base = ioremap(MX35_CLKCTL_BASE_ADDR, 4096);
|
|
if (clkctl_base != NULL) {
|
|
writel(0x00000515, clkctl_base + L2_MEM_VAL);
|
|
iounmap(clkctl_base);
|
|
} else {
|
|
pr_err("L2 cache: Cannot fix timing. Trying to continue without\n");
|
|
}
|
|
|
|
l2x0_base = ioremap(MX3x_L2CC_BASE_ADDR, 4096);
|
|
if (IS_ERR(l2x0_base)) {
|
|
printk(KERN_ERR "remapping L2 cache area failed with %ld\n",
|
|
PTR_ERR(l2x0_base));
|
|
return 0;
|
|
}
|
|
|
|
l2x0_init(l2x0_base, 0x00030024, 0x00000000);
|
|
|
|
return 0;
|
|
}
|
|
arch_initcall(mxc_init_l2x0);
|