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

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

?? xgpio_intr.c

?? edk9.1嵌入式開發實驗1代碼
?? 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一区二区三区免费野_久草精品视频
www.久久久久久久久| 久久er99热精品一区二区| 久久精品一二三| 精品乱码亚洲一区二区不卡| 精品久久久久久亚洲综合网| 精品动漫一区二区三区在线观看| 欧美欧美欧美欧美| 91精品国产麻豆| 日韩精品一区二区在线| 久久精品人人做人人爽人人| 久久人人97超碰com| 国产精品久久久久一区| 亚洲人一二三区| 亚洲国产日韩精品| 在线一区二区三区做爰视频网站| 精品免费视频.| 亚洲国产精品一区二区尤物区| 一区二区三区在线视频免费观看| 亚洲男同1069视频| 午夜欧美在线一二页| 美洲天堂一区二卡三卡四卡视频 | 国产亚洲综合色| 亚洲国产高清不卡| 亚洲免费资源在线播放| 午夜久久久久久| 国产一区二区三区日韩| 成人理论电影网| 欧美日韩精品一区二区三区蜜桃 | 一区二区三区在线观看国产| 日韩经典一区二区| 粉嫩在线一区二区三区视频| 欧美日韩在线播| 国产欧美一区二区精品仙草咪| 中文字幕欧美一区| 亚洲成人av资源| 顶级嫩模精品视频在线看| 欧美午夜一区二区三区 | 在线日韩av片| 亚洲精品一线二线三线| 亚洲伦理在线精品| 久久99国产精品麻豆| 色综合色综合色综合| 欧美不卡一区二区| 五月婷婷综合网| 99国产精品国产精品久久| 日韩欧美一级片| 亚洲成人先锋电影| 不卡免费追剧大全电视剧网站| 9191精品国产综合久久久久久| 国产精品色婷婷久久58| 国产一区二区三区在线观看免费| 欧美日韩在线播放| 最新成人av在线| 高清不卡一区二区| 久久蜜桃香蕉精品一区二区三区| 午夜精品爽啪视频| 色综合久久久久综合体桃花网| 久久免费偷拍视频| 久久成人久久鬼色| 欧美伊人久久久久久午夜久久久久| 国产精品午夜电影| 国产精品自产自拍| 久久婷婷综合激情| 久久99精品国产91久久来源 | 精一区二区三区| 在线播放一区二区三区| 亚洲图片有声小说| 色8久久人人97超碰香蕉987| 亚洲欧洲另类国产综合| 成人激情小说网站| 亚洲最大色网站| 成人黄色免费短视频| 国产精品伦理一区二区| 成人午夜大片免费观看| 国产欧美精品区一区二区三区 | 久久综合综合久久综合| 日韩女同互慰一区二区| 美女被吸乳得到大胸91| 欧美区在线观看| 日韩电影在线免费| 欧美一级二级三级乱码| 六月丁香婷婷色狠狠久久| 欧美mv日韩mv国产网站| 国产成人自拍在线| 国产精品国产三级国产有无不卡| 9l国产精品久久久久麻豆| 国产精品久久久久影院色老大| 91影视在线播放| 亚洲一区自拍偷拍| 日韩精品在线一区二区| 国产自产v一区二区三区c| 国产午夜精品久久久久久免费视| www.激情成人| 性久久久久久久久| 亚洲精品在线一区二区| 成人性生交大片免费看中文| 亚洲免费av高清| 欧美二区三区91| 国产剧情一区二区三区| 亚洲视频在线一区| 欧美一区二区视频网站| 国产精品一级二级三级| 亚洲欧美激情视频在线观看一区二区三区 | 一本大道久久a久久精二百| 丝袜亚洲另类丝袜在线| 久久九九99视频| 在线观看国产日韩| 韩国精品主播一区二区在线观看 | 美女被吸乳得到大胸91| 国产精品美女视频| 欧美日韩视频一区二区| 粉嫩欧美一区二区三区高清影视 | 欧美xxxxxxxxx| 97se亚洲国产综合自在线观| 日韩在线一区二区| 国产精品午夜久久| 日韩欧美你懂的| 在线视频你懂得一区二区三区| 久久99热这里只有精品| 亚洲综合免费观看高清完整版在线 | 欧美三级日韩在线| 韩国成人在线视频| 三级成人在线视频| 亚洲欧美自拍偷拍色图| 欧美成人r级一区二区三区| 99v久久综合狠狠综合久久| 久久99精品久久久久婷婷| 亚洲激情欧美激情| 欧美国产日产图区| 欧美xxxx在线观看| 6080国产精品一区二区| 欧美性猛片aaaaaaa做受| 成人激情校园春色| 国产成人av资源| 久久精品国产久精国产| 日韩高清电影一区| 亚洲一区二区三区中文字幕 | 亚洲激情校园春色| 国产精品素人一区二区| 久久久久99精品国产片| 精品国产凹凸成av人导航| 欧美一区二区观看视频| 在线不卡一区二区| 制服丝袜av成人在线看| 欧美日韩一区三区| 欧美视频一区二区在线观看| 色先锋资源久久综合| 一本一本久久a久久精品综合麻豆| 国产999精品久久| 国产a视频精品免费观看| 国产二区国产一区在线观看| 国产麻豆精品theporn| 国内精品久久久久影院色| 久久精品国产99国产精品| 久久99精品久久久久久久久久久久| 蜜桃视频免费观看一区| 日本三级亚洲精品| 九色|91porny| 国产精品888| 91首页免费视频| 在线影院国内精品| 欧美日产在线观看| 日韩久久久久久| 久久久久国产一区二区三区四区| 久久精品在线观看| 亚洲色图一区二区三区| 一区二区三区欧美激情| 日韩福利视频导航| 国产美女视频91| 9人人澡人人爽人人精品| 在线观看成人小视频| 91精品国产免费| 国产视频在线观看一区二区三区| 国产精品国产三级国产普通话三级 | 国产成人一级电影| 91丨九色丨蝌蚪丨老版| 在线观看免费成人| 欧美tickling网站挠脚心| 国产精品人成在线观看免费| 玉足女爽爽91| 免费成人av在线| aaa亚洲精品| 日韩一区二区麻豆国产| 国产免费观看久久| 视频一区欧美精品| 国产aⅴ综合色| 欧美肥胖老妇做爰| 国产精品久久久久久久久免费相片| 亚洲亚洲精品在线观看| 国产一区二区三区蝌蚪| 欧美亚洲国产一区二区三区| 2020国产精品久久精品美国| 亚洲男人的天堂在线观看| 国产资源精品在线观看| 欧美午夜一区二区三区免费大片| 久久久久97国产精华液好用吗| 亚洲成人免费电影| 91网站在线播放| 欧美激情一区三区| 美女mm1313爽爽久久久蜜臀|