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

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

?? lib_at91sam7x256.h

?? IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR
?? H
?? 第 1 頁 / 共 5 頁
字號:
//*----------------------------------------------------------------------------
//* \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
{

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品99久久久久久久vr| 亚洲综合视频在线观看| 激情欧美一区二区| 精品国产免费视频| 国产成人精品综合在线观看| 中文字幕一区二区三区不卡 | 天天色综合成人网| 欧美日韩国产一区二区三区地区| 午夜久久久久久| 精品久久久久久久久久久久包黑料 | 一区二区视频在线| 欧美日韩一区二区三区在线| 蜜桃久久久久久久| 国产午夜精品一区二区| 91久久精品午夜一区二区| 婷婷中文字幕一区三区| 精品国产乱码久久久久久影片| 高清在线成人网| 亚洲最新在线观看| 欧美精品一区二区三区视频| 成人免费精品视频| 日本最新不卡在线| 国产欧美久久久精品影院| 在线影视一区二区三区| 捆绑调教一区二区三区| 最新欧美精品一区二区三区| 欧美精品高清视频| 成人亚洲一区二区一| 五月激情六月综合| 中文av一区二区| 欧美狂野另类xxxxoooo| 成人av在线一区二区三区| 日韩成人免费看| 亚洲精品国产a| 欧美一区二区大片| 波多野结衣在线一区| 日韩高清在线观看| 亚洲色图清纯唯美| 精品国产不卡一区二区三区| 欧洲生活片亚洲生活在线观看| 精品一区二区三区的国产在线播放| 亚洲三级在线免费| 久久久亚洲精品石原莉奈| 欧美日韩一区二区欧美激情| 成人综合婷婷国产精品久久 | 一区二区三区成人在线视频| 久久久精品欧美丰满| 欧美一三区三区四区免费在线看| 91网站黄www| 国产激情一区二区三区| 麻豆精品蜜桃视频网站| 亚洲va欧美va国产va天堂影院| 国产精品久久毛片| 久久精品一区蜜桃臀影院| 制服丝袜中文字幕亚洲| 91在线免费视频观看| 国产高清不卡二三区| 六月丁香婷婷色狠狠久久| 亚洲高清不卡在线观看| 亚洲欧美色图小说| 日韩久久一区二区| 国产精品女主播在线观看| 国产午夜精品一区二区三区四区| 精品嫩草影院久久| 日韩欧美电影一二三| 91精品国产91久久综合桃花| 欧美日韩的一区二区| 欧美日韩免费在线视频| 色综合激情五月| 99re66热这里只有精品3直播| 国产高清在线观看免费不卡| 国产一区二区三区免费在线观看| 日本亚洲三级在线| 美国毛片一区二区| 爽好多水快深点欧美视频| 日韩综合一区二区| 日日夜夜免费精品| 日本欧美加勒比视频| 热久久久久久久| 久久精品99国产国产精| 理论电影国产精品| 国产麻豆精品视频| 成人一区二区三区视频在线观看| 国产成人精品www牛牛影视| 高清av一区二区| 91免费观看在线| 欧美在线视频全部完| 在线电影院国产精品| 欧美电影免费观看高清完整版在线| 欧美一级欧美三级在线观看| 欧美刺激脚交jootjob| 337p粉嫩大胆噜噜噜噜噜91av| 国产婷婷精品av在线| 中文字幕一区二区在线播放| 一区二区三区中文在线| 视频一区二区不卡| 国产精品一二三区在线| 97久久精品人人爽人人爽蜜臀| 日本乱人伦aⅴ精品| 欧美一级理论性理论a| 久久九九99视频| 亚洲人123区| 日本在线不卡视频| 国产91综合网| 欧美日韩一区二区电影| 久久美女高清视频| 一二三区精品福利视频| 日韩av不卡在线观看| 国产一区二区三区四区五区美女| eeuss影院一区二区三区 | 欧美一区二区三区免费| 久久久久亚洲蜜桃| 亚洲愉拍自拍另类高清精品| 久久av中文字幕片| 色综合久久精品| 欧美成人一区二区三区在线观看| 中文字幕精品—区二区四季| 亚洲妇女屁股眼交7| 国产高清一区日本| 欧美日韩亚洲不卡| 国产精品网站导航| 强制捆绑调教一区二区| 成人毛片在线观看| 91精品国产综合久久精品麻豆| 国产欧美va欧美不卡在线| 亚洲伊人色欲综合网| 国产精品66部| 欧美日韩综合在线| 国产精品美女一区二区在线观看| 午夜视频久久久久久| 国产91丝袜在线18| 日韩女优电影在线观看| 夜色激情一区二区| 成人性生交大合| 日韩欧美一区在线| 亚洲综合男人的天堂| 成人高清免费观看| 日韩免费成人网| 午夜精品福利一区二区三区蜜桃| av在线不卡观看免费观看| 日韩欧美国产系列| 亚洲成人av一区二区| 99久久综合精品| 欧美激情一区二区三区不卡 | 日韩成人av影视| 91美女片黄在线观看91美女| 久久久精品国产免费观看同学| 午夜视频在线观看一区二区| 欧美自拍丝袜亚洲| 亚洲欧美经典视频| 99久久er热在这里只有精品15 | 亚洲图片欧美综合| 91视频免费看| 亚洲美女电影在线| a4yy欧美一区二区三区| 中文字幕av一区二区三区高| 国产一区二区在线视频| 精品国产伦一区二区三区观看体验| 日韩高清不卡在线| 欧美精品乱人伦久久久久久| 亚洲一区二区成人在线观看| 色呦呦日韩精品| 亚洲乱码精品一二三四区日韩在线| 懂色av中文一区二区三区| 国产亚洲制服色| 国产福利91精品一区| 国产日本亚洲高清| 丁香啪啪综合成人亚洲小说| 欧美国产综合一区二区| 精品一区二区av| 国产欧美一区视频| 国产.精品.日韩.另类.中文.在线.播放 | 玉足女爽爽91| 色天天综合色天天久久| 亚洲一区二区三区自拍| 欧美日韩国产片| 奇米色777欧美一区二区| 91精品国产全国免费观看| 麻豆精品视频在线观看免费| 亚洲精品一区二区三区四区高清| 精品一区二区三区久久| 国产精品午夜电影| 色婷婷av一区二区三区之一色屋| 亚洲综合免费观看高清完整版| 欧美日韩精品一区二区在线播放| 日本中文字幕一区二区视频 | 91精品国产综合久久久久久漫画 | 国产一区二区视频在线| 中文字幕巨乱亚洲| 在线视频一区二区三区| 日韩精品国产欧美| 国产日韩欧美精品一区| 色屁屁一区二区| 日本亚洲电影天堂| 国产女主播一区| 欧美色网站导航| 狠狠色狠狠色综合| 亚洲精品国产一区二区三区四区在线| 欧美日韩国产片| 国产福利一区二区|