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

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

?? lib_at91sam7x256.h

?? FreeRTOS V4.2.1,增加了AVR32 UC3 和 LPC2368 的支持
?? H
?? 第 1 頁 / 共 5 頁
字號(hào):
//*----------------------------------------------------------------------------
//* \fn    AT91F_PDC_IsRxEmpty
//* \brief Test if the current transfer descriptor has been filled
//*----------------------------------------------------------------------------
__inline int AT91F_PDC_IsRxEmpty ( // \return return 1 if transfer is complete
	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller
{
	return !(pPDC->PDC_RCR);
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PDC_IsNextRxEmpty
//* \brief Test if the next transfer descriptor has been moved to the current td
//*----------------------------------------------------------------------------
__inline int AT91F_PDC_IsNextRxEmpty ( // \return return 1 if transfer is complete
	AT91PS_PDC pPDC )       // \arg pointer to a PDC controller
{
	return !(pPDC->PDC_RNCR);
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PDC_Open
//* \brief Open PDC: disable TX and RX reset transfer descriptors, re-enable RX and TX
//*----------------------------------------------------------------------------
__inline void AT91F_PDC_Open (
	AT91PS_PDC pPDC)       // \arg pointer to a PDC controller
{
    //* Disable the RX and TX PDC transfer requests
	AT91F_PDC_DisableRx(pPDC);
	AT91F_PDC_DisableTx(pPDC);

	//* Reset all Counter register Next buffer first
	AT91F_PDC_SetNextTx(pPDC, (char *) 0, 0);
	AT91F_PDC_SetNextRx(pPDC, (char *) 0, 0);
	AT91F_PDC_SetTx(pPDC, (char *) 0, 0);
	AT91F_PDC_SetRx(pPDC, (char *) 0, 0);

    //* Enable the RX and TX PDC transfer requests
	AT91F_PDC_EnableRx(pPDC);
	AT91F_PDC_EnableTx(pPDC);
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PDC_Close
//* \brief Close PDC: disable TX and RX reset transfer descriptors
//*----------------------------------------------------------------------------
__inline void AT91F_PDC_Close (
	AT91PS_PDC pPDC)       // \arg pointer to a PDC controller
{
    //* Disable the RX and TX PDC transfer requests
	AT91F_PDC_DisableRx(pPDC);
	AT91F_PDC_DisableTx(pPDC);

	//* Reset all Counter register Next buffer first
	AT91F_PDC_SetNextTx(pPDC, (char *) 0, 0);
	AT91F_PDC_SetNextRx(pPDC, (char *) 0, 0);
	AT91F_PDC_SetTx(pPDC, (char *) 0, 0);
	AT91F_PDC_SetRx(pPDC, (char *) 0, 0);

}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PDC_SendFrame
//* \brief Close PDC: disable TX and RX reset transfer descriptors
//*----------------------------------------------------------------------------
__inline unsigned int AT91F_PDC_SendFrame(
	AT91PS_PDC pPDC,
	char *pBuffer,
	unsigned int szBuffer,
	char *pNextBuffer,
	unsigned int szNextBuffer )
{
	if (AT91F_PDC_IsTxEmpty(pPDC)) {
		//* Buffer and next buffer can be initialized
		AT91F_PDC_SetTx(pPDC, pBuffer, szBuffer);
		AT91F_PDC_SetNextTx(pPDC, pNextBuffer, szNextBuffer);
		return 2;
	}
	else if (AT91F_PDC_IsNextTxEmpty(pPDC)) {
		//* Only one buffer can be initialized
		AT91F_PDC_SetNextTx(pPDC, pBuffer, szBuffer);
		return 1;
	}
	else {
		//* All buffer are in use...
		return 0;
	}
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PDC_ReceiveFrame
//* \brief Close PDC: disable TX and RX reset transfer descriptors
//*----------------------------------------------------------------------------
__inline unsigned int AT91F_PDC_ReceiveFrame (
	AT91PS_PDC pPDC,
	char *pBuffer,
	unsigned int szBuffer,
	char *pNextBuffer,
	unsigned int szNextBuffer )
{
	if (AT91F_PDC_IsRxEmpty(pPDC)) {
		//* Buffer and next buffer can be initialized
		AT91F_PDC_SetRx(pPDC, pBuffer, szBuffer);
		AT91F_PDC_SetNextRx(pPDC, pNextBuffer, szNextBuffer);
		return 2;
	}
	else if (AT91F_PDC_IsNextRxEmpty(pPDC)) {
		//* Only one buffer can be initialized
		AT91F_PDC_SetNextRx(pPDC, pBuffer, szBuffer);
		return 1;
	}
	else {
		//* All buffer are in use...
		return 0;
	}
}
/* *****************************************************************************
                SOFTWARE API FOR DBGU
   ***************************************************************************** */
//*----------------------------------------------------------------------------
//* \fn    AT91F_DBGU_InterruptEnable
//* \brief Enable DBGU Interrupt
//*----------------------------------------------------------------------------
__inline void AT91F_DBGU_InterruptEnable(
        AT91PS_DBGU pDbgu,   // \arg  pointer to a DBGU controller
        unsigned int flag) // \arg  dbgu interrupt to be enabled
{
        pDbgu->DBGU_IER = flag;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_DBGU_InterruptDisable
//* \brief Disable DBGU Interrupt
//*----------------------------------------------------------------------------
__inline void AT91F_DBGU_InterruptDisable(
        AT91PS_DBGU pDbgu,   // \arg  pointer to a DBGU controller
        unsigned int flag) // \arg  dbgu interrupt to be disabled
{
        pDbgu->DBGU_IDR = flag;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_DBGU_GetInterruptMaskStatus
//* \brief Return DBGU Interrupt Mask Status
//*----------------------------------------------------------------------------
__inline unsigned int AT91F_DBGU_GetInterruptMaskStatus( // \return DBGU Interrupt Mask Status
        AT91PS_DBGU pDbgu) // \arg  pointer to a DBGU controller
{
        return pDbgu->DBGU_IMR;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_DBGU_IsInterruptMasked
//* \brief Test if DBGU Interrupt is Masked 
//*----------------------------------------------------------------------------
__inline int AT91F_DBGU_IsInterruptMasked(
        AT91PS_DBGU pDbgu,   // \arg  pointer to a DBGU controller
        unsigned int flag) // \arg  flag to be tested
{
        return (AT91F_DBGU_GetInterruptMaskStatus(pDbgu) & flag);
}

/* *****************************************************************************
                SOFTWARE API FOR PIO
   ***************************************************************************** */
//*----------------------------------------------------------------------------
//* \fn    AT91F_PIO_CfgPeriph
//* \brief Enable pins to be drived by peripheral
//*----------------------------------------------------------------------------
__inline void AT91F_PIO_CfgPeriph(
	AT91PS_PIO pPio,             // \arg pointer to a PIO controller
	unsigned int periphAEnable,  // \arg PERIPH A to enable
	unsigned int periphBEnable)  // \arg PERIPH B to enable

{
	pPio->PIO_ASR = periphAEnable;
	pPio->PIO_BSR = periphBEnable;
	pPio->PIO_PDR = (periphAEnable | periphBEnable); // Set in Periph mode
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PIO_CfgOutput
//* \brief Enable PIO in output mode
//*----------------------------------------------------------------------------
__inline void AT91F_PIO_CfgOutput(
	AT91PS_PIO pPio,             // \arg pointer to a PIO controller
	unsigned int pioEnable)      // \arg PIO to be enabled
{
	pPio->PIO_PER = pioEnable; // Set in PIO mode
	pPio->PIO_OER = pioEnable; // Configure in Output
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PIO_CfgInput
//* \brief Enable PIO in input mode
//*----------------------------------------------------------------------------
__inline void AT91F_PIO_CfgInput(
	AT91PS_PIO pPio,             // \arg pointer to a PIO controller
	unsigned int inputEnable)      // \arg PIO to be enabled
{
	// Disable output
	pPio->PIO_ODR  = inputEnable;
	pPio->PIO_PER  = inputEnable;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PIO_CfgOpendrain
//* \brief Configure PIO in open drain
//*----------------------------------------------------------------------------
__inline void AT91F_PIO_CfgOpendrain(
	AT91PS_PIO pPio,             // \arg pointer to a PIO controller
	unsigned int multiDrvEnable) // \arg pio to be configured in open drain
{
	// Configure the multi-drive option
	pPio->PIO_MDDR = ~multiDrvEnable;
	pPio->PIO_MDER = multiDrvEnable;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PIO_CfgPullup
//* \brief Enable pullup on PIO
//*----------------------------------------------------------------------------
__inline void AT91F_PIO_CfgPullup(
	AT91PS_PIO pPio,             // \arg pointer to a PIO controller
	unsigned int pullupEnable)   // \arg enable pullup on PIO
{
		// Connect or not Pullup
	pPio->PIO_PPUDR = ~pullupEnable;
	pPio->PIO_PPUER = pullupEnable;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PIO_CfgDirectDrive
//* \brief Enable direct drive on PIO
//*----------------------------------------------------------------------------
__inline void AT91F_PIO_CfgDirectDrive(
	AT91PS_PIO pPio,             // \arg pointer to a PIO controller
	unsigned int directDrive)    // \arg PIO to be configured with direct drive

{
	// Configure the Direct Drive
	pPio->PIO_OWDR  = ~directDrive;
	pPio->PIO_OWER  = directDrive;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PIO_CfgInputFilter
//* \brief Enable input filter on input PIO
//*----------------------------------------------------------------------------
__inline void AT91F_PIO_CfgInputFilter(
	AT91PS_PIO pPio,             // \arg pointer to a PIO controller
	unsigned int inputFilter)    // \arg PIO to be configured with input filter

{
	// Configure the Direct Drive
	pPio->PIO_IFDR  = ~inputFilter;
	pPio->PIO_IFER  = inputFilter;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PIO_GetInput
//* \brief Return PIO input value
//*----------------------------------------------------------------------------
__inline unsigned int AT91F_PIO_GetInput( // \return PIO input
	AT91PS_PIO pPio) // \arg  pointer to a PIO controller
{
	return pPio->PIO_PDSR;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PIO_IsInputSet
//* \brief Test if PIO is input flag is active
//*----------------------------------------------------------------------------
__inline int AT91F_PIO_IsInputSet(
	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller
	unsigned int flag) // \arg  flag to be tested
{
	return (AT91F_PIO_GetInput(pPio) & flag);
}


//*----------------------------------------------------------------------------
//* \fn    AT91F_PIO_SetOutput
//* \brief Set to 1 output PIO
//*----------------------------------------------------------------------------
__inline void AT91F_PIO_SetOutput(
	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller
	unsigned int flag) // \arg  output to be set
{
	pPio->PIO_SODR = flag;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PIO_ClearOutput
//* \brief Set to 0 output PIO
//*----------------------------------------------------------------------------
__inline void AT91F_PIO_ClearOutput(
	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller
	unsigned int flag) // \arg  output to be cleared
{
	pPio->PIO_CODR = flag;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PIO_ForceOutput
//* \brief Force output when Direct drive option is enabled
//*----------------------------------------------------------------------------
__inline void AT91F_PIO_ForceOutput(
	AT91PS_PIO pPio,   // \arg  pointer to a PIO controller
	unsigned int flag) // \arg  output to be forced
{
	pPio->PIO_ODSR = flag;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PIO_Enable
//* \brief Enable PIO
//*----------------------------------------------------------------------------
__inline void AT91F_PIO_Enable(
        AT91PS_PIO pPio,   // \arg  pointer to a PIO controller
        unsigned int flag) // \arg  pio to be enabled 
{

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品一区二| 国产精品一区不卡| 91国偷自产一区二区三区成为亚洲经典 | 日本一区二区免费在线观看视频| 亚洲国产aⅴ天堂久久| 成人18视频在线播放| 亚洲欧洲韩国日本视频| 国产91精品入口| 国产日韩v精品一区二区| 极品少妇一区二区三区精品视频| 91精品一区二区三区在线观看| 亚洲一区欧美一区| 欧美日韩一二区| 亚洲成人av一区二区三区| 欧美色国产精品| 性久久久久久久久久久久| 欧美日韩在线一区二区| 亚洲一卡二卡三卡四卡五卡| 不卡影院免费观看| 国产精品传媒视频| 在线看一区二区| 午夜精品久久久久久久久久久 | 日韩综合小视频| 欧美日韩三级一区二区| 视频在线在亚洲| 日韩精品中文字幕一区二区三区 | 亚洲韩国一区二区三区| 7777精品伊人久久久大香线蕉超级流畅| 亚洲另类在线一区| 99久久99久久久精品齐齐| 亚洲国产精品欧美一二99| 欧美一区午夜视频在线观看| 久久国产精品第一页| 久久久91精品国产一区二区精品| 成人一区二区三区在线观看| 一区二区三区视频在线看| 欧美精品久久99久久在免费线| 日韩电影在线看| 久久久99精品免费观看不卡| 色综合天天综合网国产成人综合天| 亚洲综合丁香婷婷六月香| 日韩区在线观看| 国产激情精品久久久第一区二区 | 成人h动漫精品一区二区 | xfplay精品久久| 成人精品小蝌蚪| 婷婷中文字幕一区三区| 国产清纯白嫩初高生在线观看91 | 99久久99久久精品免费看蜜桃| 亚洲一区在线播放| 久久久久国产成人精品亚洲午夜| 成人精品视频网站| 日本亚洲免费观看| 国产精品理论在线观看| 欧美日韩一区二区三区高清 | 一区二区三区四区精品在线视频| 这里只有精品99re| 不卡视频在线看| 国产乱码精品一区二区三| 美女看a上一区| 亚洲欧美日本在线| 亚洲综合视频在线观看| 日韩一区二区在线看片| 欧美日韩大陆一区二区| 成人激情动漫在线观看| 热久久国产精品| 亚洲婷婷综合久久一本伊一区| 日韩三级.com| 欧美三级日韩在线| 粉嫩av一区二区三区粉嫩| 奇米精品一区二区三区四区| 亚洲欧美日韩一区| 欧美激情资源网| 欧美一区三区二区| 91福利精品第一导航| 国产精品一区二区91| 久久66热偷产精品| 调教+趴+乳夹+国产+精品| 亚洲欧美一区二区三区极速播放 | 91丨porny丨最新| www.在线欧美| 国产酒店精品激情| 久久综合综合久久综合| 日本特黄久久久高潮| 亚洲综合丁香婷婷六月香| 亚洲欧美在线aaa| 国产色一区二区| 欧美精品一区二区三区蜜桃| 日韩一卡二卡三卡| 91精品国产91久久久久久一区二区| 欧洲国产伦久久久久久久| 91麻豆产精品久久久久久| av不卡在线观看| 99re这里只有精品首页| 成人av在线一区二区三区| 成人精品国产免费网站| 国产一区二区看久久| 欧美性大战xxxxx久久久| 不卡高清视频专区| 国产成人综合精品三级| 激情六月婷婷久久| av一区二区三区| 99久久婷婷国产综合精品| 色哟哟精品一区| 欧美影片第一页| 日本久久一区二区| 日韩一级成人av| 日韩精品自拍偷拍| 国产日韩精品一区| 国产精品超碰97尤物18| 自拍偷在线精品自拍偷无码专区| 亚洲丝袜美腿综合| 亚洲综合在线免费观看| 婷婷国产在线综合| 久久99深爱久久99精品| 日韩精品电影在线观看| 奇米在线7777在线精品 | 亚洲超碰精品一区二区| 中文字幕一区在线观看视频| 亚洲乱码日产精品bd| 亚洲成av人在线观看| 美女任你摸久久| 国产成人免费av在线| 91视频免费观看| 欧美一级免费观看| 欧美韩日一区二区三区| 亚洲视频1区2区| 亚洲第一福利一区| 91精品啪在线观看国产60岁| 精品国产网站在线观看| 国产精品久久久久四虎| 亚洲va天堂va国产va久| 韩日欧美一区二区三区| 一本色道久久加勒比精品| 欧美日精品一区视频| 26uuu精品一区二区| 亚洲美女区一区| 免费观看一级特黄欧美大片| 国产91精品在线观看| 欧美日韩大陆在线| 国产精品色哟哟网站| 亚洲成a人片在线观看中文| 国产高清精品在线| 欧美日韩精品专区| 亚洲欧洲美洲综合色网| 视频一区二区三区中文字幕| 成人精品免费看| 日韩欧美一级二级三级| 亚洲同性同志一二三专区| 激情综合网av| 91久久精品网| 久久免费看少妇高潮| 亚洲免费av观看| 91色在线porny| 久久一日本道色综合| 亚洲成人激情综合网| 99精品桃花视频在线观看| 欧美xingq一区二区| 亚洲一区在线视频| 成人网在线播放| 欧美电影精品一区二区| 一区二区三区四区中文字幕| 日韩—二三区免费观看av| 一本大道久久精品懂色aⅴ| 国产亚洲精品中文字幕| 老鸭窝一区二区久久精品| 在线观看视频欧美| 亚洲视频中文字幕| 成人小视频在线| 国产日韩av一区二区| 精品一区二区在线视频| 91精品国产综合久久久久久久久久| 亚洲欧美经典视频| 成人精品国产一区二区4080| 国产欧美综合在线| 国产精品一区二区久激情瑜伽| 欧美一区二区视频在线观看| 亚洲国产成人tv| 欧美影片第一页| 国产精品欧美久久久久一区二区| 成人性生交大片免费看中文网站| 精品国产乱码久久久久久牛牛 | 亚洲美女精品一区| 成人黄色电影在线| 日韩一区二区在线观看视频播放| 久久精品72免费观看| 欧美一级片在线看| 日本视频免费一区| 日韩欧美一区在线观看| 日韩电影在线观看一区| 91精品国产综合久久精品性色| 亚洲国产日韩a在线播放性色| 91国产免费观看| 一区二区三区免费在线观看| 欧洲国内综合视频| 亚洲bt欧美bt精品777| 欧美一区三区四区| 蜜桃精品视频在线| 精品区一区二区| 国产成人午夜电影网|