int-handler.S
上传用户:jlfgdled
上传日期:2013-04-10
资源大小:33168k
文件大小:3k
源码类别:

Linux/Unix编程

开发平台:

Unix_Linux

  1. /*
  2.  * Copyright 2001 MontaVista Software Inc.
  3.  * Author: MontaVista Software, Inc.
  4.  *              ahennessy@mvista.com       
  5.  *
  6.  * Based on arch/mips/tsdb/kernel/int-handler.S
  7.  *
  8.  * Copyright (C) 2000-2001 Toshiba Corporation
  9.  *
  10.  *  This program is free software; you can redistribute  it and/or modify it
  11.  *  under  the terms of  the GNU General  Public License as published by the
  12.  *  Free Software Foundation;  either version 2 of the  License, or (at your
  13.  *  option) any later version.
  14.  *
  15.  *  THIS  SOFTWARE  IS PROVIDED   ``AS  IS'' AND   ANY  EXPRESS OR IMPLIED
  16.  *  WARRANTIES,   INCLUDING, BUT NOT  LIMITED  TO, THE IMPLIED WARRANTIES OF
  17.  *  MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.  IN
  18.  *  NO  EVENT  SHALL   THE AUTHOR  BE    LIABLE FOR ANY   DIRECT, INDIRECT,
  19.  *  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  20.  *  NOT LIMITED   TO, PROCUREMENT OF  SUBSTITUTE GOODS  OR SERVICES; LOSS OF
  21.  *  USE, DATA,  OR PROFITS; OR  BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
  22.  *  ANY THEORY OF LIABILITY, WHETHER IN  CONTRACT, STRICT LIABILITY, OR TORT
  23.  *  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  24.  *  THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  25.  *
  26.  *  You should have received a copy of the  GNU General Public License along
  27.  *  with this program; if not, write  to the Free Software Foundation, Inc.,
  28.  *  675 Mass Ave, Cambridge, MA 02139, USA.
  29.  */
  30. #include <asm/asm.h>
  31. #include <asm/mipsregs.h>
  32. #include <asm/regdef.h>
  33. #include <asm/stackframe.h>
  34. #include <asm/jmr3927/jmr3927.h>
  35. /* A lot of complication here is taken away because:
  36.  *
  37.  * 1) We handle one interrupt and return, sitting in a loop
  38.  *    and moving across all the pending IRQ bits in the cause
  39.  *    register is _NOT_ the answer, the common case is one
  40.  *    pending IRQ so optimize in that direction.
  41.  *
  42.  * 2) We need not check against bits in the status register
  43.  *    IRQ mask, that would make this routine slow as hell.
  44.  *
  45.  * 3) Linux only thinks in terms of all IRQs on or all IRQs
  46.  *    off, nothing in between like BSD spl() brain-damage.
  47.  *
  48.  */
  49. /* Flush write buffer (needed?)
  50.  * NOTE: TX39xx performs "non-blocking load", so explicitly use the target
  51.  * register of LBU to flush immediately.
  52.  */
  53. #define FLUSH_WB(tmp)
  54. la tmp, JMR3927_IOC_REV_ADDR; 
  55. lbu tmp, (tmp); 
  56. move tmp, zero;
  57. .text
  58. .set noreorder
  59. .set noat
  60. .align 5
  61. NESTED(jmr3927_IRQ, PT_SIZE, sp)
  62. SAVE_ALL
  63. CLI
  64. .set at
  65. jal jmr3927_irc_irqdispatch
  66.  move a0, sp
  67. FLUSH_WB(t0)
  68. j ret_from_irq
  69.  nop
  70. END(jmr3927_IRQ)