⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 lpc177x_8x_rtc.c

📁 NXPl788上lwip的无操作系统移植,基于Embest开发板
💻 C
📖 第 1 页 / 共 3 页
字号:


/*********************************************************************//**
 * @brief 		Read value from General purpose registers
 * @param[in]	RTCx	RTC peripheral selected, should be LPC_RTC
 * @param[in]	Channel General purpose registers Channel number,
 * 				should be in range from 0 to 4.
 * @return 		Read Value
 * Note: These General purpose registers can be used to store important
 * information when the main power supply is off. The value in these
 * registers is not affected by chip reset.
 **********************************************************************/
uint32_t RTC_ReadGPREG (LPC_RTC_TypeDef *RTCx, uint8_t Channel)
{
	uint32_t *preg;
	uint32_t value;

	preg = (uint32_t *)&RTCx->GPREG0;
	preg += Channel;
	value = *preg;
	return (value);
}
/*********************************************************************//**
 * @brief 		Initialize an variable of type RTC_ER_CONFIG_Type.
 * @param[in]	pConfig	The address of input variable.
 * @return 		None
 **********************************************************************/
void RTC_ER_InitConfigStruct(RTC_ER_CONFIG_Type* pConfig)
{
	uint32_t tmp;
	if(pConfig == NULL)
		return;

	for(tmp = 0; tmp < RTC_ER_INPUT_CHANNEL_NUM; tmp++)
	{
		pConfig->InputChannel[tmp].EventOnPosEdge = FALSE;
		pConfig->InputChannel[tmp].GPClear= FALSE;
		pConfig->InputChannel[tmp].IntWake= FALSE;
	}
	pConfig->Clk = 64;
}

/*********************************************************************//**
 * @brief 		Initialize Event Monitor/Recorder
 * @param[in]	pConfig	Configuration
 * @return 		SUCCESS/ERROR
 * Note: The RTC Module must be intialized before initializing this module.
 **********************************************************************/
