亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? interrupt.c

?? STM32+Grlib
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):

//*****************************************************************************
//
//! Sets the priority of an interrupt.
//!
//! \param ulInterrupt specifies the interrupt in question.
//! \param ucPriority specifies the priority of the interrupt.
//!
//! This function is used to set the priority of an interrupt.  When multiple
//! interrupts are asserted simultaneously, the ones with the highest priority
//! are processed before the lower priority interrupts.  Smaller numbers
//! correspond to higher interrupt priorities; priority 0 is the highest
//! interrupt priority.
//!
//! The hardware priority mechanism will only look at the upper N bits of the
//! priority level (where N is 3 for the Stellaris family), so any
//! prioritization must be performed in those bits.  The remaining bits can be
//! used to sub-prioritize the interrupt sources, and may be used by the
//! hardware priority mechanism on a future part.  This arrangement allows
//! priorities to migrate to different NVIC implementations without changing
//! the gross prioritization of the interrupts.
//!
//! \return None.
//
//*****************************************************************************
void
IntPrioritySet(unsigned long ulInterrupt, unsigned char ucPriority)
{
    unsigned long ulTemp;

    //
    // Check the arguments.
    //
    ASSERT((ulInterrupt >= 4) && (ulInterrupt < NUM_INTERRUPTS));

    //
    // Set the interrupt priority.
    //
    ulTemp = HWREG(g_pulRegs[ulInterrupt >> 2]);
    ulTemp &= ~(0xFF << (8 * (ulInterrupt & 3)));
    ulTemp |= ucPriority << (8 * (ulInterrupt & 3));
    HWREG(g_pulRegs[ulInterrupt >> 2]) = ulTemp;
}

//*****************************************************************************
//
//! Gets the priority of an interrupt.
//!
//! \param ulInterrupt specifies the interrupt in question.
//!
//! This function gets the priority of an interrupt.  See IntPrioritySet() for
//! a definition of the priority value.
//!
//! \return Returns the interrupt priority, or -1 if an invalid interrupt was
//! specified.
//
//*****************************************************************************
long
IntPriorityGet(unsigned long ulInterrupt)
{
    //
    // Check the arguments.
    //
    ASSERT((ulInterrupt >= 4) && (ulInterrupt < NUM_INTERRUPTS));

    //
    // Return the interrupt priority.
    //
    return((HWREG(g_pulRegs[ulInterrupt >> 2]) >> (8 * (ulInterrupt & 3))) &
           0xFF);
}

//*****************************************************************************
//
//! Enables an interrupt.
//!
//! \param ulInterrupt specifies the interrupt to be enabled.
//!
//! The specified interrupt is enabled in the interrupt controller.  Other
//! enables for the interrupt (such as at the peripheral level) are unaffected
//! by this function.
//!
//! \return None.
//
//*****************************************************************************
void
IntEnable(unsigned long ulInterrupt)
{
    //
    // Check the arguments.
    //
    ASSERT(ulInterrupt < NUM_INTERRUPTS);

    //
    // Determine the interrupt to enable.
    //
    if(ulInterrupt == FAULT_MPU)
    {
        //
        // Enable the MemManage interrupt.
        //
        HWREG(NVIC_SYS_HND_CTRL) |= NVIC_SYS_HND_CTRL_MEM;
    }
    else if(ulInterrupt == FAULT_BUS)
    {
        //
        // Enable the bus fault interrupt.
        //
        HWREG(NVIC_SYS_HND_CTRL) |= NVIC_SYS_HND_CTRL_BUS;
    }
    else if(ulInterrupt == FAULT_USAGE)
    {
        //
        // Enable the usage fault interrupt.
        //
        HWREG(NVIC_SYS_HND_CTRL) |= NVIC_SYS_HND_CTRL_USAGE;
    }
    else if(ulInterrupt == FAULT_SYSTICK)
    {
        //
        // Enable the System Tick interrupt.
        //
        HWREG(NVIC_ST_CTRL) |= NVIC_ST_CTRL_INTEN;
    }
    else if((ulInterrupt >= 16) && (ulInterrupt <= 47))
    {
        //
        // Enable the general interrupt.
        //
        HWREG(NVIC_EN0) = 1 << (ulInterrupt - 16);
    }
    else if(ulInterrupt >= 48)
    {
        //
        // Enable the general interrupt.
        //
        HWREG(NVIC_EN1) = 1 << (ulInterrupt - 48);
    }
}

//*****************************************************************************
//
//! Disables an interrupt.
//!
//! \param ulInterrupt specifies the interrupt to be disabled.
//!
//! The specified interrupt is disabled in the interrupt controller.  Other
//! enables for the interrupt (such as at the peripheral level) are unaffected
//! by this function.
//!
//! \return None.
//
//*****************************************************************************
void
IntDisable(unsigned long ulInterrupt)
{
    //
    // Check the arguments.
    //
    ASSERT(ulInterrupt < NUM_INTERRUPTS);

    //
    // Determine the interrupt to disable.
    //
    if(ulInterrupt == FAULT_MPU)
    {
        //
        // Disable the MemManage interrupt.
        //
        HWREG(NVIC_SYS_HND_CTRL) &= ~(NVIC_SYS_HND_CTRL_MEM);
    }
    else if(ulInterrupt == FAULT_BUS)
    {
        //
        // Disable the bus fault interrupt.
        //
        HWREG(NVIC_SYS_HND_CTRL) &= ~(NVIC_SYS_HND_CTRL_BUS);
    }
    else if(ulInterrupt == FAULT_USAGE)
    {
        //
        // Disable the usage fault interrupt.
        //
        HWREG(NVIC_SYS_HND_CTRL) &= ~(NVIC_SYS_HND_CTRL_USAGE);
    }
    else if(ulInterrupt == FAULT_SYSTICK)
    {
        //
        // Disable the System Tick interrupt.
        //
        HWREG(NVIC_ST_CTRL) &= ~(NVIC_ST_CTRL_INTEN);
    }
    else if((ulInterrupt >= 16) && (ulInterrupt <= 47))
    {
        //
        // Disable the general interrupt.
        //
        HWREG(NVIC_DIS0) = 1 << (ulInterrupt - 16);
    }
    else if(ulInterrupt >= 48)
    {
        //
        // Disable the general interrupt.
        //
        HWREG(NVIC_DIS1) = 1 << (ulInterrupt - 48);
    }
}

//*****************************************************************************
//
//! Pends an interrupt.
//!
//! \param ulInterrupt specifies the interrupt to be pended.
//!
//! The specified interrupt is pended in the interrupt controller.  This will
//! cause the interrupt controller to execute the corresponding interrupt
//! handler at the next available time, based on the current interrupt state
//! priorities.  For example, if called by a higher priority interrupt handler,
//! the specified interrupt handler will not be called until after the current
//! interrupt handler has completed execution.  The interrupt must have been
//! enabled for it to be called.
//!
//! \return None.
//
//*****************************************************************************
void
IntPendSet(unsigned long ulInterrupt)
{
    //
    // Check the arguments.
    //
    ASSERT(ulInterrupt < NUM_INTERRUPTS);

    //
    // Determine the interrupt to pend.
    //
    if(ulInterrupt == FAULT_NMI)
    {
        //
        // Pend the NMI interrupt.
        //
        HWREG(NVIC_INT_CTRL) |= NVIC_INT_CTRL_NMI_SET;
    }
    else if(ulInterrupt == FAULT_PENDSV)
    {
        //
        // Pend the PendSV interrupt.
        //
        HWREG(NVIC_INT_CTRL) |= NVIC_INT_CTRL_PEND_SV;
    }
    else if(ulInterrupt == FAULT_SYSTICK)
    {
        //
        // Pend the SysTick interrupt.
        //
        HWREG(NVIC_INT_CTRL) |= NVIC_INT_CTRL_PENDSTSET;
    }
    else if((ulInterrupt >= 16) && (ulInterrupt <= 47))
    {
        //
        // Pend the general interrupt.
        //
        HWREG(NVIC_PEND0) = 1 << (ulInterrupt - 16);
    }
    else if(ulInterrupt >= 48)
    {
        //
        // Pend the general interrupt.
        //
        HWREG(NVIC_PEND1) = 1 << (ulInterrupt - 48);
    }
}

//*****************************************************************************
//
//! Unpends an interrupt.
//!
//! \param ulInterrupt specifies the interrupt to be unpended.
//!
//! The specified interrupt is unpended in the interrupt controller.  This will
//! cause any previously generated interrupts that have not been handled yet
//! (due to higher priority interrupts or the interrupt no having been enabled
//! yet) to be discarded.
//!
//! \return None.
//
//*****************************************************************************
void
IntPendClear(unsigned long ulInterrupt)
{
    //
    // Check the arguments.
    //
    ASSERT(ulInterrupt < NUM_INTERRUPTS);

    //
    // Determine the interrupt to unpend.
    //
    if(ulInterrupt == FAULT_PENDSV)
    {
        //
        // Unpend the PendSV interrupt.
        //
        HWREG(NVIC_INT_CTRL) |= NVIC_INT_CTRL_UNPEND_SV;
    }
    else if(ulInterrupt == FAULT_SYSTICK)
    {
        //
        // Unpend the SysTick interrupt.
        //
        HWREG(NVIC_INT_CTRL) |= NVIC_INT_CTRL_PENDSTCLR;
    }
    else if((ulInterrupt >= 16) && (ulInterrupt <= 47))
    {
        //
        // Unpend the general interrupt.
        //
        HWREG(NVIC_UNPEND0) = 1 << (ulInterrupt - 16);
    }
    else if(ulInterrupt >= 48)
    {
        //
        // Unpend the general interrupt.
        //
        HWREG(NVIC_UNPEND1) = 1 << (ulInterrupt - 48);
    }
}

//*****************************************************************************
//
// Close the Doxygen group.
//! @}
//
//*****************************************************************************

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲影院免费观看| 中文字幕一区日韩精品欧美| 午夜成人免费视频| 欧美体内she精高潮| 亚洲福利一二三区| 91精品国产aⅴ一区二区| 日韩av二区在线播放| 欧美一区二区国产| 国内精品视频一区二区三区八戒 | 亚洲国产精品ⅴa在线观看| 国产福利91精品一区二区三区| 久久久噜噜噜久久人人看| 国产一区二区三区精品视频| 欧美日韩国产色站一区二区三区| 久久久久成人黄色影片| k8久久久一区二区三区| **性色生活片久久毛片| 欧美三级在线播放| 久久精品噜噜噜成人88aⅴ| 国产精品久久久久久久久果冻传媒| 色综合久久久久| 日本aⅴ免费视频一区二区三区| 久久久综合精品| 在线观看日韩电影| 精品一区免费av| 日韩码欧中文字| 日韩精品一区在线| 91美女片黄在线| 激情欧美一区二区三区在线观看| 国产精品国产三级国产普通话三级 | 成人免费毛片app| 一区二区三区四区国产精品| 日韩视频中午一区| 91视频在线观看| 韩国一区二区视频| 一区二区激情视频| 久久你懂得1024| 91麻豆精品国产自产在线观看一区| 国产成人啪午夜精品网站男同| 亚洲成人激情av| 国产精品美女久久久久高潮| 欧美一级久久久久久久大片| av高清久久久| 国产一区二区h| 免费成人av资源网| 亚洲综合久久久| 亚洲欧洲精品成人久久奇米网| 欧美一区二区三区系列电影| 99精品桃花视频在线观看| 狠狠色2019综合网| 男女男精品视频| 天天综合色天天综合色h| 亚洲人午夜精品天堂一二香蕉| 精品福利视频一区二区三区| 欧美三电影在线| 91九色02白丝porn| 99精品欧美一区| 国产成人午夜高潮毛片| 久久精品久久精品| 青草国产精品久久久久久| 亚洲伊人色欲综合网| 亚洲色图色小说| 中文字幕一区二区三区乱码在线 | 色综合一区二区三区| 高清视频一区二区| 国产成人99久久亚洲综合精品| 久久爱另类一区二区小说| 日韩制服丝袜av| 天天影视涩香欲综合网| 三级在线观看一区二区| 亚洲r级在线视频| 亚洲妇女屁股眼交7| 亚洲综合色噜噜狠狠| 亚洲精品视频观看| 亚洲女爱视频在线| 亚洲精品综合在线| 亚洲午夜精品在线| 婷婷成人激情在线网| 日韩国产欧美在线视频| 免费看精品久久片| 国产在线乱码一区二区三区| 久久精品国产999大香线蕉| 久国产精品韩国三级视频| 老色鬼精品视频在线观看播放| 久久av资源网| 国产成人免费视频一区| 99精品视频在线观看| 色综合天天综合网国产成人综合天| 色婷婷综合久久久中文一区二区| 色播五月激情综合网| 欧美日韩一级大片网址| 日韩一区二区在线看| 久久品道一品道久久精品| 中文字幕久久午夜不卡| 亚洲免费伊人电影| 五月婷婷综合在线| 国产又粗又猛又爽又黄91精品| 国产91精品久久久久久久网曝门| 成人av第一页| 欧美日韩在线播放| 久久综合网色—综合色88| 中文字幕在线观看一区| 亚洲午夜久久久久久久久电影院| 青青青爽久久午夜综合久久午夜| 精品影院一区二区久久久| 99久久伊人久久99| 欧美三级视频在线播放| 日韩女优电影在线观看| 国产精品拍天天在线| 亚洲成人在线观看视频| 国产毛片精品国产一区二区三区| 99re亚洲国产精品| 日韩欧美国产不卡| 中文字幕欧美一| 日韩av网站在线观看| 9色porny自拍视频一区二区| 欧美视频精品在线| 久久精品人人做人人爽97| 亚洲成人动漫精品| 国产不卡免费视频| 欧美日韩国产美| 国产精品素人视频| 日本va欧美va瓶| 色欧美片视频在线观看 | 欧美丝袜自拍制服另类| 精品sm捆绑视频| 亚洲综合精品自拍| 盗摄精品av一区二区三区| 欧美日韩一区二区在线观看 | 国产午夜精品一区二区三区嫩草| 亚洲男人的天堂在线aⅴ视频| 免费成人av资源网| 在线观看一区日韩| 国产精品久久久久久久久久久免费看| 日产国产欧美视频一区精品| 99久久久精品| 久久久久久久av麻豆果冻| 婷婷综合另类小说色区| 99国产精品视频免费观看| 欧美成人性福生活免费看| 亚洲高清免费观看 | 国产精品入口麻豆九色| 美女视频网站久久| 欧美日韩亚洲另类| 自拍av一区二区三区| 国产成人高清视频| 欧美成人一区二区三区在线观看| 亚洲午夜在线观看视频在线| 成人精品视频一区二区三区| 精品久久免费看| 免费的成人av| 欧美一级国产精品| 亚洲va韩国va欧美va| 91国偷自产一区二区开放时间| 国产精品高潮久久久久无| 丁香亚洲综合激情啪啪综合| 精品国产露脸精彩对白| 久久草av在线| 欧美成人aa大片| 国产最新精品精品你懂的| 欧美成人猛片aaaaaaa| 蜜乳av一区二区| 欧美成人女星排行榜| 久久国内精品视频| 日韩一区二区精品| 久久99精品国产.久久久久久| 日韩欧美一区电影| 九九精品视频在线看| 精品国产一区二区三区忘忧草| 麻豆精品一区二区综合av| 精品福利在线导航| 国产成人av资源| 国产精品蜜臀av| 色婷婷av一区二区三区gif| 洋洋成人永久网站入口| 欧洲一区在线电影| 三级久久三级久久| www日韩大片| 风间由美一区二区av101| 中文字幕一区二区三区av | 欧美日韩在线亚洲一区蜜芽| 亚洲成a人v欧美综合天堂 | 国产精品系列在线播放| 国产午夜精品在线观看| 波多野结衣精品在线| 亚洲激情欧美激情| 欧美一区二区日韩一区二区| 日本欧美一区二区在线观看| 欧美成人官网二区| 成人精品视频.| 亚洲一区精品在线| 欧美一区二区性放荡片| 国产美女娇喘av呻吟久久| 欧美精彩视频一区二区三区| 91网站在线播放| 偷窥少妇高潮呻吟av久久免费| 精品黑人一区二区三区久久| 成人小视频在线观看| 一区二区欧美视频| 日韩免费性生活视频播放|