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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? xgpio_intr.c

?? 關于xilinx大學計劃配需教程實驗五源代碼
?? C
字號:
/* $Id *//********************************************************************************       XILINX IS PROVIDING THIS DESIGN, CODE, OR INFORMATION "AS IS"*       AS A COURTESY TO YOU, SOLELY FOR USE IN DEVELOPING PROGRAMS AND*       SOLUTIONS FOR XILINX DEVICES.  BY PROVIDING THIS DESIGN, CODE,*       OR INFORMATION AS ONE POSSIBLE IMPLEMENTATION OF THIS FEATURE,*       APPLICATION OR STANDARD, XILINX IS MAKING NO REPRESENTATION*       THAT THIS IMPLEMENTATION IS FREE FROM ANY CLAIMS OF INFRINGEMENT,*       AND YOU ARE RESPONSIBLE FOR OBTAINING ANY RIGHTS YOU MAY REQUIRE*       FOR YOUR IMPLEMENTATION.  XILINX EXPRESSLY DISCLAIMS ANY*       WARRANTY WHATSOEVER WITH RESPECT TO THE ADEQUACY OF THE*       IMPLEMENTATION, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OR*       REPRESENTATIONS THAT THIS IMPLEMENTATION IS FREE FROM CLAIMS OF*       INFRINGEMENT, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS*       FOR A PARTICULAR PURPOSE.**       (c) Copyright 2002 - 2004 Xilinx Inc.*       All rights reserved.*******************************************************************************//*****************************************************************************//*** @file xgpio_intr.c** Implements GPIO interrupt processing functions for the XGpio * component. See xgpio.h for more information about the component.* * The functions in this file require the hardware device to be built with * interrupt capabilities. The functions will assert if called using hardware* that does not have interrupt capabilities.** <pre>* MODIFICATION HISTORY:** Ver   Who  Date     Changes* ----- ---- -------- -----------------------------------------------* 2.00a jhl  11/26/03 Initial release* </pre>******************************************************************************//***************************** Include Files ********************************/#include "xgpio.h"#include "xipif_v1_23_b.h"/************************** Constant Definitions ****************************//* The following constant describes the offset of the interrupt registers * that are contained in the IPIF.  This offset should be added to the base * address of the device when using the IPIF access functions. */#define XGPIO_IPIF_OFFSET 0x100/**************************** Type Definitions ******************************//***************** Macros (Inline Functions) Definitions ********************//************************** Variable Definitions ****************************//************************** Function Prototypes *****************************//****************************************************************************//*** Enable the interrupt output signal. Interrupts enabled through* XGpio_InterruptEnable() will not be passed through until the global enable* bit is set by this function.  This function is designed to allow all * interrupts (both channels) to be enabled easily for exiting a critical* section. This function will assert if the hardware device has not been * built with interrupt capabilities.** @param InstancePtr is the GPIO component to operate on.* * @return** None.** @note** None.******************************************************************************/void XGpio_InterruptGlobalEnable(XGpio *InstancePtr){    XASSERT_VOID(InstancePtr != XNULL);    XASSERT_VOID(InstancePtr->IsReady == XCOMPONENT_IS_READY);    XASSERT_VOID(InstancePtr->InterruptPresent == XTRUE);    XIIF_V123B_GINTR_ENABLE(InstancePtr->BaseAddress + XGPIO_IPIF_OFFSET);}/****************************************************************************//*** Disable the interrupt output signal. Interrupts enabled through* XGpio_InterruptEnable() will no longer be passed through until the global * enable bit is set by XGpio_InterruptGlobalEnable(). This function is * designed to allow all interrupts (both channels) to be disabled easily for* entering a critical section. This function will assert if the hardware * device has not been built with interrupt capabilities.** @param InstancePtr is the GPIO component to operate on.** @return** None.* * @note** None.******************************************************************************/void XGpio_InterruptGlobalDisable(XGpio *InstancePtr){    XASSERT_VOID(InstancePtr != XNULL);    XASSERT_VOID(InstancePtr->IsReady == XCOMPONENT_IS_READY);    XASSERT_VOID(InstancePtr->InterruptPresent == XTRUE);        XIIF_V123B_GINTR_DISABLE(InstancePtr->BaseAddress + XGPIO_IPIF_OFFSET); }/****************************************************************************//*** Enable interrupts. The global interrupt must also be enabled by calling* XGpio_InterruptGlobalEnable() for interrupts to occur. This function will * assert if the hardware device has not been built with interrupt capabilities.** @param InstancePtr is the GPIO component to operate on.* @param Mask is the mask to enable. Bit positions of 1 are enabled. This mask*        is formed by OR'ing bits from XGPIO_IR* bits which are contained in *        xgpio_l.h.* * @return** None.* * @note** None.******************************************************************************/void XGpio_InterruptEnable(XGpio *InstancePtr, Xuint32 Mask){    Xuint32 Register;    XASSERT_VOID(InstancePtr != XNULL);    XASSERT_VOID(InstancePtr->IsReady == XCOMPONENT_IS_READY);    XASSERT_VOID(InstancePtr->InterruptPresent == XTRUE);    /* Read the interrupt enable register and only enable the specified     * interrupts without disabling or enabling any others.     */      Register = XIIF_V123B_READ_IIER(InstancePtr->BaseAddress +                                     XGPIO_IPIF_OFFSET);    XIIF_V123B_WRITE_IIER(InstancePtr->BaseAddress + XGPIO_IPIF_OFFSET,                           Mask | Register);}/****************************************************************************//*** Disable interrupts. This function allows specific interrupts for each * channel to be disabled. This function will assert if the hardware device * has not been built with interrupt capabilities. ** @param InstancePtr is the GPIO component to operate on.* @param Mask is the mask to disable. Bits set to 1 are disabled. This mask *        is formed by OR'ing bits from XGPIO_IR* bits which are contained in *        xgpio_l.h.* * @return** None.* * @note** None.******************************************************************************/void XGpio_InterruptDisable(XGpio *InstancePtr, Xuint32 Mask){    Xuint32 Register;    XASSERT_VOID(InstancePtr != XNULL);    XASSERT_VOID(InstancePtr->IsReady == XCOMPONENT_IS_READY);    XASSERT_VOID(InstancePtr->InterruptPresent == XTRUE);    /* Read the interrupt enable register and only disable the specified     * interrupts without enabling or disabling any others.     */      Register = XIIF_V123B_READ_IIER(InstancePtr->BaseAddress +                                     XGPIO_IPIF_OFFSET);    XIIF_V123B_WRITE_IIER(InstancePtr->BaseAddress + XGPIO_IPIF_OFFSET,                           Mask & ~Register);}/****************************************************************************//*** Clear pending interrupts with the provided mask. This function should be* called after the software has serviced the interrupts that are pending.* This function will assert if the hardware device has not been built with * interrupt capabilities.* * @param InstancePtr is the GPIO component to operate on.* @param Mask is the mask to clear pending interrupts for. Bit positions of 1 *        are cleared. This mask is formed by OR'ing bits from*        XGPIO_IR* bits which are contained in xgpio_l.h.* * @return** None.* * @note** None.******************************************************************************/void XGpio_InterruptClear(XGpio *InstancePtr, Xuint32 Mask){    Xuint32 Register;    XASSERT_VOID(InstancePtr != XNULL);    XASSERT_VOID(InstancePtr->IsReady == XCOMPONENT_IS_READY);        XASSERT_VOID(InstancePtr->InterruptPresent == XTRUE);    /* Read the interrupt status register and only clear the interrupts      * that are specified without affecting any others.  Since the register     * is a toggle on write, make sure any bits to be written are already      * set.     */      Register = XIIF_V123B_READ_IISR(InstancePtr->BaseAddress +                                     XGPIO_IPIF_OFFSET);    XIIF_V123B_WRITE_IISR(InstancePtr->BaseAddress + XGPIO_IPIF_OFFSET,                           Register & Mask);}/****************************************************************************//*** Returns the interrupt enable mask. This function will assert if the * hardware device has not been built with interrupt capabilities.** @param InstancePtr is the GPIO component to operate on.* * @return A mask of bits made from XGPIO_IR* bits which are contained in *         xgpio_l.h.  ** @return** None.* * @note** None.******************************************************************************/Xuint32 XGpio_InterruptGetEnabled(XGpio *InstancePtr){    XASSERT_NONVOID(InstancePtr != XNULL);    XASSERT_NONVOID(InstancePtr->IsReady == XCOMPONENT_IS_READY);        XASSERT_NONVOID(InstancePtr->InterruptPresent == XTRUE);    return XIIF_V123B_READ_IIER(InstancePtr->BaseAddress + XGPIO_IPIF_OFFSET);}/****************************************************************************//*** Returns the status of interrupt signals. Any bit in the mask set to 1 * indicates that the channel associated with the bit has asserted an interrupt* condition. This function will assert if the hardware device has not been * built with interrupt capabilities.** @param InstancePtr is the GPIO component to operate on.* * @return A pointer to a mask of bits made from XGPIO_IR* bits which are *         contained in xgpio_l.h.  ** @note** The interrupt status indicates the status of the device irregardless if* the interrupts from the devices have been enabled or not through* XGpio_InterruptEnable().******************************************************************************/Xuint32 XGpio_InterruptGetStatus(XGpio *InstancePtr){    XASSERT_NONVOID(InstancePtr != XNULL);    XASSERT_NONVOID(InstancePtr->IsReady == XCOMPONENT_IS_READY);        XASSERT_NONVOID(InstancePtr->InterruptPresent == XTRUE);    return XIIF_V123B_READ_IISR(InstancePtr->BaseAddress + XGPIO_IPIF_OFFSET);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99re6这里只有精品视频在线观看| 欧美精品在线视频| 一本到不卡精品视频在线观看| 91视视频在线直接观看在线看网页在线看| 色偷偷久久一区二区三区| 欧美亚洲综合另类| 26uuu亚洲综合色| 中文字幕制服丝袜一区二区三区| 亚洲精品欧美在线| 婷婷丁香激情综合| 粉嫩蜜臀av国产精品网站| 成人av资源在线| 911精品国产一区二区在线| 久久影视一区二区| 一区二区国产盗摄色噜噜| 免费观看在线综合| av在线这里只有精品| 欧美一级黄色片| 亚洲欧洲日韩在线| 免费在线观看视频一区| 成人激情开心网| 欧美年轻男男videosbes| 久久新电视剧免费观看| 洋洋av久久久久久久一区| 精品在线免费视频| 91福利精品第一导航| www国产成人| 天堂蜜桃91精品| av在线播放不卡| 欧美成人r级一区二区三区| 一区视频在线播放| 久久国产乱子精品免费女| 一本一道久久a久久精品综合蜜臀| 日韩欧美亚洲国产精品字幕久久久| 自拍偷拍亚洲综合| 国产美女av一区二区三区| 欧美日韩国产一区| 亚洲色图制服诱惑| 国产高清在线精品| 欧美一级国产精品| 亚洲国产精品久久久久婷婷884| 国产成人在线网站| 日韩三级精品电影久久久| 一区二区三区不卡在线观看| 粉嫩av一区二区三区粉嫩 | 婷婷丁香激情综合| 色狠狠综合天天综合综合| 国产日韩欧美一区二区三区综合 | 日韩亚洲欧美综合| 亚洲愉拍自拍另类高清精品| 国产成人在线免费| 亚洲精品一区二区三区蜜桃下载 | 日韩丝袜情趣美女图片| 亚洲精品一二三| eeuss影院一区二区三区| 中文字幕第一区二区| 国内精品在线播放| 日韩精品一区二区三区在线| 性做久久久久久久免费看| 色婷婷综合视频在线观看| 国产精品久久久久7777按摩| 国产精品一区二区三区乱码| 日韩免费电影一区| 日韩国产欧美视频| 欧美日韩一区精品| 亚洲一区二区在线免费观看视频| 成av人片一区二区| 久久免费偷拍视频| 国产黄色精品视频| 国产精品丝袜久久久久久app| 国产激情一区二区三区四区| 久久午夜免费电影| 国产高清无密码一区二区三区| 久久久久久综合| 国产乱子伦视频一区二区三区| 欧美精品一区二区精品网| 美女免费视频一区二区| 日韩精品一区国产麻豆| 精品亚洲国产成人av制服丝袜| 欧美不卡一区二区三区| 精品在线亚洲视频| 国产亚洲欧美在线| 国产成人福利片| 国产精品久线在线观看| 97国产一区二区| 亚洲影院久久精品| 欧美伦理影视网| 免费在线观看一区二区三区| 日韩久久免费av| 国产传媒日韩欧美成人| 中文字幕国产一区| 色综合久久中文综合久久97| 一区二区三区丝袜| 欧美日韩精品一区二区在线播放 | 欧美成人bangbros| 高清成人免费视频| 亚洲精品视频自拍| 欧美老年两性高潮| 精品亚洲国内自在自线福利| 国产精品久久久久天堂| 成人久久18免费网站麻豆| 亚洲日本一区二区三区| 欧美日韩电影在线播放| 久久精品国产久精国产| 亚洲精品一区二区三区精华液| 国产在线精品一区二区三区不卡 | 国产成人av一区| 亚洲欧洲一区二区在线播放| 欧美日韩国产综合一区二区| 久久国产乱子精品免费女| 国产精品国模大尺度视频| 欧美色涩在线第一页| 国内精品久久久久影院薰衣草 | 色悠悠亚洲一区二区| 五月婷婷欧美视频| 欧美刺激脚交jootjob| 不卡视频在线看| 亚洲成av人片www| 久久综合99re88久久爱| jlzzjlzz亚洲女人18| 香港成人在线视频| 欧美精品一区二区三区蜜臀| 色噜噜夜夜夜综合网| 久久www免费人成看片高清| 中文字幕一区二区三区在线播放| 欧美精品久久天天躁| 成人小视频在线| 日韩二区三区在线观看| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 欧美日韩国产综合一区二区| 国产精品一区二区无线| 亚洲v中文字幕| 欧美国产精品一区二区| 91精品综合久久久久久| 99久久99久久综合| 久久精品免费看| 一区二区三区精密机械公司| 久久综合九色综合97婷婷女人 | 午夜亚洲福利老司机| 久久久久久麻豆| 777欧美精品| 91啪亚洲精品| 国产福利不卡视频| 日韩成人一区二区三区在线观看| 国产精品免费视频网站| 日韩久久久精品| 欧美日韩精品欧美日韩精品 | 亚洲日本青草视频在线怡红院| 日韩欧美中文一区| 欧美午夜精品免费| 99视频超级精品| 国产成人夜色高潮福利影视| 日韩二区三区在线观看| 亚洲成人资源在线| 亚洲美腿欧美偷拍| 国产女人18水真多18精品一级做| 欧美一级艳片视频免费观看| 在线精品国精品国产尤物884a| 成人a级免费电影| 高清日韩电视剧大全免费| 久久99精品久久只有精品| 亚洲第一激情av| 亚洲美女视频一区| 亚洲欧洲av另类| 国产精品乱码妇女bbbb| 国产亚洲一区字幕| 久久一区二区视频| 亚洲精品在线观看网站| 欧美成人video| 精品嫩草影院久久| 欧美成人在线直播| 欧美变态tickle挠乳网站| 欧美久久高跟鞋激| 欧美色精品天天在线观看视频| 一本色道综合亚洲| 99视频精品在线| a级高清视频欧美日韩| 91在线观看视频| 91小视频在线观看| 不卡高清视频专区| caoporm超碰国产精品| 91最新地址在线播放| 99riav一区二区三区| 91原创在线视频| 色婷婷久久久综合中文字幕 | 午夜视频在线观看一区二区 | 欧美成人精品3d动漫h| 欧美成人在线直播| 久久久久国产一区二区三区四区| 久久影院午夜论| 国产精品久久免费看| 国产精品久久看| 亚洲精品中文在线观看| 亚洲mv在线观看| 秋霞午夜鲁丝一区二区老狼| 美国一区二区三区在线播放| 黄色精品一二区| 国产91精品久久久久久久网曝门| 成人av电影在线网| 一本久久综合亚洲鲁鲁五月天|