Status RTC_ER_Init(RTC_ER_CONFIG_Type* pConfig)
{
	if(pConfig == NULL)
		return ERROR;
	if((LPC_RTC->CCR & RTC_CCR_CLKEN) == 0)
		return ERROR;

	/* EV0 */
	if(pConfig->InputChannel[0].EventOnPosEdge)
		LPC_RTC->ERCONTROL |= RTC_ERCTRL_EV0_POS_EDGE;
	else
		LPC_RTC->ERCONTROL &= ~RTC_ERCTRL_EV0_POS_EDGE;
	
	if(pConfig->InputChannel[0].IntWake)
		LPC_RTC->ERCONTROL |= RTC_ERCTRL_EV0_INTWAKE_ENABLE;
	else
		LPC_RTC->ERCONTROL &= ~RTC_ERCTRL_EV0_INTWAKE_ENABLE;

	if(pConfig->InputChannel[0].GPClear)
		LPC_RTC->ERCONTROL |= RTC_ERCTRL_EV0_GPCLEAR_ENABLE;
	else
		LPC_RTC->ERCONTROL &= ~RTC_ERCTRL_EV0_GPCLEAR_ENABLE;

	/* EV1 */
	if(pConfig->InputChannel[1].EventOnPosEdge)
		LPC_RTC->ERCONTROL |= RTC_ERCTRL_EV1_POS_EDGE;
	else
		LPC_RTC->ERCONTROL &= ~RTC_ERCTRL_EV1_POS_EDGE;
	
	if(pConfig->InputChannel[1].IntWake)
		LPC_RTC->ERCONTROL |= RTC_ERCTRL_EV1_INTWAKE_ENABLE;
	else
		LPC_RTC->ERCONTROL &= ~RTC_ERCTRL_EV1_INTWAKE_ENABLE;

	if(pConfig->InputChannel[1].GPClear)
		LPC_RTC->ERCONTROL |= RTC_ERCTRL_EV1_GPCLEAR_ENABLE;
	else
		LPC_RTC->ERCONTROL &= ~RTC_ERCTRL_EV1_GPCLEAR_ENABLE;

	/* EV2 */
	if(pConfig->InputChannel[2].EventOnPosEdge)
		LPC_RTC->ERCONTROL |= RTC_ERCTRL_EV2_POS_EDGE;
	else
		LPC_RTC->ERCONTROL &= ~RTC_ERCTRL_EV2_POS_EDGE;
	
	if(pConfig->InputChannel[2].IntWake)
		LPC_RTC->ERCONTROL |= RTC_ERCTRL_EV2_INTWAKE_ENABLE;
	else
		LPC_RTC->ERCONTROL &= ~RTC_ERCTRL_EV2_INTWAKE_ENABLE;

	if(pConfig->InputChannel[2].GPClear)
		LPC_RTC->ERCONTROL |= RTC_ERCTRL_EV2_GPCLEAR_ENABLE;
	else
		LPC_RTC->ERCONTROL &= ~RTC_ERCTRL_EV2_GPCLEAR_ENABLE;

	/* Sample Clock */
	LPC_RTC->ERCONTROL &= ~RTC_ERCTRL_MODE_MASK;
	switch(pConfig->Clk)
	{
		case 0:
			LPC_RTC->ERCONTROL |= RTC_ERCTRL_MODE_CLK_DISABLE;
			break;
		case 16:
			LPC_RTC->ERCONTROL |= RTC_ERCTRL_MODE_16HZ;
			break;
		case 64:
			LPC_RTC->ERCONTROL |= RTC_ERCTRL_MODE_64HZ;
			break;
		case 1000:
			LPC_RTC->ERCONTROL |= RTC_ERCTRL_MODE_1KHZ;
			break;
		default:
			return ERROR;
	}
	return SUCCESS;
}
/*********************************************************************//**
 * @brief 		Enable/Disable a input channel for Event Monitor/Recorder
 * @param[in]	channel	Channel Number. It should be 0~2
  * @param[in]state	ENABLE/DISABLE
 * @return 		SUCCESS/ERROR
 **********************************************************************/
Status RTC_ER_Cmd(uint8_t channel, FunctionalState state)
{
	switch(channel)
	{
		case 0:
			if(state)
				LPC_RTC->ERCONTROL |= RTC_ERCTRL_EV0_INPUT_ENABLE;
			else
				LPC_RTC->ERCONTROL &= ~RTC_ERCTRL_EV0_INPUT_ENABLE;
			break;
		case 1:
			if(state)
				LPC_RTC->ERCONTROL |= RTC_ERCTRL_EV1_INPUT_ENABLE;
			else
				LPC_RTC->ERCONTROL &= ~RTC_ERCTRL_EV1_INPUT_ENABLE;
			break;
		case 2:
			if(state)
				LPC_RTC->ERCONTROL |= RTC_ERCTRL_EV2_INPUT_ENABLE;
			else
				LPC_RTC->ERCONTROL &= ~RTC_ERCTRL_EV2_INPUT_ENABLE;
			break;
		default:
			return ERROR;
	}
	return SUCCESS;
}
/*********************************************************************//**
 * @brief 		Get event count on a given channel.
 * @param[in]	channel	Channel Number. It should be 0~2
 * @return 	counter
 **********************************************************************/
uint8_t RTC_ER_GetEventCount(uint8_t channel)
{
	uint8_t count = 0;
	switch(channel)
	{
		case 0:
			count = RTC_ER_EV0_COUNTER(LPC_RTC->ERCOUNTERS);
			break;
		case 1:
			count = RTC_ER_EV1_COUNTER(LPC_RTC->ERCOUNTERS);
			break;
		case 2:
			count = RTC_ER_EV2_COUNTER(LPC_RTC->ERCOUNTERS);
			break;
		default: 
			break;		
	}
	return count;
}
/*********************************************************************//**
 * @brief 		Get Event Monirot/Recorder Status.
 * @param[in]	None
 * @return 	    Status. It can includes:
 *                  RTC_ER_EVENTS_ON_EV0_FLG
 *                  RTC_ER_EVENTS_ON_EV1_FLG
 *                  RTC_ER_EVENTS_ON_EV2_FLG
 *                  RTC_ER_STATUS_GP_CLEARED_FLG
 *                  RTC_ER_STATUS_WAKEUP_REQ_PENDING
 **********************************************************************/
