source: rtems/c/src/lib/libbsp/mips/p4000/startup/setvec.c @ 08311cc3

4.104.114.84.95
Last change on this file since 08311cc3 was 08311cc3, checked in by Joel Sherrill <joel.sherrill@…>, on 11/17/99 at 17:51:34

Updated copyright notice.

  • Property mode set to 100644
File size: 1.5 KB
Line 
1/*  set_vector
2 *
3 *  This routine installs an interrupt vector on the target Board/CPU.
4 *  This routine is allowed to be as board dependent as necessary.
5 *
6 *  INPUT:
7 *    handler - interrupt handler entry point
8 *    vector  - vector number
9 *    type    - 0 indicates raw hardware connect
10 *              1 indicates RTEMS interrupt connect
11 *
12 *  RETURNS:
13 *    address of previous interrupt handler
14 *
15 *  COPYRIGHT (c) 1989-1999.
16 *  On-Line Applications Research Corporation (OAR).
17 *
18 *  The license and distribution terms for this file may be
19 *  found in the file LICENSE in this distribution or at
20 *  http://www.OARcorp.com/rtems/license.html.
21 *
22 *  $Id$
23 */
24
25/*
26 *  Rather than deleting this, it is commented out to (hopefully) help
27 *  the submitter send updates.
28 *
29 *  static char _sccsid[] = "@(#)setvec.c 04/25/96     1.2\n";
30 */
31
32
33#include <rtems.h>
34#include <bsp.h>
35
36mips_isr_entry set_vector(                    /* returns old vector */
37  rtems_isr_entry     handler,                  /* isr routine        */
38  rtems_vector_number vector,                   /* vector number      */
39  int                 type                      /* RTEMS or RAW intr  */
40)
41{
42  mips_isr_entry previous_isr;
43
44  if ( type )
45    rtems_interrupt_catch( handler, vector, (rtems_isr_entry *) &previous_isr );
46  else {
47    /* XXX: install non-RTEMS ISR as "raw" interupt */
48    rtems_interrupt_catch( handler, vector, (rtems_isr_entry *) &previous_isr );
49  }
50  return previous_isr;
51}
52
Note: See TracBrowser for help on using the repository browser.