143 lines
3.0 KiB
ArmAsm
143 lines
3.0 KiB
ArmAsm
/*
|
|
* Copyright (C) 2010 Jaccon Bastiaansen <jaccon.bastiaansen@gmail.com>
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License as
|
|
* published by the Free Software Foundation; either version 2 of
|
|
* the License, or (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
*/
|
|
|
|
#include <config.h>
|
|
#include <sizes.h>
|
|
#include <asm-generic/memory_layout.h>
|
|
#include <mach/imx21-regs.h>
|
|
#include <asm/barebox-arm-head.h>
|
|
|
|
.section ".text_bare_init","ax"
|
|
|
|
.globl barebox_arm_reset_vector
|
|
barebox_arm_reset_vector:
|
|
|
|
arm_cpu_lowlevel_init r0
|
|
|
|
/*
|
|
* Initialize the AHB-Lite IP Interface (AIPI) module (to enable access to
|
|
* on chip peripherals) as described in section 7.2 of rev3 of the i.MX21
|
|
* reference manual.
|
|
*/
|
|
ldr r0, =MX21_AIPI_BASE_ADDR + MX21_AIPI1_PSR0
|
|
ldr r1, =0x00040304
|
|
str r1, [r0]
|
|
ldr r0, =MX21_AIPI_BASE_ADDR + MX21_AIPI1_PSR1
|
|
ldr r1, =0xfffbfcfb
|
|
str r1, [r0]
|
|
|
|
ldr r0, =MX21_AIPI_BASE_ADDR + MX21_AIPI2_PSR0
|
|
ldr r1, =0x3ffc0000
|
|
str r1, [r0]
|
|
ldr r0, =MX21_AIPI_BASE_ADDR + MX21_AIPI2_PSR1
|
|
ldr r1, =0xffffffff
|
|
str r1, [r0]
|
|
|
|
/*
|
|
* Configure CPU core clock (266MHz), peripheral clock (133MHz) and enable
|
|
* the clock to peripherals.
|
|
*/
|
|
ldr r0, =MX21_CCM_BASE_ADDR + MX21_CSCR
|
|
ldr r1, =0x17180607
|
|
str r1, [r0]
|
|
|
|
ldr r0, =MX21_CCM_BASE_ADDR + MX21_PCCR1
|
|
ldr r1, =0x0e000000
|
|
str r1, [r0]
|
|
|
|
|
|
/*
|
|
* SDRAM and SDRAM controller configuration
|
|
*/
|
|
|
|
/*
|
|
* CSD1 not required, because the MX21ADS board only contains 64Mbyte.
|
|
* CS3 can therefore be made available.
|
|
*/
|
|
ldr r0, =MX21_SYSCTRL_BASE_ADDR + MX21_FMCR
|
|
ldr r1, =0xffffffc9
|
|
str r1, [r0]
|
|
|
|
/* Skip SDRAM initialization if we run from RAM */
|
|
cmp pc, #0xc0000000
|
|
bls 1f
|
|
cmp pc, #0xc8000000
|
|
bhi 1f
|
|
|
|
b ret
|
|
1:
|
|
|
|
/* Precharge */
|
|
ldr r0, =MX21_X_MEMC_BASE_ADDR + MX21_SDCTL0
|
|
ldr r1, =0x92120300
|
|
str r1, [r0]
|
|
ldr r2, =0xc0200000
|
|
ldr r1, [r2]
|
|
|
|
bl mem_delay
|
|
|
|
/* Auto refresh */
|
|
ldr r1, =0xa2120300
|
|
str r1, [r0]
|
|
ldr r2, =0xc0000000
|
|
ldr r1, [r2]
|
|
ldr r1, [r2]
|
|
ldr r1, [r2]
|
|
ldr r1, [r2]
|
|
ldr r1, [r2]
|
|
ldr r1, [r2]
|
|
ldr r1, [r2]
|
|
ldr r1, [r2]
|
|
|
|
/* Set mode register */
|
|
ldr r1, =0xB2120300
|
|
str r1, [r0]
|
|
ldr r1, =0xC0119800
|
|
ldr r2, [r1]
|
|
|
|
bl mem_delay
|
|
|
|
/* Back to Normal Mode */
|
|
ldr r1, =0x8212F339
|
|
str r1, [r0]
|
|
|
|
/* Set NFC_CLK to 24MHz */
|
|
ldr r0, =MX21_CCM_BASE_ADDR + MX21_PCDR0
|
|
ldr r1, =0x6419a007
|
|
str r1, [r0]
|
|
|
|
#ifdef CONFIG_NAND_IMX_BOOT
|
|
/* Setup a temporary stack in SRAM */
|
|
ldr sp, =MX21_IRAM_BASE_ADDR + MX21_IRAM_SIZE - 4
|
|
|
|
b imx21_barebox_boot_nand_external
|
|
#endif /* CONFIG_NAND_IMX_BOOT */
|
|
|
|
ret:
|
|
mov r0, #0xc0000000
|
|
mov r1, #SZ_64M
|
|
mov r2, #0
|
|
b barebox_arm_entry
|
|
|
|
/*
|
|
* spin for a while. we need to wait at least 200 usecs.
|
|
*/
|
|
mem_delay:
|
|
mov r4, #0x4000
|
|
spin: subs r4, r4, #1
|
|
bne spin
|
|
mov pc, lr
|
|
|