📄 edk.s
字号:
##=============================================================================#### edk.S#### EDK board hardware setup####=============================================================================#####COPYRIGHTBEGIN##### # ------------------------------------------- # The contents of this file are subject to the Red Hat eCos Public License # Version 1.1 (the "License"); you may not use this file except in # compliance with the License. You may obtain a copy of the License at # http://www.redhat.com/ # # Software distributed under the License is distributed on an "AS IS" # basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the # License for the specific language governing rights and limitations under # the License. # # The Original Code is eCos - Embedded Configurable Operating System, # released September 30, 1998. # # The Initial Developer of the Original Code is Red Hat. # Portions created by Red Hat are # Copyright (C) 1998, 1999, 2000 Red Hat, Inc. # All Rights Reserved. # ------------------------------------------- # #####COPYRIGHTEND######=============================================================================#######DESCRIPTIONBEGIN######## Author(s): jskov## Contributors:jskov## Date: 1999-05-03## Purpose: EDK7708 board hardware setup## Description: This file contains any code needed to initialize the## hardware on a Hitachi SH3 EDK7708 board.########DESCRIPTIONEND########=============================================================================#include <pkgconf/hal.h>#include <cyg/hal/sh_regs.h> .globl _hal_hardware_init_hal_hardware_init: // Set up the Bus State Controller mov.l $BSC_settings_table,r31: mov.w @r3+,r0 // Address (or zero) cmp/eq #0,r0 bt 2f mov.w @r3+,r1 // data bra 1b mov.w r1,@r0 // delay slot2: rts nop .align 2$BSC_settings_table: .long BSC_settings_tableBSC_settings_table: # These are the settings set by the Hitachi ROM Monitor. # BCR2: Bus size of areas 1-6 to 32 bits .word CYGARC_REG_BCR2 .word 0x3ffc # BCR1: Areas 2 and 3 are SDRAM .word CYGARC_REG_BCR1 .word 0x080c # BCR2: Bus size of areas 1-6 to 32 bits [note: second write!] .word CYGARC_REG_BCR2 .word 0x3ffc # WCR1: 3 wait-state cycles inserted for all areas .word CYGARC_REG_WCR1 .word 0x3fff # WCR2: extra wait states and full pitch for burst .word CYGARC_REG_WCR2 .word 0xffd7 # MCR: RAS/CAS & burst timing area 2/3 .word CYGARC_REG_MCR .word 0x963c#if 0 # DCR: RAS/CAS & burst timing area 2 .word CYGARC_REG_DCR .word 0x0000 # PCR: PCMCIA disabled .word CYGARC_REG_PCR .word 0x0000#endif # RTCNT: refresh counter (needs a5 in top byte to accept write) .word CYGARC_REG_RTCNT .word (0xa500 | 0x0000) # RTCOR: refresh time constant (needs a5 in top byte to accept write) .word CYGARC_REG_RTCOR .word (0xa500 | 0x003b) # RFCR: refresh count register (needs a4 in top byte to accept write) .word CYGARC_REG_RFCR .word (0xa400 | 0x0000) # RTCSR: refresh timer control (needs a5 in top byte to accept write) .word CYGARC_REG_RTCSR .word (0xa500 | 0x0008) # Set SDMR to 0x220 .word 0xd880 .word 0 # Table end .word 0#------------------------------------------------------------------------------# end of edk.S
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -