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

📄 m8260intrctl.c

📁 Embedded Planet公司的ep8260单板计算机的BSP包(VxWorks)
💻 C
📖 第 1 页 / 共 2 页
字号:
/* m8260IntrCtl.c - Motorola Voyager MPC 8260 interrupt controller driver */

/* Copyright 1984-1999 Wind River Systems, Inc. */
#include "copyright_wrs.h"

/*
modification history
--------------------
01i,30jul01,g_h  fix a problem with error interrupt.
01h,13jun01,g_h  change UINT32 intVec in m8260IntrDeMux() to VINT32 because DIAB
                 optimize to much.
01j,16sep99,ms_  m8260IntrCtl.h comes from h/drv/intrCtl
01i,16sep99,ms_  rename m8260Int.h to m8260IntrCtl.h
01h,15jul99,ms_  make compliant with our coding standards
01g,13may99,ms_  minor fixes
01f,17apr99,ms_  final cleanup for EAR
01e,15apr99,ms_  disable only lower priority interrupts while processing
                 interrupt
01d,13apr99,ms_  redefine IVEC_TO_INUM and INUM_TO_IVEC to use the numbers as
                 shown in the MPC8260 user's manaul
01c,12apr99,ms_  remove any sio specific items; that is handled in the sio
                 driver
01b,29mar99,ms_  add ability to mask out lower priority interrupts when
                 processing an interrupt
01a,22feb99,ms_  adapted from ppc8260Intr.c version 01f
*/

/*
DESCRIPTION
The PowerPC 8260 CPU is divided in three units: PowerPC core, System
Interface Unit (SIU) and Communication Processor Unit (CPM). The PowerPC
core accepts only one external interrupt exception (vector 0x500). The SIU
provides an interrupt controller which provides 55 interrupt sources
The Interrupt controller is connected to the PowerPC core external 
interrupt. This library provides the routines to manage this interrupt 
controllers.

m8260IntrInit() connects the default demultiplexer, m8260IntrDeMux(), to the 
external interrupt vector and initializes a table containing a function pointer
and an associated parameter for each interrupt source. m8260IntrInit() is called
by sysHwInit() from sysLib.c.

The default demultimplexer, m8260IntrDeMux() detects which peripheral or 
controller has raised an interrupt and calls the associated routine with its 
parameter. 

INCLUDE FILES: m8260IntrCtl.h
*/

/* includes */

#include "intLib.h"
#include "m8260IntrCtl.h"

#ifdef  INCLUDE_WINDVIEW
#include "private/funcBindP.h"
#include "private/eventP.h"
#endif /* INCLUDE_WINDVIEW */

/* local */

LOCAL INTR_HANDLER	intrVecTable[IVEC_MAX+1];	/*  Intr vector table */

/* SIU Interrupt Mask structure; a value for the high and low parts */
typedef struct siu_int_mask
    {
    UINT32	simr_h;
    UINT32	simr_l;
    } SIU_INT_MASK;

/* 
 * for a give inum, return a pair of masks, one for SIMR_H and one for SIMR_L,
 * which will enable only higher priority interrupts.
 */

LOCAL SIU_INT_MASK enableHighPriInts[] =
    {
    {0x00000000, 0x00000000},	/* interrupt 0 error - enable nothing */
    {0x003F7C06, 0xECF02658},		/* I2C */
    {0x0FFF7F06, 0xECF0A7DE},		/* SPI */
    {0x003F7C06, 0xECF00658},		/* RISC Timer Table */
    {0x3FFF7F06, 0xECF0E7DE},		/* SMC1 */
    {0x3FFF7F06, 0xECF0F7DE},		/* SMC2 */
    {0x00077C06, 0xECF00050},		/* IDMA1 */
    {0x001F7C06, 0xECF00450},		/* IDMA2 */
    {0x00FF7E06, 0xECF0A658},		/* IDMA3 */
    {0x0FFF7F06, 0xECF0A75E},		/* IDMA4 */
    {0x00077C06, 0xECF00010},		/* SDMA Bus Error */
    {0xFFFFFFFF, 0xFFFFFFFF},	/* interrupt 11 reserved - enable everything */
    {0x00017C06, 0xECF00000},		/* Timer 1 */
    {0x001F7C06, 0xECF00650},		/* Timer 2 */
    {0x00FF7F06, 0xECF0A758},		/* Timer 3 */
    {0x07FF7F06, 0xECF0A75C},		/* Timer 4 */
    {0x00000000, 0x00000000},		/* TMCNT */
    {0x00000004, 0x00000000},		/* PIT */
    {0xFFFFFFFF, 0xFFFFFFFF},	/* interrupt 18 reserved - enable everything */
    {0x00000006, 0x00000000},		/* IRQ1 XXXX */
    {0x00004006, 0xEC000000},		/* IRQ2 */
    {0x00006006, 0xEC000000},		/* IRQ3 */
    {0x00007006, 0xEC000000},		/* IRQ4 */
    {0x00007806, 0xEC000000},		/* IRQ5 */
    {0x00FF7C06, 0xECF0A658},		/* IRQ6 */
    {0x00FF7E06, 0xECF0A758},		/* IRQ7 */
    {0xFFFFFFFF, 0xFFFFFFFF},	/* interrupt 26 reserved - enable everything */
    {0x00004006, 0x00000000},		/* FCC1 */
    {0x00004006, 0x80000000},		/* FCC2 */
    {0x00004006, 0xC0000000},		/* FCC3 */
    {0xFFFFFFFF, 0xFFFFFFFF},	/* interrupt 30 reserved - enable everything */
    {0x00004006, 0xE0000000},		/* MCC1 */
    {0x00004006, 0xE8000000},		/* MCC2 */
    {0xFFFFFFFF, 0xFFFFFFFF},	/* interrupt 33 reserved - enable everything */
    {0xFFFFFFFF, 0xFFFFFFFF},	/* interrupt 34 reserved - enable everything */
    {0x00007C06, 0xEC000000},		/* SCC1 */
    {0x00007C06, 0xEC800000},		/* SCC2 */
    {0x00007C06, 0xECC00000},		/* SCC3 */
    {0x00007C06, 0xECE00000},		/* SCC4 */
    {0xFFFFFFFF, 0xFFFFFFFF},	/* interrupt 39 reserved - enable everything */
    {0x00007C06, 0xECF00000},		/* PC15 */
    {0x00017C06, 0xECF00010},		/* PC14 */
    {0x00037C06, 0xECF00010},		/* PC13 */
    {0x00077C06, 0xECF00450},		/* PC12 */
    {0x000F7C06, 0xECF00450},		/* PC11 */
    {0x001F7C06, 0xECF00658},		/* PC10 */
    {0x003F7C06, 0xECF0A658},		/* PC9 */
    {0x007F7C06, 0xECF0A658},		/* PC8 */
    {0x00FF7F06, 0xECF0A75C},		/* PC7 */
    {0x01FF7F06, 0xECF0A75C},		/* PC6 */
    {0x03FF7F06, 0xECF0A75C},		/* PC5 */
    {0x07FF7F06, 0xECF0A75E},		/* PC4 */
    {0x0FFF7F06, 0xECF0E7DE},		/* PC3 */
    {0x1FFF7F06, 0xECF0E7DE},		/* PC2 */
    {0x3FFF7F06, 0xECF0FFDE},		/* PC1 */
    {0x7FFF7F06, 0xECF0FFDE}		/* PC0 */
    };



LOCAL UINT32		iNumToMaskPattern[] = 
    {
    0x00000000,			/* interrupt number 0: Error */
    0x00008000,			/* interrupt number 1: I2C */
    0x00004000,			/* interrupt number 2: SPI */
    0x00002000,			/* interrupt number 3: Risc Timer Table */
    0x00001000,			/* interrupt number 4: SMC 1 */
    0x00000800,			/* interrupt number 5: SMC 2 */
    0x00000400,			/* interrupt number 6: IDMA1 */
    0x00000200,			/* interrupt number 7: IDMA2 */
    0x00000100,			/* interrupt number 8: IDMA3 */
    0x00000080,			/* interrupt number 9: IDMA4 */
    0x00000040,			/* interrupt number 10: SDMA */
    0x00000000,			/* interrupt number 11: reserved */
    0x00000010,			/* interrupt number 12: Timer 1 */
    0x00000008,			/* interrupt number 13: Timer 2 */
    0x00000004,			/* interrupt number 14: Timer 3 */
    0x00000002,			/* interrupt number 15: Timer 4 */
    0x00000004,			/* interrupt number 16: TMCNT */
    0x00000002,			/* interrupt number 17: PIT */
    0x00000000,			/* interrupt number 18: reserved */
    0x00004000,			/* interrupt number 19: IRQ 1 interrupt */
    0x00002000,			/* interrupt number 20: IRQ 2 interrupt */
    0x00001000,			/* interrupt number 21: IRQ 3 interrupt */
    0x00000800,			/* interrupt number 22: IRQ 4 interrupt */
    0x00000400,			/* interrupt number 23: IRQ 5 interrupt */
    0x00000200,			/* interrupt number 24: IRQ 6 interrupt */
    0x00000100,			/* interrupt number 25: IRQ 7 interrupt */
    0x00000000,			/* interrupt number 26: reserved */
    0x80000000,			/* interrupt number 27: FCC1 */
    0x40000000,			/* interrupt number 28: FCC2 */
    0x20000000,			/* interrupt number 29: FCC3 */
    0x00000000,			/* interrupt number 30: reserved */
    0x08000000,			/* interrupt number 31: MCC1 */
    0x04000000,			/* interrupt number 32: MCC2 */
    0x00000000,			/* interrupt number 33: reserved */
    0x00000000,			/* interrupt number 34: reserved */
    0x00800000,			/* interrupt number 35: SCC1 */
    0x00400000,			/* interrupt number 36: SCC2 */
    0x00200000,			/* interrupt number 37: SCC3 */
    0x00100000,			/* interrupt number 38: SCC4 */
    0x00000000,			/* interrupt number 39: reserved */
    0x00010000,			/* interrupt number 40: Parallel I/O [15] */
    0x00020000,			/* interrupt number 41: Parallel I/O [14] */
    0x00040000,			/* interrupt number 42: Parallel I/O [13] */
    0x00080000,			/* interrupt number 43: Parallel I/O [12] */
    0x00100000,			/* interrupt number 44: Parallel I/O [11] */
    0x00200000,			/* interrupt number 45: Parallel I/O [10] */
    0x00400000,			/* interrupt number 46: Parallel I/O [9] */
    0x00800000,			/* interrupt number 47: Parallel I/O [8] */
    0x01000000,			/* interrupt number 48: Parallel I/O [7] */
    0x02000000,			/* interrupt number 49: Parallel I/O [6] */
    0x04000000,			/* interrupt number 50: Parallel I/O [5] */
    0x08000000,			/* interrupt number 51: Parallel I/O [4] */
    0x10000000,			/* interrupt number 52: Parallel I/O [3] */
    0x20000000,			/* interrupt number 53: Parallel I/O [2] */
    0x40000000,			/* interrupt number 54: Parallel I/O [1] */
    0x80000000			/* interrupt number 55: Parallel I/O [0] */
    };

/* forward declarations */

LOCAL void	 m8260IntrDeMux (void);
LOCAL STATUS m8260IntConnect (VOIDFUNCPTR *, VOIDFUNCPTR, int);

/*******************************************************************************
*
* m8260IntrInit - initialize the interrupt manager for the PowerPC 8260
*
* This routine connects the default demultiplexer, m8260IntrDeMux(), to the 
* external interrupt vector and associates all 
* interrupt sources with the default interrupt handler.  This routine is
* called by sysHwInit() in sysLib.c.
*
* NOTE: All interrupt from the SIU unit are enabled, CICR is setup so
* that SCC1 has the highest relative interrupt priority, through SCC4 with the
* lowest.
*
* RETURN : OK always
*/

STATUS m8260IntrInit 
    (
    )
    {
    VOIDFUNCPTR defaultVec;     	/* INTR3 default vector */
    int		vector;

	UINT32 immrVal = vxImmrGet();

    /* Get the default vector connected to the External Interrupt (0x500) */
    
	defaultVec = (VOIDFUNCPTR) excVecGet ((FUNCPTR *) _EXC_OFF_INTR);

    /* Connect the interrupt demultiplexer to External Interrupt (0x500) */

    excIntConnect ((VOIDFUNCPTR *) _EXC_OFF_INTR, m8260IntrDeMux);

    /* Install `system' intConnect routine */

    if (_func_intConnectRtn == NULL)
        _func_intConnectRtn = m8260IntConnect;

    if (_func_intEnableRtn == NULL)
        _func_intEnableRtn = m8260IntEnable;

    if (_func_intDisableRtn == NULL)
        _func_intDisableRtn = m8260IntDisable;

    /* Set all vectors to default handler */

    for (vector = 0; vector <= IVEC_MAX; vector++)
	intConnect (INUM_TO_IVEC(vector), (VOIDFUNCPTR) defaultVec, 0); 

    /* disable all interrupts */

    *M8260_SIMR_L(immrVal) = 0x00000000;
    *M8260_SIMR_H(immrVal) = 0x00000000;

    return (OK);
 
    }

⌨️ 快捷键说明

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