uint32_t RTC_ER_GetStatus(void)
{
    return LPC_RTC->ERSTATUS;
}
/*********************************************************************//**
 * @brief 		Clear Event Monitor/recoder status register.
 * @param[in] status	Status Flag. It should be:
 *                  RTC_ER_EVENTS_ON_EV0_FLG
 *                  RTC_ER_EVENTS_ON_EV1_FLG
 *                  RTC_ER_EVENTS_ON_EV2_FLG
 *                  RTC_ER_STATUS_GP_CLEARED_FLG
 *                  RTC_ER_STATUS_WAKEUP_REQ_PENDING
 * @return 	None
 **********************************************************************/
void RTC_ER_ClearStatus(uint32_t status)
{
	LPC_RTC->ERSTATUS |= status;
}
/*********************************************************************//**
 * @brief 		Check whether a Wakup request is pending or not.
 * @param[in] None
 * @return 	TRUE/FALSE
 **********************************************************************/
Bool RTC_ER_WakupReqPending(void)
{
	if(LPC_RTC->ERSTATUS & RTC_ER_STATUS_WAKEUP_REQ_PENDING)
		return TRUE;
	else
		return FALSE;
}
/*********************************************************************//**
 * @brief 		Check whether RTC General Purpose registed has been cleared or not.
 * @param[in] None
 * @return 	TRUE/FALSE
 **********************************************************************/
Bool 	 RTC_ER_GPCleared(void)
{
	if(LPC_RTC->ERSTATUS & RTC_ER_STATUS_GP_CLEARED_FLG)
		return TRUE;
	else
		return FALSE;
}
/*********************************************************************//**
 * @brief 		Get the timestamp of the fist event on a given channel.
 * @param[in] channel	Channel number (It should be 0~2)
 * @param[in] pTimeStamp	point to the buffer
 * @return 	SUCCESS/ERROR
 **********************************************************************/
Status RTC_ER_GetFirstTimeStamp(uint8_t channel, RTC_ER_TIMESTAMP_Type* pTimeStamp)
{
	if(pTimeStamp == NULL)
		return ERROR;
	
	switch(channel)
	{
		case 0:
			if((LPC_RTC->ERSTATUS & (1<<RTC_ER_STATUS_EV0_BIT)) == 0)
				return ERROR;
			pTimeStamp->SEC = RTC_ER_TIMESTAMP_SEC(LPC_RTC->ERFIRSTSTAMP0);
			pTimeStamp->MIN= RTC_ER_TIMESTAMP_MIN(LPC_RTC->ERFIRSTSTAMP0);
			pTimeStamp->HOUR= RTC_ER_TIMESTAMP_HOUR(LPC_RTC->ERFIRSTSTAMP0);
			pTimeStamp->DOY = RTC_ER_TIMESTAMP_DOY(LPC_RTC->ERFIRSTSTAMP0);
			break;
		case 1:
			if((LPC_RTC->ERSTATUS & (1<<RTC_ER_STATUS_EV1_BIT)) == 0)
				return ERROR;
			pTimeStamp->SEC = RTC_ER_TIMESTAMP_SEC(LPC_RTC->ERFIRSTSTAMP1);
			pTimeStamp->MIN= RTC_ER_TIMESTAMP_MIN(LPC_RTC->ERFIRSTSTAMP1);
			pTimeStamp->HOUR= RTC_ER_TIMESTAMP_HOUR(LPC_RTC->ERFIRSTSTAMP1);
			pTimeStamp->DOY = RTC_ER_TIMESTAMP_DOY(LPC_RTC->ERFIRSTSTAMP1);
			break;
		case 2:
			if((LPC_RTC->ERSTATUS & (1<<RTC_ER_STATUS_EV2_BIT)) == 0)
				return ERROR;
			pTimeStamp->SEC = RTC_ER_TIMESTAMP_SEC(LPC_RTC->ERFIRSTSTAMP2);
			pTimeStamp->MIN= RTC_ER_TIMESTAMP_MIN(LPC_RTC->ERFIRSTSTAMP2);
			pTimeStamp->HOUR= RTC_ER_TIMESTAMP_HOUR(LPC_RTC->ERFIRSTSTAMP2);
			pTimeStamp->DOY = RTC_ER_TIMESTAMP_DOY(LPC_RTC->ERFIRSTSTAMP2);
			break;
		default: 
			break;		
	}
	return SUCCESS;

}
/*********************************************************************//**
 * @brief 		Get the timestamp of the last event on a given channel.
 * @param[in] channel	Channel number (It should be 0~2)
 * @param[in] pTimeStamp	point to the buffer
 * @return 	SUCCESS/ERROR
 **********************************************************************/
