Add Freescale MCF5307 cpu support. Signed-off-by: Angelo Dureghello <angelo@sysam.it>master
parent
06fd66a4aa
commit
e77e65dfc2
@ -0,0 +1,9 @@ |
|||||||
|
#
|
||||||
|
# (C) Copyright 2014 Angelo Dureghello <angelo@sysam.it>
|
||||||
|
#
|
||||||
|
# SPDX-License-Identifier: GPL-2.0+
|
||||||
|
#
|
||||||
|
|
||||||
|
extra-y = start.o
|
||||||
|
obj-y = interrupts.o cpu.o speed.o cpu_init.o
|
||||||
|
|
@ -0,0 +1,12 @@ |
|||||||
|
#
|
||||||
|
# (C) Copyright 2014 Angelo Dureghello <angelo@sysam.it>
|
||||||
|
#
|
||||||
|
# SPDX-License-Identifier: GPL-2.0+
|
||||||
|
#
|
||||||
|
|
||||||
|
cfg=$(srctree)/include/configs/$(CONFIG_SYS_CONFIG_NAME:"%"=%).h
|
||||||
|
is5307:=$(shell grep CONFIG_M5307 $(cfg))
|
||||||
|
|
||||||
|
ifneq (,$(findstring CONFIG_M5307,$(is5307))) |
||||||
|
PLATFORM_CPPFLAGS += -mcpu=5307
|
||||||
|
endif |
@ -0,0 +1,36 @@ |
|||||||
|
/*
|
||||||
|
* (C) Copyright 2014 Angelo Dureghello <angelo@sysam.it> |
||||||
|
* |
||||||
|
* SPDX-License-Identifier: GPL-2.0+ |
||||||
|
* |
||||||
|
*/ |
||||||
|
|
||||||
|
#include <common.h> |
||||||
|
#include <asm/immap.h> |
||||||
|
#include <asm/io.h> |
||||||
|
|
||||||
|
#ifdef CONFIG_M5307 |
||||||
|
int do_reset(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) |
||||||
|
{ |
||||||
|
sim_t *sim = (sim_t *)(MMAP_SIM); |
||||||
|
|
||||||
|
/* enable watchdog/reset, set timeout to 0 and wait */ |
||||||
|
out_8(&sim->sypcr, SYPCR_SWE | SYPCR_SWRI); |
||||||
|
|
||||||
|
/* wait for watchdog reset */ |
||||||
|
for (;;) |
||||||
|
; |
||||||
|
|
||||||
|
/* we don't return! */ |
||||||
|
return 0; |
||||||
|
} |
||||||
|
|
||||||
|
int checkcpu(void) |
||||||
|
{ |
||||||
|
char buf[32]; |
||||||
|
|
||||||
|
printf("CPU: Freescale Coldfire MCF5307 at %s MHz\n", |
||||||
|
strmhz(buf, CONFIG_SYS_CPU_CLK)); |
||||||
|
return 0; |
||||||
|
} |
||||||
|
#endif |
@ -0,0 +1,160 @@ |
|||||||
|
/*
|
||||||
|
* (C) Copyright 2014 Angelo Dureghello <angelo@sysam.it> |
||||||
|
* |
||||||
|
* SPDX-License-Identifier: GPL-2.0+ |
||||||
|
* |
||||||
|
*/ |
||||||
|
|
||||||
|
#include <common.h> |
||||||
|
#include <watchdog.h> |
||||||
|
#include <asm/immap.h> |
||||||
|
#include <asm/io.h> |
||||||
|
|
||||||
|
#if defined(CONFIG_M5307) |
||||||
|
/*
|
||||||
|
* Simple mcf5307 chip select module init. |
||||||
|
* |
||||||
|
* Note: this chip has an issue reported in the device "errata": |
||||||
|
* MCF5307ER Rev 4.2 reports @ section 35: |
||||||
|
* Corrupted Return PC in Exception Stack Frame |
||||||
|
* When processing an autovectored interrupt an error can occur that |
||||||
|
* causes 0xFFFFFFFF to be written as the return PC value in the |
||||||
|
* exception stack frame. The problem is caused by a conflict between |
||||||
|
* an internal autovector access and a chip select mapped to the IACK |
||||||
|
* address space (0xFFFFXXXX). |
||||||
|
* Workaround: |
||||||
|
* Set the C/I bit in the chip select mask register (CSMR) for the |
||||||
|
* chip select that is mapped to 0xFFFFXXXX. |
||||||
|
* This will prevent the chip select from asserting for IACK accesses. |
||||||
|
*/ |
||||||
|
|
||||||
|
#define MCF5307_SP_ERR_FIX(cs_base, mask) \ |
||||||
|
do { \
|
||||||
|
if (((cs_base<<16)+(in_be32(&mask)&0xffff0000)) >= \
|
||||||
|
0xffff0000) \
|
||||||
|
setbits_be32(&mask, CSMR_CI); \
|
||||||
|
} while (0) |
||||||
|
|
||||||
|
void init_csm(void) |
||||||
|
{ |
||||||
|
csm_t *csm = (csm_t *)(MMAP_CSM); |
||||||
|
|
||||||
|
#if (defined(CONFIG_SYS_CS0_BASE) && defined(CONFIG_SYS_CS0_MASK) && \ |
||||||
|
defined(CONFIG_SYS_CS0_CTRL)) |
||||||
|
out_be16(&csm->csar0, CONFIG_SYS_CS0_BASE); |
||||||
|
out_be32(&csm->csmr0, CONFIG_SYS_CS0_MASK); |
||||||
|
out_be16(&csm->cscr0, CONFIG_SYS_CS0_CTRL); |
||||||
|
MCF5307_SP_ERR_FIX(CONFIG_SYS_CS0_BASE, csm->csmr0); |
||||||
|
#else |
||||||
|
#warning "Chip Select 0 are not initialized/used" |
||||||
|
#endif |
||||||
|
#if (defined(CONFIG_SYS_CS1_BASE) && defined(CONFIG_SYS_CS1_MASK) && \ |
||||||
|
defined(CONFIG_SYS_CS1_CTRL)) |
||||||
|
out_be16(&csm->csar1, CONFIG_SYS_CS1_BASE); |
||||||
|
out_be32(&csm->csmr1, CONFIG_SYS_CS1_MASK); |
||||||
|
out_be16(&csm->cscr1, CONFIG_SYS_CS1_CTRL); |
||||||
|
MCF5307_SP_ERR_FIX(CONFIG_SYS_CS1_BASE, csm->csmr1); |
||||||
|
#endif |
||||||
|
#if (defined(CONFIG_SYS_CS2_BASE) && defined(CONFIG_SYS_CS2_MASK) && \ |
||||||
|
defined(CONFIG_SYS_CS2_CTRL)) |
||||||
|
out_be16(&csm->csar2, CONFIG_SYS_CS2_BASE); |
||||||
|
out_be32(&csm->csmr2, CONFIG_SYS_CS2_MASK); |
||||||
|
out_be16(&csm->cscr2, CONFIG_SYS_CS2_CTRL); |
||||||
|
MCF5307_SP_ERR_FIX(CONFIG_SYS_CS2_BASE, csm->csmr2); |
||||||
|
#endif |
||||||
|
#if (defined(CONFIG_SYS_CS3_BASE) && defined(CONFIG_SYS_CS3_MASK) && \ |
||||||
|
defined(CONFIG_SYS_CS3_CTRL)) |
||||||
|
out_be16(&csm->csar3, CONFIG_SYS_CS3_BASE); |
||||||
|
out_be32(&csm->csmr3, CONFIG_SYS_CS3_MASK); |
||||||
|
out_be16(&csm->cscr3, CONFIG_SYS_CS3_CTRL); |
||||||
|
MCF5307_SP_ERR_FIX(CONFIG_SYS_CS3_BASE, csm->csmr3); |
||||||
|
#endif |
||||||
|
#if (defined(CONFIG_SYS_CS4_BASE) && defined(CONFIG_SYS_CS4_MASK) && \ |
||||||
|
defined(CONFIG_SYS_CS4_CTRL)) |
||||||
|
out_be16(&csm->csar4, CONFIG_SYS_CS4_BASE); |
||||||
|
out_be32(&csm->csmr4, CONFIG_SYS_CS4_MASK); |
||||||
|
out_be16(&csm->cscr4, CONFIG_SYS_CS4_CTRL); |
||||||
|
MCF5307_SP_ERR_FIX(CONFIG_SYS_CS4_BASE, csm->csmr4); |
||||||
|
#endif |
||||||
|
#if (defined(CONFIG_SYS_CS5_BASE) && defined(CONFIG_SYS_CS5_MASK) && \ |
||||||
|
defined(CONFIG_SYS_CS5_CTRL)) |
||||||
|
out_be16(&csm->csar5, CONFIG_SYS_CS5_BASE); |
||||||
|
out_be32(&csm->csmr5, CONFIG_SYS_CS5_MASK); |
||||||
|
out_be16(&csm->cscr5, CONFIG_SYS_CS5_CTRL); |
||||||
|
MCF5307_SP_ERR_FIX(CONFIG_SYS_CS5_BASE, csm->csmr5); |
||||||
|
#endif |
||||||
|
#if (defined(CONFIG_SYS_CS6_BASE) && defined(CONFIG_SYS_CS6_MASK) && \ |
||||||
|
defined(CONFIG_SYS_CS6_CTRL)) |
||||||
|
out_be16(&csm->csar6, CONFIG_SYS_CS6_BASE); |
||||||
|
out_be32(&csm->csmr6, CONFIG_SYS_CS6_MASK); |
||||||
|
out_be16(&csm->cscr6, CONFIG_SYS_CS6_CTRL); |
||||||
|
MCF5307_SP_ERR_FIX(CONFIG_SYS_CS6_BASE, csm->csmr6); |
||||||
|
#endif |
||||||
|
#if (defined(CONFIG_SYS_CS7_BASE) && defined(CONFIG_SYS_CS7_MASK) && \ |
||||||
|
defined(CONFIG_SYS_CS7_CTRL)) |
||||||
|
out_be16(&csm->csar7, CONFIG_SYS_CS7_BASE); |
||||||
|
out_be32(&csm->csmr7, CONFIG_SYS_CS7_MASK); |
||||||
|
out_be16(&csm->cscr7, CONFIG_SYS_CS7_CTRL); |
||||||
|
MCF5307_SP_ERR_FIX(CONFIG_SYS_CS7_BASE, csm->csmr7); |
||||||
|
#endif |
||||||
|
} |
||||||
|
|
||||||
|
/*
|
||||||
|
* Set up the memory map and initialize registers |
||||||
|
*/ |
||||||
|
void cpu_init_f(void) |
||||||
|
{ |
||||||
|
sim_t *sim = (sim_t *)(MMAP_SIM); |
||||||
|
|
||||||
|
out_8(&sim->sypcr, 0x00); |
||||||
|
out_8(&sim->swivr, 0x0f); |
||||||
|
out_8(&sim->swsr, 0x00); |
||||||
|
out_8(&sim->mpark, 0x00); |
||||||
|
|
||||||
|
intctrl_t *icr = (intctrl_t *)(MMAP_INTC); |
||||||
|
|
||||||
|
/* timer 2 not masked */ |
||||||
|
out_be32(&icr->imr, 0xfffffbff); |
||||||
|
|
||||||
|
out_8(&icr->icr0, 0x00); /* sw watchdog */ |
||||||
|
out_8(&icr->icr1, 0x00); /* timer 1 */ |
||||||
|
out_8(&icr->icr2, 0x88); /* timer 2 */ |
||||||
|
out_8(&icr->icr3, 0x00); /* i2c */ |
||||||
|
out_8(&icr->icr4, 0x00); /* uart 0 */ |
||||||
|
out_8(&icr->icr5, 0x00); /* uart 1 */ |
||||||
|
out_8(&icr->icr6, 0x00); /* dma 0 */ |
||||||
|
out_8(&icr->icr7, 0x00); /* dma 1 */ |
||||||
|
out_8(&icr->icr8, 0x00); /* dma 2 */ |
||||||
|
out_8(&icr->icr9, 0x00); /* dma 3 */ |
||||||
|
|
||||||
|
/* Chipselect Init */ |
||||||
|
init_csm(); |
||||||
|
|
||||||
|
/* enable data/instruction cache now */ |
||||||
|
icache_enable(); |
||||||
|
} |
||||||
|
|
||||||
|
/*
|
||||||
|
* initialize higher level parts of CPU like timers |
||||||
|
*/ |
||||||
|
int cpu_init_r(void) |
||||||
|
{ |
||||||
|
return 0; |
||||||
|
} |
||||||
|
|
||||||
|
void uart_port_conf(void) |
||||||
|
{ |
||||||
|
} |
||||||
|
|
||||||
|
void arch_preboot_os(void) |
||||||
|
{ |
||||||
|
/*
|
||||||
|
* OS can change interrupt offsets and are about to boot the OS so |
||||||
|
* we need to make sure we disable all async interrupts. |
||||||
|
*/ |
||||||
|
intctrl_t *icr = (intctrl_t *)(MMAP_INTC); |
||||||
|
|
||||||
|
out_8(&icr->icr1, 0x00); /* timer 1 */ |
||||||
|
out_8(&icr->icr2, 0x00); /* timer 2 */ |
||||||
|
} |
||||||
|
#endif |
@ -0,0 +1,29 @@ |
|||||||
|
/*
|
||||||
|
* (C) Copyright 2014 Angelo Dureghello <angelo@sysam.it> |
||||||
|
* |
||||||
|
* SPDX-License-Identifier: GPL-2.0+ |
||||||
|
* |
||||||
|
*/ |
||||||
|
|
||||||
|
#include <common.h> |
||||||
|
#include <asm/immap.h> |
||||||
|
#include <asm/io.h> |
||||||
|
|
||||||
|
#ifdef CONFIG_M5307 |
||||||
|
int interrupt_init(void) |
||||||
|
{ |
||||||
|
enable_interrupts(); |
||||||
|
|
||||||
|
return 0; |
||||||
|
} |
||||||
|
|
||||||
|
void dtimer_intr_setup(void) |
||||||
|
{ |
||||||
|
intctrl_t *icr = (intctrl_t *)(MMAP_INTC); |
||||||
|
|
||||||
|
/* clearing TIMER2 mask, so enabling the related interrupt */ |
||||||
|
out_be32(&icr->imr, in_be32(&icr->imr) & ~0x00000400); |
||||||
|
/* set TIMER2 interrupt priority */ |
||||||
|
out_8(&icr->icr2, CONFIG_SYS_TMRINTR_PRI); |
||||||
|
} |
||||||
|
#endif |
@ -0,0 +1,23 @@ |
|||||||
|
/*
|
||||||
|
* (C) Copyright 2014 Angelo Dureghello <angelo@sysam.it> |
||||||
|
* |
||||||
|
* SPDX-License-Identifier: GPL-2.0+ |
||||||
|
* |
||||||
|
*/ |
||||||
|
|
||||||
|
#include <common.h> |
||||||
|
#include <asm/processor.h> |
||||||
|
#include <asm/immap.h> |
||||||
|
|
||||||
|
DECLARE_GLOBAL_DATA_PTR; |
||||||
|
|
||||||
|
/* get_clocks() fills in gd->cpu_clock and gd->bus_clk */ |
||||||
|
int get_clocks(void) |
||||||
|
{ |
||||||
|
#if defined(CONFIG_M5307) |
||||||
|
gd->bus_clk = CONFIG_SYS_CLK; |
||||||
|
gd->cpu_clk = CONFIG_SYS_CPU_CLK; |
||||||
|
#endif |
||||||
|
|
||||||
|
return 0; |
||||||
|
} |
@ -0,0 +1,257 @@ |
|||||||
|
/* |
||||||
|
* (C) Copyright 2015 Angelo Dureghello <angelo@sysam.it>
|
||||||
|
* Based on code from Bernhard Kuhn <bkuhn@metrowerks.com>
|
||||||
|
* |
||||||
|
* SPDX-License-Identifier: GPL-2.0+ |
||||||
|
*/ |
||||||
|
|
||||||
|
#include <asm-offsets.h> |
||||||
|
#include <config.h> |
||||||
|
#include "version.h" |
||||||
|
#include <asm/cache.h> |
||||||
|
|
||||||
|
#ifndef CONFIG_IDENT_STRING |
||||||
|
#define CONFIG_IDENT_STRING "" |
||||||
|
#endif |
||||||
|
|
||||||
|
#define _START _start |
||||||
|
#define _FAULT _fault |
||||||
|
|
||||||
|
|
||||||
|
.macro SAVE_ALL
|
||||||
|
move.w #0x2700,%sr; /* disable intrs */
|
||||||
|
subl #60,%sp; /* space for 15 regs */
|
||||||
|
moveml %d0-%d7/%a0-%a6,%sp@
|
||||||
|
.endm |
||||||
|
|
||||||
|
.macro RESTORE_ALL
|
||||||
|
moveml %sp@,%d0-%d7/%a0-%a6;
|
||||||
|
addl #60,%sp; /* space for 15 regs */
|
||||||
|
rte |
||||||
|
.endm |
||||||
|
|
||||||
|
/* If we come from a pre-loader we don't need an initial exception |
||||||
|
* table. |
||||||
|
*/ |
||||||
|
#if !defined(CONFIG_MONITOR_IS_IN_RAM) |
||||||
|
|
||||||
|
.text |
||||||
|
/* |
||||||
|
* Vector table. This is used for initial platform startup. |
||||||
|
* These vectors are to catch any un-intended traps. |
||||||
|
*/ |
||||||
|
_vectors: |
||||||
|
|
||||||
|
/* Flash offset is 0 until we setup CS0 */ |
||||||
|
.long 0x00000000
|
||||||
|
#if defined(CONFIG_M5307) && \ |
||||||
|
(CONFIG_SYS_TEXT_BASE == CONFIG_SYS_INT_FLASH_BASE) |
||||||
|
.long _start - CONFIG_SYS_TEXT_BASE |
||||||
|
#else |
||||||
|
.long _START
|
||||||
|
#endif |
||||||
|
|
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
|
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
|
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
|
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
||||||
|
|
||||||
|
#endif |
||||||
|
|
||||||
|
.text |
||||||
|
.globl _start
|
||||||
|
_start: |
||||||
|
nop |
||||||
|
nop |
||||||
|
move.w #0x2700,%sr |
||||||
|
|
||||||
|
/* set MBAR address + valid flag */ |
||||||
|
move.l #(CONFIG_SYS_MBAR + 1), %d0 |
||||||
|
move.c %d0, %MBAR |
||||||
|
|
||||||
|
move.l #(CONFIG_SYS_INIT_RAM_ADDR + 1), %d0 |
||||||
|
move.c %d0, %RAMBAR |
||||||
|
|
||||||
|
/* DS 4.8.2 (Cache Organization) invalidate and disable cache */ |
||||||
|
move.l #CF_CACR_CINVA, %d0 |
||||||
|
movec %d0, %CACR |
||||||
|
move.l #0, %d0 |
||||||
|
movec %d0, %ACR0 |
||||||
|
movec %d0, %ACR1 |
||||||
|
|
||||||
|
/* |
||||||
|
* if we come from a pre-loader we have no exception table and |
||||||
|
* therefore no VBR to set |
||||||
|
*/ |
||||||
|
#if !defined(CONFIG_MONITOR_IS_IN_RAM) |
||||||
|
move.l #CONFIG_SYS_FLASH_BASE, %d0 |
||||||
|
movec %d0, %VBR |
||||||
|
#endif |
||||||
|
|
||||||
|
/* initialize general use internal ram */ |
||||||
|
move.l #0, %d0 |
||||||
|
move.l #(ICACHE_STATUS), %a1 /* icache */ |
||||||
|
move.l #(DCACHE_STATUS), %a2 /* dcache */ |
||||||
|
move.l %d0, (%a1) |
||||||
|
move.l %d0, (%a2) |
||||||
|
|
||||||
|
/* |
||||||
|
* set stackpointer to internal sram end - 80 |
||||||
|
* (global data struct size + some bytes) |
||||||
|
* get some stackspace for the first c-code, |
||||||
|
*/ |
||||||
|
move.l #(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET), %sp |
||||||
|
clr.l %sp@-
|
||||||
|
|
||||||
|
/* put relocation table address to a5 */ |
||||||
|
move.l #__got_start, %a5 |
||||||
|
|
||||||
|
/* run low-level CPU init code (from flash) */ |
||||||
|
bsr cpu_init_f |
||||||
|
|
||||||
|
/* run low-level board init code (from flash) */ |
||||||
|
bsr board_init_f |
||||||
|
|
||||||
|
/* board_init_f() does not return */ |
||||||
|
|
||||||
|
/*--------------------------------------------------------------------------*/ |
||||||
|
|
||||||
|
/* |
||||||
|
* void relocate_code (addr_sp, gd, addr_moni) |
||||||
|
* |
||||||
|
* This "function" does not return, instead it continues in RAM |
||||||
|
* after relocating the monitor code. |
||||||
|
* |
||||||
|
*/ |
||||||
|
.globl relocate_code
|
||||||
|
relocate_code: |
||||||
|
link.w %a6,#0 |
||||||
|
move.l 8(%a6), %sp /* set new stack pointer */ |
||||||
|
move.l 12(%a6), %d0 /* Save copy of Global Data pointer */ |
||||||
|
move.l 16(%a6), %a0 /* Save copy of Destination Address */ |
||||||
|
|
||||||
|
move.l #CONFIG_SYS_MONITOR_BASE, %a1 |
||||||
|
move.l #__init_end, %a2 |
||||||
|
move.l %a0, %a3 |
||||||
|
/* copy the code to RAM */ |
||||||
|
1: |
||||||
|
move.l (%a1)+, (%a3)+ |
||||||
|
cmp.l %a1,%a2 |
||||||
|
bgt.s 1b |
||||||
|
|
||||||
|
/* |
||||||
|
* We are done. Do not return, instead branch to second part of board |
||||||
|
* initialization, now running from RAM. |
||||||
|
*/ |
||||||
|
move.l %a0, %a1 |
||||||
|
add.l #(in_ram - CONFIG_SYS_MONITOR_BASE), %a1 |
||||||
|
jmp (%a1) |
||||||
|
|
||||||
|
in_ram: |
||||||
|
|
||||||
|
clear_bss: |
||||||
|
/* |
||||||
|
* Now clear BSS segment |
||||||
|
*/ |
||||||
|
move.l %a0, %a1 |
||||||
|
add.l #(_sbss - CONFIG_SYS_MONITOR_BASE), %a1 |
||||||
|
move.l %a0, %d1 |
||||||
|
add.l #(_ebss - CONFIG_SYS_MONITOR_BASE), %d1 |
||||||
|
6: |
||||||
|
clr.l (%a1)+ |
||||||
|
cmp.l %a1,%d1 |
||||||
|
bgt.s 6b |
||||||
|
|
||||||
|
/* |
||||||
|
* fix got table in RAM |
||||||
|
*/ |
||||||
|
move.l %a0, %a1 |
||||||
|
add.l #(__got_start - CONFIG_SYS_MONITOR_BASE), %a1 |
||||||
|
/* * fix got pointer register a5 */ |
||||||
|
move.l %a1,%a5 |
||||||
|
|
||||||
|
move.l %a0, %a2 |
||||||
|
add.l #(__got_end - CONFIG_SYS_MONITOR_BASE), %a2 |
||||||
|
|
||||||
|
7: |
||||||
|
move.l (%a1),%d1 |
||||||
|
sub.l #_start, %d1 |
||||||
|
add.l %a0,%d1 |
||||||
|
move.l %d1,(%a1)+ |
||||||
|
cmp.l %a2, %a1 |
||||||
|
bne 7b |
||||||
|
|
||||||
|
/* calculate relative jump to board_init_r in ram */ |
||||||
|
move.l %a0, %a1 |
||||||
|
add.l #(board_init_r - CONFIG_SYS_MONITOR_BASE), %a1 |
||||||
|
|
||||||
|
/* set parameters for board_init_r */ |
||||||
|
move.l %a0,-(%sp) /* dest_addr */ |
||||||
|
move.l %d0,-(%sp) /* gd */ |
||||||
|
#if defined(DEBUG) && (CONFIG_SYS_TEXT_BASE!=CONFIG_SYS_INT_FLASH_BASE) && \ |
||||||
|
defined(CONFIG_SYS_HALT_BEFOR_RAM_JUMP) |
||||||
|
halt |
||||||
|
#endif |
||||||
|
jsr (%a1) |
||||||
|
|
||||||
|
/*--------------------------------------------------------------------------*/ |
||||||
|
/* exception code */ |
||||||
|
.globl _fault
|
||||||
|
_fault: |
||||||
|
bra _fault |
||||||
|
|
||||||
|
.globl _exc_handler
|
||||||
|
_exc_handler: |
||||||
|
SAVE_ALL |
||||||
|
movel %sp,%sp@-
|
||||||
|
bsr exc_handler |
||||||
|
addql #4,%sp |
||||||
|
RESTORE_ALL |
||||||
|
|
||||||
|
.globl _int_handler
|
||||||
|
_int_handler: |
||||||
|
SAVE_ALL |
||||||
|
movel %sp,%sp@-
|
||||||
|
bsr int_handler |
||||||
|
addql #4,%sp |
||||||
|
RESTORE_ALL |
||||||
|
|
||||||
|
/*--------------------------------------------------------------------------*/ |
||||||
|
|
||||||
|
.globl version_string
|
||||||
|
version_string: |
||||||
|
.ascii U_BOOT_VERSION
|
||||||
|
.ascii " (", U_BOOT_DATE, " - ", U_BOOT_TIME, ")" |
||||||
|
.ascii CONFIG_IDENT_STRING, "\0" |
||||||
|
.align 4
|
@ -0,0 +1,118 @@ |
|||||||
|
/*
|
||||||
|
* (C) Copyright 2014 Angelo Dureghello <angelo@sysam.it> |
||||||
|
* |
||||||
|
* SPDX-License-Identifier: GPL-2.0+ |
||||||
|
* |
||||||
|
*/ |
||||||
|
|
||||||
|
#ifndef __IMMAP_5307__ |
||||||
|
#define __IMMAP_5307__ |
||||||
|
|
||||||
|
#define MMAP_SIM (CONFIG_SYS_MBAR + 0x00000000) |
||||||
|
#define MMAP_INTC (CONFIG_SYS_MBAR + 0x00000040) |
||||||
|
#define MMAP_CSM (CONFIG_SYS_MBAR + 0x00000080) |
||||||
|
#define MMAP_DRAMC (CONFIG_SYS_MBAR + 0x00000100) |
||||||
|
#define MMAP_DTMR0 (CONFIG_SYS_MBAR + 0x00000140) |
||||||
|
#define MMAP_DTMR1 (CONFIG_SYS_MBAR + 0x00000180) |
||||||
|
#define MMAP_UART0 (CONFIG_SYS_MBAR + 0x000001C0) |
||||||
|
#define MMAP_UART1 (CONFIG_SYS_MBAR + 0x00000200) |
||||||
|
#define MMAP_GPIO (CONFIG_SYS_MBAR + 0x00000244) |
||||||
|
|
||||||
|
typedef struct sim { |
||||||
|
u8 rsr; |
||||||
|
u8 sypcr; |
||||||
|
u8 swivr; |
||||||
|
u8 swsr; |
||||||
|
u16 par; |
||||||
|
u8 irqpar; |
||||||
|
u8 res1; |
||||||
|
u8 pllcr; |
||||||
|
u8 res2; |
||||||
|
u16 res3; |
||||||
|
u8 mpark; |
||||||
|
u8 res4; |
||||||
|
u16 res5; |
||||||
|
u32 res6; |
||||||
|
} sim_t; |
||||||
|
|
||||||
|
typedef struct intctrl { |
||||||
|
u32 ipr; |
||||||
|
u32 imr; |
||||||
|
u16 res7; |
||||||
|
u8 res8; |
||||||
|
u8 avr; |
||||||
|
u8 icr0; |
||||||
|
u8 icr1; |
||||||
|
u8 icr2; |
||||||
|
u8 icr3; |
||||||
|
u8 icr4; |
||||||
|
u8 icr5; |
||||||
|
u8 icr6; |
||||||
|
u8 icr7; |
||||||
|
u8 icr8; |
||||||
|
u8 icr9; |
||||||
|
u16 res9; |
||||||
|
} intctrl_t; |
||||||
|
|
||||||
|
typedef struct csm { |
||||||
|
u16 csar0; /* Chip-select Address */ |
||||||
|
u16 res1; |
||||||
|
u32 csmr0; /* Chip-select Mask */ |
||||||
|
u16 res2; |
||||||
|
u16 cscr0; /* Chip-select Control */ |
||||||
|
u16 csar1; |
||||||
|
u16 res3; |
||||||
|
u32 csmr1; |
||||||
|
u16 res4; |
||||||
|
u16 cscr1; |
||||||
|
u16 csar2; |
||||||
|
u16 res5; |
||||||
|
u32 csmr2; |
||||||
|
u16 res6; |
||||||
|
u16 cscr2; |
||||||
|
u16 csar3; |
||||||
|
u16 res7; |
||||||
|
u32 csmr3; |
||||||
|
u16 res8; |
||||||
|
u16 cscr3; |
||||||
|
u16 csar4; |
||||||
|
u16 res9; |
||||||
|
u32 csmr4; |
||||||
|
u16 res10; |
||||||
|
u16 cscr4; |
||||||
|
u16 csar5; |
||||||
|
u16 res11; |
||||||
|
u32 csmr5; |
||||||
|
u16 res12; |
||||||
|
u16 cscr5; |
||||||
|
u16 csar6; |
||||||
|
u16 res13; |
||||||
|
u32 csmr6; |
||||||
|
u16 res14; |
||||||
|
u16 cscr6; |
||||||
|
u16 csar7; |
||||||
|
u16 res15; |
||||||
|
u32 csmr7; |
||||||
|
u16 res16; |
||||||
|
u16 cscr7; |
||||||
|
} csm_t; |
||||||
|
|
||||||
|
typedef struct sdramctrl { |
||||||
|
u16 dcr; |
||||||
|
u16 res1; |
||||||
|
u32 res2; |
||||||
|
u32 dacr0; |
||||||
|
u32 dmr0; |
||||||
|
u32 dacr1; |
||||||
|
u32 dmr1; |
||||||
|
} sdramctrl_t; |
||||||
|
|
||||||
|
typedef struct gpio { |
||||||
|
u16 paddr; |
||||||
|
u16 res1; |
||||||
|
u16 padat; |
||||||
|
u16 res2; |
||||||
|
} gpio_t; |
||||||
|
|
||||||
|
#endif /* __IMMAP_5307__ */ |
||||||
|
|
@ -0,0 +1,70 @@ |
|||||||
|
/*
|
||||||
|
* (C) Copyright 2014 Angelo Dureghello <angelo@sysam.it> |
||||||
|
* |
||||||
|
* SPDX-License-Identifier: GPL-2.0+ |
||||||
|
* |
||||||
|
*/ |
||||||
|
|
||||||
|
#ifndef mcf5307_h |
||||||
|
#define mcf5307_h |
||||||
|
|
||||||
|
/*
|
||||||
|
* Size of internal RAM (RAMBAR) |
||||||
|
*/ |
||||||
|
#define INT_RAM_SIZE 4096 |
||||||
|
|
||||||
|
/* Bit definitions and macros for SYPCR */ |
||||||
|
#define SYPCR_SWTAVAL 0x02 |
||||||
|
#define SYPCR_SWTA 0x04 |
||||||
|
#define SYPCR_SWT(x) ((x&0x3)<<3) |
||||||
|
#define SYPCR_SWP 0x20 |
||||||
|
#define SYPCR_SWRI 0x40 |
||||||
|
#define SYPCR_SWE 0x80 |
||||||
|
|
||||||
|
/* Bit definitions and macros for CSMR */ |
||||||
|
#define CSMR_V 0x01 |
||||||
|
#define CSMR_UD 0x02 |
||||||
|
#define CSMR_UC 0x04 |
||||||
|
#define CSMR_SD 0x08 |
||||||
|
#define CSMR_SC 0x10 |
||||||
|
#define CSMR_CI 0x20 |
||||||
|
#define CSMR_AM 0x40 |
||||||
|
#define CSMR_WP 0x100 |
||||||
|
|
||||||
|
/* Bit definitions and macros for DACR (SDRAM) */ |
||||||
|
#define DACR_PM_CONTINUOUS 0x04 |
||||||
|
#define DACR_IP_PRECHG_ALL 0x08 |
||||||
|
#define DACR_PORT_SZ_32 0 |
||||||
|
#define DACR_PORT_SZ_8 (1<<4) |
||||||
|
#define DACR_PORT_SZ_16 (2<<4) |
||||||
|
#define DACR_IMRS_INIT_CMD (1<<6) |
||||||
|
#define DACR_CMD_PIN(x) ((x&7)<<8) |
||||||
|
#define DACR_CASL(x) ((x&3)<<12) |
||||||
|
#define DACR_RE (1<<15) |
||||||
|
|
||||||
|
/* Bit definitions and macros for CSCR */ |
||||||
|
#define CSCR_BSTW 0x08 |
||||||
|
#define CSCR_BSTR 0x10 |
||||||
|
#define CSCR_BEM 0x20 |
||||||
|
#define CSCR_PS(x) ((x&0x3)<<6) |
||||||
|
#define CSCR_AA 0x100 |
||||||
|
#define CSCR_WS ((x&0xf)<<10) |
||||||
|
|
||||||
|
/* Bit definitions for the ICR family of registers */ |
||||||
|
#define MCFSIM_ICR_AUTOVEC 0x80 /* Auto-vectored intr */ |
||||||
|
#define MCFSIM_ICR_LEVEL0 0x00 /* Level 0 intr */ |
||||||
|
#define MCFSIM_ICR_LEVEL1 0x04 /* Level 1 intr */ |
||||||
|
#define MCFSIM_ICR_LEVEL2 0x08 /* Level 2 intr */ |
||||||
|
#define MCFSIM_ICR_LEVEL3 0x0c /* Level 3 intr */ |
||||||
|
#define MCFSIM_ICR_LEVEL4 0x10 /* Level 4 intr */ |
||||||
|
#define MCFSIM_ICR_LEVEL5 0x14 /* Level 5 intr */ |
||||||
|
#define MCFSIM_ICR_LEVEL6 0x18 /* Level 6 intr */ |
||||||
|
#define MCFSIM_ICR_LEVEL7 0x1c /* Level 7 intr */ |
||||||
|
|
||||||
|
#define MCFSIM_ICR_PRI0 0x00 /* Priority 0 intr */ |
||||||
|
#define MCFSIM_ICR_PRI1 0x01 /* Priority 1 intr */ |
||||||
|
#define MCFSIM_ICR_PRI2 0x02 /* Priority 2 intr */ |
||||||
|
#define MCFSIM_ICR_PRI3 0x03 /* Priority 3 intr */ |
||||||
|
|
||||||
|
#endif /* mcf5307_h */ |
||||||
|
|
Loading…
Reference in new issue