OpenCores
URL https://opencores.org/ocsvn/openrisc_2011-10-31/openrisc_2011-10-31/trunk

Subversion Repositories openrisc_2011-10-31

[/] [openrisc/] [trunk/] [rtos/] [rtems/] [c/] [src/] [lib/] [libbsp/] [hppa1.1/] [simhppa/] [startup/] [setvec.c] - Rev 173

Compare with Previous | Blame | View Log

/*  set_vector
 *
 *  This routine installs an interrupt vector on the HP PA-RISC simulator.
 *
 *  INPUT:
 *    handler - interrupt handler entry point
 *    vector  - vector number
 *    type    - 0 indicates raw hardware connect
 *              1 indicates RTEMS interrupt connect
 *
 *  NOTE 'type' is ignored on hppa; all interrupts are owned by RTEMS
 *
 *  RETURNS:
 *    address of previous interrupt handler
 *
 *  COPYRIGHT (c) 1989-1999.
 *  On-Line Applications Research Corporation (OAR).
 *
 *  The license and distribution terms for this file may be
 *  found in the file LICENSE in this distribution or at
 *  http://www.OARcorp.com/rtems/license.html.
 *
 *  $Id: setvec.c,v 1.2 2001-09-27 11:59:45 chris Exp $
 */
 
#include <bsp.h>
 
/*
 * Install an interrupt handler in the right place
 * given its vector number from cpu/hppa.h
 * There are 2 places an interrupt can be installed
 *      _ISR_Vector_table
 *      bsp interrupt      XXX: nyi
 *
 * We decide which based on the vector number
 */
 
rtems_isr_entry
set_vector(                                     /* returns old vector */
    rtems_isr_entry     handler,                /* isr routine        */
    rtems_vector_number vector,                 /* vector number      */
    int                 type                    /* RTEMS or RAW intr  */
)
{
    rtems_isr_entry previous_isr;
 
    /* is it an on chip interrupt? */
    /* XXX this should say CPU_INTERRUPT_NUMBER_OF_VECTORS */
    if (vector < HPPA_INTERRUPT_MAX)
    {
        rtems_interrupt_catch(handler, vector, &previous_isr);
    }
#if 0   /* XXX */
    else if ((vector >= HPPA_INTERRUPT_BSP_BASE) &&
             (vector < (HPPA_INTERRUPT_BSP_BASE + HPPA_BSP_INTERRUPTS)))
    {
        pxfl_interrupt_install(handler,
                               vector - HPPA_INTERRUPT_BSP_BASE,
                               (rtems_isr_entry *) &previous_isr);
    }
#endif
 
    return previous_isr;
}
 
 

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.