⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 irq.s

📁 基于ecos的redboot
💻 S
字号:
//=============================================================================
//
//      irq.S - Cyclone Diagnostics
//
//=============================================================================
//####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) 2001 Red Hat, Inc.                             
// All Rights Reserved.                                                     
// -------------------------------------------                              
//                                                                          
//####COPYRIGHTEND####
//=============================================================================
//#####DESCRIPTIONBEGIN####
//
// Author(s):   Scott Coulter, Jeff Frazier, Eric Breeden
// Contributors:
// Date:        2001-01-25
// Purpose:     
// Description: 
//
//####DESCRIPTIONEND####
//
//===========================================================================*/

/*
 * Low-lebvel interrupt support for IQ80310 diags
 */
	.extern iq80310_irq_handler
	.extern iq80310_fiq_handler

	.text
	.globl __diag_IRQ
  __diag_IRQ:
	ldr	sp, =__irq_stack    /* point stack pointer at IRQ stack */
	sub	lr, lr, #4 	   /* adjust lr (return to last address) */
	stmfd	sp!, {r12, lr}     /* push r12 and link reg onto stack */
	mrs	r12, spsr	   /* store spsr in r12 */
	stmfd	sp!, {r12}	   /* push spsr onto stack */
	stmfd	sp!, {r0-r11}  	   /* push all registers onto stack */
	bl	iq80310_irq_handler
	ldmfd	sp!, {r0-r12} 	   /* restore r0 thru r12 */
	msr	spsr, r12	   /* restore SPSR */
	ldmfd	sp!, {r12,pc}^	   /* restore r12 and PC, return */

	.globl __diag_FIQ
  __diag_FIQ:
	/* Cyclone FIQ handler */
	/* save registers onto stack */
	ldr     sp, =__fiq_stack	/* point stack pointer at FIQ stack */
	sub	lr, lr, #4	/* adjust link register (return to last address) */
	stmfd	sp!, {r12, lr}	/* push r12 and link reg onto stack */
	mrs	r12, spsr	/* store spsr in r12 */
	stmfd	sp!, {r12}	/* push spsr onto stack */
	stmfd	sp!, {r0-r7}	/* push r0 thru r7 (r8 - r14 are banked) */
	bl      iq80310_fiq_handler
	/* restore registers and return */
	ldmfd	sp!, {r0-r7}	/* restore r0 thru r7 (r8 - r14 are banked) */
	ldmfd	sp!, {r12}
	msr	spsr, r12	/* restore SPSR */
	ldmfd	sp!, {r12,pc}^	/* restore r12 and PC, return to inst before exception occurred */

	.globl __ignore_abort
__ignore_abort:
	subs pc,lr,#4

	.globl _cspr_enable_fiq_int
_cspr_enable_fiq_int:
	mrs	r0, cpsr
	bic	r0, r0, #0x40
	msr	cpsr, r0
	mov     pc, lr

	.globl _cspr_enable_irq_int
_cspr_enable_irq_int:
	mrs	r0, cpsr
	bic	r0, r0, #0x80
	msr	cpsr, r0
	mov     pc, lr

	.bss
	.rept 1024
	.word 0
	.endr
  __irq_stack:
	.rept 1024
	.word 0
	.endr
  __fiq_stack:


⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -