/* * Copyright (C) 2001 Deep Blue Solutions Ltd. * Copyright 2004-2009 Freescale Semiconductor, Inc. All Rights Reserved. * * 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. * */ /*! * @file mach-mx37/cpu.c * * @brief This file contains the CPU initialization code. * * @ingroup MSL_MX37 */ #include #include #include #include #include #include /*! * CPU initialization. It is called by fixup_mxc_board() */ void __init mxc_cpu_init(void) { if (!system_rev) { mxc_set_system_rev(0x37, CHIP_REV_1_0); } } #define MXC_ARM1176_BASE IO_ADDRESS(ARM1176_BASE_ADDR) /*! * Post CPU init code * * @return 0 always */ static int __init post_cpu_init(void) { u32 reg; void *l2_base; volatile unsigned long aips_reg; /* Set ALP bits to 000. Set ALP_EN bit in Arm Memory Controller reg. */ reg = __raw_readl(MXC_ARM1176_BASE + 0x1C); reg = 0x8; __raw_writel(reg, MXC_ARM1176_BASE + 0x1C); /* Initialize L2 cache */ l2_base = ioremap(L2CC_BASE_ADDR, SZ_4K); if (l2_base) { l2x0_init(l2_base, 0x0003001B, 0x00000000); } __raw_writel(0x0, IO_ADDRESS(AIPS1_BASE_ADDR + 0x40)); __raw_writel(0x0, IO_ADDRESS(AIPS1_BASE_ADDR + 0x44)); __raw_writel(0x0, IO_ADDRESS(AIPS1_BASE_ADDR + 0x48)); __raw_writel(0x0, IO_ADDRESS(AIPS1_BASE_ADDR + 0x4C)); aips_reg = __raw_readl(IO_ADDRESS(AIPS1_BASE_ADDR + 0x50)); aips_reg &= 0x00FFFFFF; __raw_writel(aips_reg, IO_ADDRESS(AIPS1_BASE_ADDR + 0x50)); __raw_writel(0x0, IO_ADDRESS(AIPS2_BASE_ADDR + 0x40)); __raw_writel(0x0, IO_ADDRESS(AIPS2_BASE_ADDR + 0x44)); __raw_writel(0x0, IO_ADDRESS(AIPS2_BASE_ADDR + 0x48)); __raw_writel(0x0, IO_ADDRESS(AIPS2_BASE_ADDR + 0x4C)); aips_reg = __raw_readl(IO_ADDRESS(AIPS2_BASE_ADDR + 0x50)); aips_reg &= 0x00FFFFFF; __raw_writel(aips_reg, IO_ADDRESS(AIPS2_BASE_ADDR + 0x50)); return 0; } postcore_initcall(post_cpu_init);