URL
https://opencores.org/ocsvn/openrisc_me/openrisc_me/trunk
Subversion Repositories openrisc_me
[/] [openrisc/] [trunk/] [rtos/] [ecos-2.0/] [packages/] [hal/] [mips/] [rm7000/] [ocelot/] [v2_0/] [src/] [platform.S] - Rev 174
Compare with Previous | Blame | View Log
##=============================================================================
##
## platform.S
##
## MIPS Ocelot platform code
##
##=============================================================================
#####ECOSGPLCOPYRIGHTBEGIN####
## -------------------------------------------
## This file is part of eCos, the Embedded Configurable Operating System.
## Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.
##
## eCos 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 or (at your option) any later version.
##
## eCos 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.
##
## You should have received a copy of the GNU General Public License along
## with eCos; if not, write to the Free Software Foundation, Inc.,
## 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
##
## As a special exception, if other files instantiate templates or use macros
## or inline functions from this file, or you compile this file and link it
## with other works to produce a work based on this file, this file does not
## by itself cause the resulting work to be covered by the GNU General Public
## License. However the source code for this file must still be made available
## in accordance with section (3) of the GNU General Public License.
##
## This exception does not invalidate any other reasons why a work based on
## this file might be covered by the GNU General Public License.
##
## Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.
## at http://sources.redhat.com/ecos/ecos-license/
## -------------------------------------------
#####ECOSGPLCOPYRIGHTEND####
##=============================================================================
#######DESCRIPTIONBEGIN####
##
## Author(s): nickg
## Contributors:nickg, jskov
## Date: 2000-05-09
## Purpose: MIPS Ocelot platform code
## Description: Platform specific code for Ocelot board.
##
######DESCRIPTIONEND####
##
##=============================================================================
.set noreorder
#include <pkgconf/system.h>
#include <pkgconf/hal.h>
#ifdef CYGPKG_KERNEL
# include <pkgconf/kernel.h>
#endif
#include <cyg/hal/arch.inc>
#include <cyg/hal/plf_defs.inc>
#include <cyg/hal/hal_misc.h>
##-----------------------------------------------------------------------------
## MEMC initialization.
## This code is table driven, which is somewhat more compact that coding it
## all.
## Table entries consist of an address and a value to store in that address.
## A zero address terminates the table. Two special address values modify the
## behaviour:
## DELAY_LOOP loops for the number of iterations in the value field.
## WRITE16 treats the next 2 words as an address and value to be written
## with a 16 bit write cycle.
#define HAL_GALILEO_CONTROLLER_BASE 0xb4000000
#define GL_CPU_CFG 0xb4000000
#define GL_CPU_CFG_WRITERATE 0x00010000
#define GL_DEV_PAR_BANK0 0xb400045c
#define GL_DEV_PAR_BANK1 0xb4000460
#define GL_DEV_PAR_BANK2 0xb4000464
#define GL_DEV_PAR_BANK3 0xb4000468
#define GL_DEV_PAR_BOOT 0xb400046c
#define GL_SDRAM_CFG 0xb4000448
#define GL_SDRAM_CFG_REF_INT_CNT_default 0x00000200
#define GL_SDRAM_CFG_CPU_TO_DRAM_ERR 0x00020000
#define GL_SDRAM_CFG_ECC_INT 0x00040000
#define GL_SDRAM_CFG_DUP_BA 0x00100000
#define GL_SDRAM_CFG_REG_SDRAM 0x00800000
#define GL_SDRAM_CFG_DADR_12_SEL 0x01000000
#define GL_SDRAM_CFG_init (GL_SDRAM_CFG_REF_INT_CNT_default| \
GL_SDRAM_CFG_CPU_TO_DRAM_ERR| \
GL_SDRAM_CFG_ECC_INT| \
GL_SDRAM_CFG_DUP_BA| \
GL_SDRAM_CFG_REG_SDRAM| \
GL_SDRAM_CFG_DADR_12_SEL)
#define GL_SDRAM_PAR_BANK0 0xb400044c
#define GL_SDRAM_PAR_BANK2 0xb4000454
#define GL_CPU_SCS10_LO 0xb4000008
#define GL_CPU_SCS10_HI 0xb4000010
#define GL_CPU_SCS32_LO 0xb4000018
#define GL_CPU_SCS32_HI 0xb4000020
#define GL_SDRAM_SCS0_LO 0xb4000400
#define GL_SDRAM_SCS0_HI 0xb4000404
#define GL_SDRAM_SCS1_LO 0xb4000408
#define GL_SDRAM_SCS1_HI 0xb400040c
#define GL_SDRAM_SCS2_LO 0xb4000410
#define GL_SDRAM_SCS2_HI 0xb4000414
#define GL_SDRAM_SCS3_LO 0xb4000418
#define GL_SDRAM_SCS3_HI 0xb400041c
#define GL_SDRAM_MODE 0xb4000474
#define GL_SDRAM_MODE_NORMAL 0x00000000
#define GL_SDRAM_MODE_ENABLE 0x00000003
#define PLD_BOARD_STAT 0xbc000004
#define PLD_INT_SET 0xbc00000c
#define PLD_INT_CLEAR 0xbc00000d
#define PLD_INT_SET_USER_LED 0x40
#define CPU_TO_LE(x) (((x & 0xff) << 24) | ((x & 0xff00) << 8) | ((x & 0xff0000) >> 8) | ((x >> 24) & 0xff))
#define HAL_OCELOT_RAM_BASE 0x00000000
#define HAL_GALILEO_CPU_DECODE_SHIFT 21
#define HAL_GALILEO_DEV_DECODE_SHIFT 20
#define HAL_GALILEO_SCS10_LD_OFFSET 0x008
#define HAL_GALILEO_SCS10_HD_OFFSET 0x010
#define HAL_GALILEO_SCS32_LD_OFFSET 0x018
#define HAL_GALILEO_SCS32_HD_OFFSET 0x020
#define HAL_GALILEO_SCS0_LD_OFFSET 0x400
#define HAL_GALILEO_SCS0_HD_OFFSET 0x404
#define HAL_GALILEO_SCS1_LD_OFFSET 0x408
#define HAL_GALILEO_SCS1_HD_OFFSET 0x40c
#define HAL_GALILEO_SCS2_LD_OFFSET 0x410
#define HAL_GALILEO_SCS2_HD_OFFSET 0x414
#define HAL_GALILEO_SCS3_LD_OFFSET 0x418
#define HAL_GALILEO_SCS3_HD_OFFSET 0x41c
#if !defined(CYG_HAL_STARTUP_RAM)
#define DELAY_LOOP 1
#define WRITE16 2
#define swap(v, t1, t2, t3) \
lui t1,0xff; \
andi t2,v,0xff00; \
and t3,v,t1; \
sll t1,v,0x18; \
srl v,v,0x18; \
or v,v,t1; \
srl t3,t3,0x08; \
sll t2,t2,0x08; \
or v,v,t3; \
or v,v,t2;
FUNC_START(hal_memc_setup)
lar t0,hal_memc_setup_table
la t1,0xbfc00000
la t2,DELAY_LOOP
la t3,WRITE16
1:
lw a0,0(t0) # next table entry
lw a1,4(t0) # value to write
addiu t0,8 # go to next entry
beq a0,t2,2f # Check for delay
nop
beq a0,t3,3f # Check for 16 bit write
nop
beqz a0,9f # zero terminates loop
nop
sw a1,0(a0) # write it
lw zero,0(t1) # uncached read to flush write buffer
b 1b
nop
2:
lw zero,0(t1) # uncached read to flush write buffer
bnez a1,2b # count down by value in a1
addiu a1,-1 # decrement in delay slot
b 1b # go back to loop
nop
3:
lw a3,0(t0) # get next word
addiu t0,4 # skip it
sh a3,0(a1) # store halfword
lw zero,0(t1) # uncached read to flush write buffer
b 1b
nop
9:
// Complete the SDRAM setup.
la t0,GL_SDRAM_MODE
la t1,CPU_TO_LE(GL_SDRAM_MODE_ENABLE)
sw t1,0(t0)
// Wait 100us after writing mode
la a1,(CYGHWR_HAL_MIPS_RM7000_CPU_CLOCK * 100 / 1000000)
lui a0,0xa000 // uncached bank0 device
sw zero,0(a0)
mtc0 zero,$9
1: mfc0 a0,$9
nop
blt a0, a1, 1b
nop
lui a0,0xa080 // uncached bank2 device
sw zero,0(a0)
mtc0 zero,$9
1: mfc0 a0,$9
nop
blt a0, a1, 1b
nop
la t0,GL_SDRAM_MODE
la t1,CPU_TO_LE(GL_SDRAM_MODE_NORMAL)
sw t1,0(t0)
// Set CPU cfg word
la a0,GL_CPU_CFG
lw a1,0(a0)
la t0,CPU_TO_LE(0x20000)
or a1,a1,t0 // disable retries
// CPU WriteRate - set GT to match CPU
mfc0 t0,$16
la t1, 0x0f000000
and t0, t0, t1
beqz t0,1f // defaults to zero
nop
la t0, CPU_TO_LE(GL_CPU_CFG_WRITERATE)
or a1, a1, t0
1:
sw a1,0(a0)
# FIXME: Hardwired for 256MB - need kuseg magic to map full 512MB.
#
# Setup SDRAM Bank 0 Address Decoding
#
la s7, HAL_GALILEO_CONTROLLER_BASE
la a0, HAL_OCELOT_RAM_BASE # Phys bottom of Bank 0
la a1, (HAL_OCELOT_RAM_BASE+128*1024*1024)
subu a1, 1 # Phys top of Bank0
srl t0, a0, HAL_GALILEO_CPU_DECODE_SHIFT # Setup SCS[1:0]
swap(t0,t1,t2,t3) # 1st level decoding
sw t0, HAL_GALILEO_SCS10_LD_OFFSET(s7) # (CPU Decode Region)
srl t0, a1, HAL_GALILEO_CPU_DECODE_SHIFT #
swap(t0,t1,t2,t3)
sw t0, HAL_GALILEO_SCS10_HD_OFFSET(s7) #
srl t0, a0, HAL_GALILEO_DEV_DECODE_SHIFT # Setup SCS0
swap(t0,t1,t2,t3) # 2nd level decoding
sw t0, HAL_GALILEO_SCS0_LD_OFFSET(s7) # (Device Sub-decode Region)
srl t0, a1, HAL_GALILEO_DEV_DECODE_SHIFT #
swap(t0,t1,t2,t3)
sw t0, HAL_GALILEO_SCS0_HD_OFFSET(s7) #
#
# Setup SDRAM Bank 1 Address Decoding
#
la a0, (HAL_OCELOT_RAM_BASE+128*1024*1024) # Phys bottom of Bank 1
la a1, (HAL_OCELOT_RAM_BASE+256*1024*1024)
subu a1, 1 # Phys top of Bank1
srl t0, a0, HAL_GALILEO_CPU_DECODE_SHIFT # Setup SCS[3:2]
swap(t0,t1,t2,t3) # 1st level decoding
sw t0, HAL_GALILEO_SCS32_LD_OFFSET(s7) # (CPU Decode Region)
srl t0, a1, HAL_GALILEO_CPU_DECODE_SHIFT #
swap(t0,t1,t2,t3)
sw t0, HAL_GALILEO_SCS32_HD_OFFSET(s7) #
srl t0, a0, HAL_GALILEO_DEV_DECODE_SHIFT # Setup SCS2
swap(t0,t1,t2,t3) # 2nd level decoding
sw t0, HAL_GALILEO_SCS2_LD_OFFSET(s7) # (Device Sub-decode Region)
srl t0, a1, HAL_GALILEO_DEV_DECODE_SHIFT #
swap(t0,t1,t2,t3)
sw t0, HAL_GALILEO_SCS2_HD_OFFSET(s7) #
jr ra
nop
FUNC_END(hal_memc_setup)
##-----------------------------------------------------------------------------
## The initialization table
hal_memc_setup_table:
.long DELAY_LOOP, 10000 # Wait for HW to settle
.long GL_DEV_PAR_BANK0, CPU_TO_LE(0x000b6b33) // PLD
.long GL_DEV_PAR_BANK1, CPU_TO_LE(0x000bad53) // NVRAM
.long GL_DEV_PAR_BANK2, CPU_TO_LE(0x000bad54) // UART
.long GL_DEV_PAR_BANK3, CPU_TO_LE(0x000fef73) // flash disk
.long GL_DEV_PAR_BOOT, CPU_TO_LE(0x144bee63) // boot flash
.long GL_SDRAM_CFG, CPU_TO_LE(GL_SDRAM_CFG_init)
.long GL_SDRAM_PAR_BANK0, CPU_TO_LE(0x00000c69 | 0x4000)
.long GL_SDRAM_PAR_BANK2, CPU_TO_LE(0x00000c69 | 0x4000)
.long GL_CPU_SCS10_LO, CPU_TO_LE(0x00000000)
.long GL_CPU_SCS10_HI, CPU_TO_LE(0x00000003)
.long GL_CPU_SCS32_LO, CPU_TO_LE(0x00000004)
.long GL_CPU_SCS32_HI, CPU_TO_LE(0x00000007)
.long GL_SDRAM_SCS0_LO, CPU_TO_LE(0x00000000)
.long GL_SDRAM_SCS0_HI, CPU_TO_LE(0x00000007)
.long GL_SDRAM_SCS1_LO, CPU_TO_LE(0x000000ff)
.long GL_SDRAM_SCS1_HI, CPU_TO_LE(0x00000000)
.long GL_SDRAM_SCS2_LO, CPU_TO_LE(0x00000008)
.long GL_SDRAM_SCS2_HI, CPU_TO_LE(0x0000000f)
.long GL_SDRAM_SCS3_LO, CPU_TO_LE(0x000000ff)
.long GL_SDRAM_SCS3_HI, CPU_TO_LE(0x00000000)
.long 0, 0
#endif // !CYG_HAL_STARTUP_RAM
##-----------------------------------------------------------------------------
## ISR tables.
.extern hal_default_isr
.data
#ifdef CYGIMP_HAL_COMMON_INTERRUPTS_CHAIN
.globl hal_interrupt_handlers
hal_interrupt_handlers:
.long hal_default_isr # chaining vector
.globl hal_interrupt_data
hal_interrupt_data:
.long 0 # chaining vector data
.globl hal_interrupt_objects
hal_interrupt_objects:
.long 0 # chaining vector object
.globl cyg_hal_interrupt_level
cyg_hal_interrupt_level:
.rept CYGNUM_HAL_ISR_COUNT
.byte 0
.endr
#else // CYGIMP_HAL_COMMON_INTERRUPTS_CHAIN
.globl hal_interrupt_handlers
hal_interrupt_handlers:
.long hal_default_isr
.long hal_default_isr
.long hal_default_isr
.long hal_default_isr
.long hal_default_isr
.long hal_default_isr
.long hal_default_isr
.long hal_default_isr
.long hal_default_isr
.long hal_default_isr
.rept CYGNUM_HAL_ISR_COUNT-10
.long hal_default_isr
.endr
.globl hal_interrupt_data
hal_interrupt_data:
.long 0
.long 0
.long 0
.long 0
.long 0
.long 0
.long 0
.long 0
.long 0
.long 0
.rept CYGNUM_HAL_ISR_COUNT-10
.long 0
.endr
.globl hal_interrupt_objects
hal_interrupt_objects:
.rept CYGNUM_HAL_ISR_COUNT
.long 0
.endr
.globl cyg_hal_interrupt_level
cyg_hal_interrupt_level:
.rept CYGNUM_HAL_ISR_COUNT
.byte 0
.endr
#endif // CYGIMP_HAL_COMMON_INTERRUPTS_CHAIN
##-----------------------------------------------------------------------------
## end of platform.S