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

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

?? lib_at91rm9200.c

?? AT91RM9200的引到程序
?? C
?? 第 1 頁 / 共 5 頁
字號:
	int mode)        // mode register 
{
	//* Write to the MR register
	pSPI->SPI_MR = mode;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_SPI_CfgPCS
//* \brief Switch to the correct PCS of SPI Mode Register : Fixed Peripheral Selected
//*----------------------------------------------------------------------------
 void AT91F_SPI_CfgPCS (
	AT91PS_SPI pSPI, // pointer to a SPI controller
	char PCS_Device) // PCS of the Device
{	
 	//* Write to the MR register
	pSPI->SPI_MR &= 0xFFF0FFFF;
	pSPI->SPI_MR |= ( (PCS_Device<<16) & AT91C_SPI_PCS );
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_SPI_ReceiveFrame
//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initializaed with Next Buffer, 0 if PDC is busy
//*----------------------------------------------------------------------------
 unsigned int AT91F_SPI_ReceiveFrame (
	AT91PS_SPI pSPI,
	char *pBuffer,
	unsigned int szBuffer,
	char *pNextBuffer,
	unsigned int szNextBuffer )
{
	return AT91F_PDC_ReceiveFrame(
		(AT91PS_PDC) &(pSPI->SPI_RPR),
		pBuffer,
		szBuffer,
		pNextBuffer,
		szNextBuffer);
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_SPI_SendFrame
//* \brief Return 2 if PDC has been initialized with Buffer and Next Buffer, 1 if PDC has been initializaed with Next Buffer, 0 if PDC is bSPIy
//*----------------------------------------------------------------------------
 unsigned int AT91F_SPI_SendFrame(
	AT91PS_SPI pSPI,
	char *pBuffer,
	unsigned int szBuffer,
	char *pNextBuffer,
	unsigned int szNextBuffer )
{
	return AT91F_PDC_SendFrame(
		(AT91PS_PDC) &(pSPI->SPI_RPR),
		pBuffer,
		szBuffer,
		pNextBuffer,
		szNextBuffer);
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_SPI_Close
//* \brief Close SPI: disable IT disable transfert, close PDC
//*----------------------------------------------------------------------------
 void AT91F_SPI_Close (
	AT91PS_SPI pSPI)     // \arg pointer to a SPI controller
{
    //* Reset all the Chip Select register
    pSPI->SPI_CSR[0] = 0 ;
    pSPI->SPI_CSR[1] = 0 ;
    pSPI->SPI_CSR[2] = 0 ;
    pSPI->SPI_CSR[3] = 0 ;

    //* Reset the SPI mode
    pSPI->SPI_MR = 0  ;

    //* Disable all interrupts
    pSPI->SPI_IDR = 0xFFFFFFFF ;

    //* Abort the Peripheral Data Transfers
    AT91F_PDC_Close((AT91PS_PDC) &(pSPI->SPI_RPR));

    //* Disable receiver and transmitter and stop any activity immediately
    pSPI->SPI_CR = AT91C_SPI_SPIDIS;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_SPI_PutChar
//* \brief Send a character,does not check if ready to send
//*----------------------------------------------------------------------------
 void AT91F_SPI_PutChar (
	AT91PS_SPI pSPI,
	unsigned int character,
             unsigned int cs_number )
{
    unsigned int value_for_cs;
    value_for_cs = (~(1 << cs_number)) & 0xF;  //Place a zero among a 4 ONEs number
    pSPI->SPI_TDR = (character & 0xFFFF) | (value_for_cs << 16);
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_SPI_GetChar
//* \brief Receive a character,does not check if a character is available
//*----------------------------------------------------------------------------
 int AT91F_SPI_GetChar (
	const AT91PS_SPI pSPI)
{
    return((pSPI->SPI_RDR) & 0xFFFF);
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_SPI_GetInterruptMaskStatus
//* \brief Return SPI Interrupt Mask Status
//*----------------------------------------------------------------------------
 unsigned int AT91F_SPI_GetInterruptMaskStatus( // \return SPI Interrupt Mask Status
        AT91PS_SPI pSpi) // \arg  pointer to a SPI controller
{
        return pSpi->SPI_IMR;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_SPI_IsInterruptMasked
//* \brief Test if SPI Interrupt is Masked 
//*----------------------------------------------------------------------------
 int AT91F_SPI_IsInterruptMasked(
        AT91PS_SPI pSpi,   // \arg  pointer to a SPI controller
        unsigned int flag) // \arg  flag to be tested
{
        return (AT91F_SPI_GetInterruptMaskStatus(pSpi) & flag);
}

/* *****************************************************************************
                SOFTWARE API FOR TC
   ***************************************************************************** */
//*----------------------------------------------------------------------------
//* \fn    AT91F_TC_InterruptEnable
//* \brief Enable TC Interrupt
//*----------------------------------------------------------------------------
 void AT91F_TC_InterruptEnable(
        AT91PS_TC pTc,   // \arg  pointer to a TC controller
        unsigned int flag) // \arg  TC interrupt to be enabled
{
        pTc->TC_IER = flag;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_TC_InterruptDisable
//* \brief Disable TC Interrupt
//*----------------------------------------------------------------------------
 void AT91F_TC_InterruptDisable(
        AT91PS_TC pTc,   // \arg  pointer to a TC controller
        unsigned int flag) // \arg  TC interrupt to be disabled
{
        pTc->TC_IDR = flag;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_TC_GetInterruptMaskStatus
//* \brief Return TC Interrupt Mask Status
//*----------------------------------------------------------------------------
 unsigned int AT91F_TC_GetInterruptMaskStatus( // \return TC Interrupt Mask Status
        AT91PS_TC pTc) // \arg  pointer to a TC controller
{
        return pTc->TC_IMR;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_TC_IsInterruptMasked
//* \brief Test if TC Interrupt is Masked 
//*----------------------------------------------------------------------------
 int AT91F_TC_IsInterruptMasked(
        AT91PS_TC pTc,   // \arg  pointer to a TC controller
        unsigned int flag) // \arg  flag to be tested
{
        return (AT91F_TC_GetInterruptMaskStatus(pTc) & flag);
}

/* *****************************************************************************
                SOFTWARE API FOR PMC
   ***************************************************************************** */
//*----------------------------------------------------------------------------
//* \fn    AT91F_CKGR_GetMainClock
//* \brief Return Main clock in Hz
//*----------------------------------------------------------------------------
 unsigned int AT91F_CKGR_GetMainClock (
	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller
	unsigned int slowClock)  // \arg slowClock in Hz
{
	return ((pCKGR->CKGR_MCFR  & AT91C_CKGR_MAINF) * slowClock) >> 4;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PMC_GetProcessorClock
//* \brief Return processor clock in Hz (for AT91RM3400 and AT91RM9200)
//*----------------------------------------------------------------------------
 unsigned int AT91F_PMC_GetProcessorClock (
	AT91PS_PMC pPMC, // \arg pointer to PMC controller
	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller
	unsigned int slowClock)  // \arg slowClock in Hz
{
	unsigned int reg = pPMC->PMC_MCKR;
	unsigned int prescaler = (1 << ((reg & AT91C_PMC_PRES) >> 2));
	unsigned int pllDivider, pllMultiplier;

	switch (reg & AT91C_PMC_CSS) {
		case AT91C_PMC_CSS_SLOW_CLK: // Slow clock selected
			return slowClock / prescaler;
		case AT91C_PMC_CSS_MAIN_CLK: // Main clock is selected
			return AT91F_CKGR_GetMainClock(pCKGR, slowClock) / prescaler;
		case AT91C_PMC_CSS_PLLA_CLK: // PLLA clock is selected
			reg = pCKGR->CKGR_PLLAR;
			pllDivider    = (reg  & AT91C_CKGR_DIVA);
			pllMultiplier = ((reg  & AT91C_CKGR_MULA) >> 16) + 1;
			if (reg & AT91C_CKGR_SRCA) // Source is Main clock
				return AT91F_CKGR_GetMainClock(pCKGR, slowClock) / pllDivider * pllMultiplier / prescaler;
			else                       // Source is Slow clock
				return slowClock / pllDivider * pllMultiplier / prescaler;
		case AT91C_PMC_CSS_PLLB_CLK: // PLLB clock is selected
			reg = pCKGR->CKGR_PLLBR;
			pllDivider    = (reg  & AT91C_CKGR_DIVB);
			pllMultiplier = ((reg  & AT91C_CKGR_MULB) >> 16) + 1;
			return AT91F_CKGR_GetMainClock(pCKGR, slowClock) / pllDivider * pllMultiplier / prescaler;
	}
	return 0;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PMC_GetMasterClock
//* \brief Return master clock in Hz (just for AT91RM9200)
//*----------------------------------------------------------------------------
 unsigned int AT91F_PMC_GetMasterClock (
	AT91PS_PMC pPMC, // \arg pointer to PMC controller
	AT91PS_CKGR pCKGR, // \arg pointer to CKGR controller
	unsigned int slowClock)  // \arg slowClock in Hz
{
	return AT91F_PMC_GetProcessorClock(pPMC, pCKGR, slowClock) /
		(((pPMC->PMC_MCKR & AT91C_PMC_MDIV) >> 8)+1);
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PMC_EnablePeriphClock
//* \brief Enable peripheral clock
//*----------------------------------------------------------------------------
 void AT91F_PMC_EnablePeriphClock (
	AT91PS_PMC pPMC, // \arg pointer to PMC controller
	unsigned int periphIds)  // \arg IDs of peripherals to enable
{
	pPMC->PMC_PCER = periphIds;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PMC_DisablePeriphClock
//* \brief Enable peripheral clock
//*----------------------------------------------------------------------------
 void AT91F_PMC_DisablePeriphClock (
	AT91PS_PMC pPMC, // \arg pointer to PMC controller
	unsigned int periphIds)  // \arg IDs of peripherals to enable
{
	pPMC->PMC_PCDR = periphIds;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PMC_EnablePCK
//* \brief Enable peripheral clock
//*----------------------------------------------------------------------------
 void AT91F_PMC_EnablePCK (
	AT91PS_PMC pPMC, // \arg pointer to PMC controller
	unsigned int pck,  // \arg Peripheral clock identifier 0 .. 7
	unsigned int ccs,  // \arg clock selection: AT91C_PMC_CSS_SLOW_CLK, AT91C_PMC_CSS_MAIN_CLK, AT91C_PMC_CSS_PLLA_CLK, AT91C_PMC_CSS_PLLB_CLK
	unsigned int pres) // \arg Programmable clock prescalar AT91C_PMC_PRES_CLK, AT91C_PMC_PRES_CLK_2, ..., AT91C_PMC_PRES_CLK_64
{
	pPMC->PMC_PCKR[pck] = ccs | pres;
	pPMC->PMC_SCER = (1 << pck) << 8;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_PMC_DisablePCK
//* \brief Enable peripheral clock
//*----------------------------------------------------------------------------
 void AT91F_PMC_DisablePCK (
	AT91PS_PMC pPMC, // \arg pointer to PMC controller
	unsigned int pck)  // \arg Peripheral clock identifier 0 .. 7
{
	pPMC->PMC_SCDR = (1 << pck) << 8;
}

/* *****************************************************************************
                SOFTWARE API FOR PIO
   ***************************************************************************** */
//*----------------------------------------------------------------------------
//* \fn    AT91F_PIO_CfgPeriph
//* \brief Enable pins to be drived by peripheral
//*----------------------------------------------------------------------------
 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
//*----------------------------------------------------------------------------
 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
//*----------------------------------------------------------------------------
 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;
}

//*----------------------------------------------------------------------------

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人动漫视频在线| 亚洲国产成人高清精品| 国产一区二区三区在线观看精品| 欧美一级高清片| 免费av成人在线| 久久久久久97三级| 国产成a人亚洲| 一区二区三区不卡视频在线观看| 91视频.com| 三级一区在线视频先锋| 日韩精品一区在线| 国产成人av资源| 亚洲猫色日本管| 在线91免费看| 国产精品羞羞答答xxdd| 亚洲男人电影天堂| 884aa四虎影成人精品一区| 国产一区在线精品| 亚洲同性同志一二三专区| 在线免费观看视频一区| 激情综合网av| 亚洲欧美日韩在线播放| 日韩一卡二卡三卡| 成人涩涩免费视频| 视频一区欧美日韩| 欧美国产综合一区二区| 欧美日韩精品一区二区在线播放| 国产一本一道久久香蕉| 亚洲二区在线视频| 国产无遮挡一区二区三区毛片日本 | 色哟哟一区二区三区| 日韩中文字幕一区二区三区| 久久久天堂av| 欧美丰满嫩嫩电影| av在线不卡电影| 久久国产精品无码网站| 亚洲欧美日韩一区二区 | 欧美韩国日本综合| 欧美午夜精品一区二区三区| 久久精品国产亚洲aⅴ| 一区二区三区蜜桃网| 久久天堂av综合合色蜜桃网| 欧美性色欧美a在线播放| 国产高清在线精品| 视频一区二区三区中文字幕| 国产精品国产三级国产aⅴ入口 | 亚洲精品日产精品乱码不卡| 精品av综合导航| 欧美日韩三级在线| 色婷婷综合久久久久中文一区二区| 毛片av一区二区| 亚洲成人动漫精品| 亚洲欧美一区二区三区久本道91 | 欧美男人的天堂一二区| 成人国产一区二区三区精品| 久久国产精品99久久人人澡| 午夜精品久久久久久久| 自拍偷拍国产亚洲| 国产精品理论在线观看| 久久精品欧美一区二区三区不卡| 日韩精品影音先锋| 正在播放亚洲一区| 欧美美女网站色| 欧美久久久影院| 欧美视频中文字幕| 欧美性色综合网| 欧美视频在线播放| 在线观看视频91| 欧美日韩一区在线观看| 色综合天天综合给合国产| 波多野结衣的一区二区三区| 成人免费毛片片v| 春色校园综合激情亚洲| 国产精品一区专区| 国产精品综合二区| 国产精品一区在线观看你懂的| 国内一区二区视频| 国产一区二区主播在线| 国产一区二区三区在线看麻豆| 久久 天天综合| 国产一区高清在线| 高清不卡在线观看av| 在线不卡一区二区| 91精品国产黑色紧身裤美女| 91精品国产色综合久久ai换脸| 欧美精品一二三区| 精品国产亚洲一区二区三区在线观看| 日韩欧美亚洲一区二区| 久久久综合网站| 中文字幕中文字幕中文字幕亚洲无线 | 成人黄色a**站在线观看| 99精品视频中文字幕| 欧美亚洲综合色| 欧美一区二区人人喊爽| 久久久久国产精品人| 国产精品国产馆在线真实露脸| 亚洲人成在线观看一区二区| 艳妇臀荡乳欲伦亚洲一区| 免费一级欧美片在线观看| 国产成人综合在线| 欧美在线观看一区二区| 欧美一区二区三区日韩视频| 国产亚洲女人久久久久毛片| 亚洲日本va午夜在线电影| 午夜天堂影视香蕉久久| 国产一区久久久| 91免费看`日韩一区二区| 欧美日韩国产bt| 国产日韩视频一区二区三区| 国产精品日韩精品欧美在线| 一区二区三区欧美日| 免费精品99久久国产综合精品| 国产精品自产自拍| 在线观看免费成人| 久久青草国产手机看片福利盒子| 自拍偷拍亚洲欧美日韩| 美女视频黄频大全不卡视频在线播放| 国产精品一区一区三区| 91成人免费在线| 26uuu亚洲| 亚洲午夜精品网| 成人av资源在线观看| 欧美精品高清视频| 中文字幕在线观看一区| 欧美aa在线视频| 色欧美片视频在线观看| 久久久久久亚洲综合影院红桃| 亚洲精品中文在线观看| 91激情在线视频| 久久久久久一二三区| 丝袜亚洲另类欧美| 成人精品视频一区| 2020日本不卡一区二区视频| 亚洲一区免费观看| 99久久久精品| 久久久另类综合| 蜜桃精品在线观看| 欧美日本在线一区| 综合电影一区二区三区 | 91在线免费播放| 久久综合网色—综合色88| 性做久久久久久免费观看欧美| 国产成人精品亚洲午夜麻豆| 日韩一级二级三级精品视频| 综合色天天鬼久久鬼色| 成人国产精品免费观看动漫| 精品久久人人做人人爽| 日本91福利区| 在线不卡一区二区| 午夜成人免费电影| 欧美性做爰猛烈叫床潮| 亚洲精品菠萝久久久久久久| 不卡的电影网站| 国产欧美一区二区精品性| 国产乱淫av一区二区三区| 欧美成人高清电影在线| 天天影视涩香欲综合网| 欧美日韩中字一区| 亚洲一区二区三区在线| 欧美视频中文字幕| 亚洲国产欧美日韩另类综合| 日本国产一区二区| 亚洲免费在线视频一区 二区| 99在线热播精品免费| 亚洲欧美另类久久久精品| 99久久久国产精品| 亚洲品质自拍视频网站| 在线这里只有精品| 亚洲黄色av一区| 欧美久久久影院| 日本在线不卡视频一二三区| 91麻豆精品国产无毒不卡在线观看| 亚洲综合图片区| 欧美久久一区二区| 久久福利视频一区二区| 2021久久国产精品不只是精品| 国产一区二区三区四| 欧美国产视频在线| 99国产精品久久久久久久久久 | 亚洲成人1区2区| 91麻豆精品国产91久久久久久久久 | 这里是久久伊人| 黑人精品欧美一区二区蜜桃| 国产三级三级三级精品8ⅰ区| 成人黄色a**站在线观看| 亚洲精品日韩综合观看成人91| 欧美在线你懂得| 玖玖九九国产精品| 国产欧美日韩精品a在线观看| 99riav久久精品riav| 亚洲国产精品一区二区尤物区| 欧美一级欧美三级| 成人一级视频在线观看| 亚洲精品少妇30p| 日韩欧美激情一区| www.一区二区| 奇米色一区二区| 久久久久国产精品麻豆ai换脸| av男人天堂一区| 奇米色一区二区|