variant.s
来自「eCos操作系统源码」· S 代码 · 共 252 行
S
252 行
##==========================================================================#### variant.S#### SH4 variant assembly 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): jskov## Contributors: jskov## Date: 2000-10-31## Purpose: SH4 misc assembly code######DESCRIPTIONEND########==========================================================================#include <pkgconf/hal.h>#include <pkgconf/hal_sh.h>#include <cyg/hal/sh_regs.h>#include <cyg/hal/sh4_offsets.inc>#include <cyg/hal/arch.inc>#include <cyg/hal/hal_intr.h> #---------------------------------------------------------------------------# Cache operations# These need to be written in assembly to ensure they do not rely on data# in cachable space (i.e., code must use registers exclusively, not the stack).# This macro must be used at the top of each cache function. It ensures# that the code gets executed from a shadow region where caching is disabled# (0xA0000000). .macro GOTO_NONCACHED_SHADOW mova 10f,r0 mov.l $MASK,r1 and r1,r0 mov.l $BASE,r1 or r1,r0 jmp @r0 nop .align 210: .endm .macro RETURN_FROM_NONCACHED_SHADOW nop ! Wait for 8 instructions nop ! before jumping to a non-P2 nop ! area nop nop nop nop nop rts nop .endmFUNC_START(cyg_hal_dcache_enable) GOTO_NONCACHED_SHADOW mov.l $nCYGARC_REG_CCR,r1 mov.l @r1,r0 mov #CYGARC_REG_CCR_OCE,r2 or r2,r0 mov.l r0,@r1 RETURN_FROM_NONCACHED_SHADOWFUNC_START(cyg_hal_dcache_disable) GOTO_NONCACHED_SHADOW mov.l $nCYGARC_REG_CCR,r1 mov.l @r1,r0 mov #CYGARC_REG_CCR_OCE,r2 not r2,r2 and r2,r0 mov.l r0,@r1 RETURN_FROM_NONCACHED_SHADOW FUNC_START(cyg_hal_dcache_invalidate_all) GOTO_NONCACHED_SHADOW mov.l $nCYGARC_REG_CCR,r1 mov.l @r1,r0 mov #CYGARC_REG_CCR_OCI,r2 or r2,r0 mov.l r0,@r1 RETURN_FROM_NONCACHED_SHADOWFUNC_START(cyg_hal_dcache_sync) GOTO_NONCACHED_SHADOW mov.l $CYGARC_REG_DCACHE_ADDRESS_FLUSH,r0 mov.l $CYGARC_REG_DCACHE_ADDRESS_BASE,r1 mov.l $CYGARC_REG_DCACHE_ADDRESS_TOP,r2 mov.l $CYGARC_REG_DCACHE_ADDRESS_STEP,r31: cmp/hi r1,r2 bf 2f mov.l r0,@r1 bra 1b add r3,r1 ! delay slot!2: RETURN_FROM_NONCACHED_SHADOW .align 2$CYGARC_REG_DCACHE_ADDRESS_FLUSH: .long CYGARC_REG_DCACHE_ADDRESS_FLUSH$CYGARC_REG_DCACHE_ADDRESS_BASE: .long CYGARC_REG_DCACHE_ADDRESS_BASE$CYGARC_REG_DCACHE_ADDRESS_TOP: .long CYGARC_REG_DCACHE_ADDRESS_TOP$CYGARC_REG_DCACHE_ADDRESS_STEP: .long CYGARC_REG_DCACHE_ADDRESS_STEP ! r4 = base ! r5 = sizeFUNC_START(cyg_hal_dcache_sync_region) GOTO_NONCACHED_SHADOW1: ocbp @r4 ! operand cache block purge add #CYGARC_SH_MOD_DCAC_ADDRESS_STEP,r4 add #-CYGARC_SH_MOD_DCAC_ADDRESS_STEP,r5 cmp/pl r5 bt 1b RETURN_FROM_NONCACHED_SHADOWFUNC_START(cyg_hal_dcache_write_mode) GOTO_NONCACHED_SHADOW # Mode argument in r4. # Read current state and mask out the two caching mode bits mov.l $nCYGARC_REG_CCR,r1 mov.l @r1,r3 mov #CYGARC_REG_CCR_CB|CYGARC_REG_CCR_WT,r2 and r2,r4 not r2,r2 and r2,r3 # Or in the new settings and restore to CCR or r4,r3 mov.l r3,@r1 RETURN_FROM_NONCACHED_SHADOWFUNC_START(cyg_hal_icache_enable) GOTO_NONCACHED_SHADOW mov.l $nCYGARC_REG_CCR,r1 mov.l @r1,r0 mov.l $nCYGARC_REG_CCR_ICE,r2 or r2,r0 mov.l r0,@r1 RETURN_FROM_NONCACHED_SHADOWFUNC_START(cyg_hal_icache_disable) GOTO_NONCACHED_SHADOW mov.l $nCYGARC_REG_CCR,r1 mov.l @r1,r0 mov.l $nCYGARC_REG_CCR_ICE,r2 not r2,r2 and r2,r0 mov.l r0,@r1 RETURN_FROM_NONCACHED_SHADOW FUNC_START(cyg_hal_icache_invalidate_all) GOTO_NONCACHED_SHADOW mov.l $nCYGARC_REG_CCR,r1 mov.l @r1,r0 mov.l $nCYGARC_REG_CCR_ICI,r2 or r2,r0 mov.l r0,@r1 RETURN_FROM_NONCACHED_SHADOW .align 2$MASK: .long 0x1fffffff ! mask off top 3 bits$BASE: .long 0xa0000000 ! base of non-cachable memory$nCYGARC_REG_CCR: .long CYGARC_REG_CCR $nCYGARC_REG_CCR_ICE: .long CYGARC_REG_CCR_ICE$nCYGARC_REG_CCR_ICI: .long CYGARC_REG_CCR_ICI .dataSYM_DEF(cyg_hal_ILVL_table) # The first entries in the table have static priorities. .byte 0xf // NMI .byte 0xf // Reserved .byte 0xf // LVL0 .byte 0xe // LVL1 .byte 0xd // LVL2 .byte 0xc // LVL3 .byte 0xb // LVL4 .byte 0xa // LVL5 .byte 0x9 // LVL6 .byte 0x8 // LVL7 .byte 0x7 // LVL8 .byte 0x6 // LVL9 .byte 0x5 // LVL10 .byte 0x4 // LVL11 .byte 0x3 // LVL12 .byte 0x2 // LVL13 .byte 0x1 // LVL14 .byte 0xf // Reserved # The rest of the table consists of programmable levels, maintained # by the HAL_INTERRUPT_SET_LEVEL macro. # These default to the highest level so that a spurious # interrupt cause the IPL to be suddenly lowered to allow all # interrupts. This should give a better chance at tracking down # the problem. .rept (CYGNUM_HAL_ISR_MAX-CYGNUM_HAL_INTERRUPT_RESERVED_3E0) .byte 0xf .endr # All interrupts are masked initally. Set to 1 to enable.SYM_DEF(cyg_hal_IMASK_table) .rept (CYGNUM_HAL_ISR_MAX) .byte 0x0 .endr
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?