Status RTC_ER_GetLastTimeStamp(uint8_t channel, RTC_ER_TIMESTAMP_Type* pTimeStamp)
{
	if(pTimeStamp == NULL)
		return ERROR;
	
	switch(channel)
	{
		case 0:
			if((LPC_RTC->ERSTATUS & (1<<RTC_ER_STATUS_EV0_BIT)) == 0)
				return ERROR;
			pTimeStamp->SEC = RTC_ER_TIMESTAMP_SEC(LPC_RTC->ERLASTSTAMP0);
			pTimeStamp->MIN= RTC_ER_TIMESTAMP_MIN(LPC_RTC->ERLASTSTAMP0);
			pTimeStamp->HOUR= RTC_ER_TIMESTAMP_HOUR(LPC_RTC->ERLASTSTAMP0);
			pTimeStamp->DOY = RTC_ER_TIMESTAMP_DOY(LPC_RTC->ERLASTSTAMP0);
			break;
		case 1:
			if((LPC_RTC->ERSTATUS & (1<<RTC_ER_STATUS_EV1_BIT)) == 0)
				return ERROR;
			pTimeStamp->SEC = RTC_ER_TIMESTAMP_SEC(LPC_RTC->ERLASTSTAMP1);
			pTimeStamp->MIN= RTC_ER_TIMESTAMP_MIN(LPC_RTC->ERLASTSTAMP1);
			pTimeStamp->HOUR= RTC_ER_TIMESTAMP_HOUR(LPC_RTC->ERLASTSTAMP1);
			pTimeStamp->DOY = RTC_ER_TIMESTAMP_DOY(LPC_RTC->ERLASTSTAMP1);
			break;
		case 2:
			if((LPC_RTC->ERSTATUS & (1<<RTC_ER_STATUS_EV2_BIT)) == 0)
				return ERROR;
			pTimeStamp->SEC = RTC_ER_TIMESTAMP_SEC(LPC_RTC->ERLASTSTAMP2);
			pTimeStamp->MIN= RTC_ER_TIMESTAMP_MIN(LPC_RTC->ERLASTSTAMP2);
			pTimeStamp->HOUR= RTC_ER_TIMESTAMP_HOUR(LPC_RTC->ERLASTSTAMP2);
			pTimeStamp->DOY = RTC_ER_TIMESTAMP_DOY(LPC_RTC->ERLASTSTAMP2);
			break;
		default: 
			break;		
	}
	return SUCCESS;

}


/**
 * @}
 */

#endif /*_RTC*/
/**
 * @}
 */

/* --------------------------------- End Of File ------------------------------ */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -