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

4.104.114.84.95
Last change on this file since b1b5a7cb was 5bb00a8, checked in by Joel Sherrill <joel.sherrill@…>, on 09/11/96 at 19:13:44

added $Id$ string to file header

  • 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, 1990, 1991, 1992, 1993, 1994.
16 *  On-Line Applications Research Corporation (OAR).
17 *  All rights assigned to U.S. Government, 1994.
18 *
19 *  This material may be reproduced by or for the U.S. Government pursuant
20 *  to the copyright license under the clause at DFARS 252.227-7013.  This
21 *  notice must appear in all copies of this file and its derivatives.
22 *
23 *  $Id$
24 */
25
26#ifndef lint
27static char _sccsid[] = "@(#)setvec.c 04/25/96     1.2\n";
28#endif
29
30#include <rtems.h>
31#include <bsp.h>
32
33mips_isr_entry set_vector(                    /* returns old vector */
34  rtems_isr_entry     handler,                  /* isr routine        */
35  rtems_vector_number vector,                   /* vector number      */
36  int                 type                      /* RTEMS or RAW intr  */
37)
38{
39  mips_isr_entry previous_isr;
40
41  if ( type )
42    rtems_interrupt_catch( handler, vector, (rtems_isr_entry *) &previous_isr );
43  else {
44    /* XXX: install non-RTEMS ISR as "raw" interupt */
45    rtems_interrupt_catch( handler, vector, (rtems_isr_entry *) &previous_isr );
46  }
47  return previous_isr;
48}
49
Note: See TracBrowser for help on using the repository browser.