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

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

?? can.c

?? 講述LPC2468在無操作系統條件下使用YAFFS文件系統是如何實現的以及完整的測試代碼,代碼部分詳見lpc2468_yaffs2.rar
?? C
字號:
/*****************************************************************************
 *  can.c:  CAN module API file for NXP LPC23xx/24xx Family Microprocessors
 *
 *   Copyright(C) 2006, NXP Semiconductor
 *   All rights reserved.
 *
 *   History
 *   2006.09.13  ver 1.00    Prelimnary version, first Release
 *
*****************************************************************************/
#include <target.h>
#include <can.h>


// Receive Queue: one queue for each CAN port
extern CAN_MSG MsgBuf_RX1, MsgBuf_RX2;
extern volatile uint32_t CAN1RxDone, CAN2RxDone;
struct PASSTHRU_MSG passthru_msg;

uint32_t CANStatus;

CAN_MSG First_Frame_buff[4];
uint8_t First_Frame_insert_idx,First_Frame_extract_idx;
uint8_t First_Keep = 0;

CAN_MSG can1_rx_buff[64];

uint16_t can1_rx_insert_idx, can1_rx_extract_idx;
uint32_t CAN1RxCount = 0, CAN2RxCount = 0;
uint32_t CAN1ErrCount = 0, CAN2ErrCount = 0;

extern uint32_t EXT_ID[2];


volatile uint8_t CAN1RX_ID = 0;

/******************************************************************************
** Function name:		CAN_ISR_Rx1
**
** Descriptions:		CAN Rx1 interrupt handler
**
** parameters:			None
** Returned value:		None
** 
******************************************************************************/
void CAN_ISR_Rx1( void )
{
	
	uint32_t * pDest;

	// initialize destination pointer
	pDest = (uint32_t *)&MsgBuf_RX1;
	*pDest = CAN1RFS;  // Frame

	pDest++;
	*pDest = CAN1RID; // ID		//change by gongjun

	pDest++;
	*pDest = CAN1RDA; // Data A
	
	pDest++;
	*pDest = CAN1RDB; // Data B
	
	CAN1RxDone = TRUE;
	CAN1CMR = 0x04; // release receive buffer
	CAN1RX_ID = 1;
	return;

}

/******************************************************************************
** Function name:		CAN_ISR_Rx2
**
** Descriptions:		CAN Rx2 interrupt handler
**
** parameters:			None
** Returned value:		None
** 
******************************************************************************/
void CAN_ISR_Rx2( void )
{
	uint32_t *pDest;
	uint32_t temp;
	uint32_t Frame_Type;
	
	RX_LED_ON;
	
	temp = CAN2RDA;
	
	
	
	Frame_Type = (temp>> 4) & 0x0000000f;
	
	if(Frame_Type == 1)	//First Frame
	{
		if(!First_Keep)
		{
			
			temp = (can1_rx_insert_idx + 1) % 64;
			can1_rx_buff[can1_rx_insert_idx].Frame = CAN2RFS;
			can1_rx_buff[can1_rx_insert_idx].MsgID = CAN2RID;
			can1_rx_buff[can1_rx_insert_idx].DataA = CAN2RDA;
			can1_rx_buff[can1_rx_insert_idx].DataB = CAN2RDB;
			if(temp != can1_rx_extract_idx)
				can1_rx_insert_idx = temp;
			First_Keep = 1;
			passthru_msg_index = 0;
		}
		else
		{
			temp = (First_Frame_insert_idx + 1) % 4;
			First_Frame_buff[First_Frame_insert_idx].Frame = CAN2RFS;
			First_Frame_buff[First_Frame_insert_idx].MsgID = CAN2RID;
			First_Frame_buff[First_Frame_insert_idx].DataA = CAN2RDA;
			First_Frame_buff[First_Frame_insert_idx].DataB = CAN2RDB;
			if(temp != First_Frame_extract_idx)
				First_Frame_insert_idx = temp;	
		}	
	}
//	else if(Frame_Type == 2)
//	{
//		passthru_msg_data[passthru_msg_index++] = CAN2RDA;
//		passthru_msg_data[passthru_msg_index++] = CAN2RDB;
//		passthru_fc_cnt --;
//	}
	else
	{
		temp = (can1_rx_insert_idx + 1) % 64;
	
			can1_rx_buff[can1_rx_insert_idx].Frame = CAN2RFS;
			can1_rx_buff[can1_rx_insert_idx].MsgID = CAN2RID;
			can1_rx_buff[can1_rx_insert_idx].DataA = CAN2RDA;
			can1_rx_buff[can1_rx_insert_idx].DataB = CAN2RDB;
	
		if(temp != can1_rx_extract_idx)
			can1_rx_insert_idx = temp;
	}
		

/*	pDest = (uint32_t *)&MsgBuf_RX2;
	*pDest = CAN2RFS;  // Frame
	
	pDest++;
	*pDest = CAN2RID; // ID

	pDest++;
	*pDest = CAN2RDA; // Data A
	*pDest = Reverse(*pDest);
	pDest++;
	*pDest = CAN2RDB; // Data B
	*pDest = Reverse(*pDest);
*/

	CAN2RxDone = TRUE;
	CAN2CMR = 0x04; // release receive buffer
	return;
}

/*****************************************************************************
** Function name:		CAN_Handler
**
** Descriptions:		CAN interrupt handler
**
** parameters:			None
** Returned value:		None
** 
*****************************************************************************/
void CAN_Handler(void) 
{		
  // perform proper ISR entry so thumb-interwork works properly
  ISR_ENTRY();

	CANStatus = CAN_RX_SR;
	if ( CANStatus & (1 << 8) )
	{
		CAN1RxCount++;
		CAN_ISR_Rx1();
	}
	if ( CANStatus & (1 << 9) )
	{
		CAN2RxCount++;
		CAN_ISR_Rx2();
	}
	if ( CAN1GSR & (1 << 6 ) )
	{
		/* The error count includes both TX and RX */
		CAN1ErrCount = (CAN1GSR >> 16 );
	}
	if ( CAN2GSR & (1 << 6 ) )
	{
		/* The error count includes both TX and RX */
		CAN2ErrCount = (CAN2GSR >> 16 );
	}

    VICVectAddr = 0;		/* Acknowledge Interrupt */
  ISR_EXIT();                           // recover registers and return
	return;
}

/******************************************************************************
** Function name:		CAN_Init
**
** Descriptions:		Initialize CAN, install CAN interrupt handler
**
** parameters:			bitrate
** Returned value:		true or false, false if initialization failed.
** 
******************************************************************************/
uint32_t CAN_Init( uint32_t can_btr )
{
	CAN1RxDone = CAN2RxDone = FALSE;
	
	can1_rx_extract_idx = can1_rx_insert_idx = 0;
	

	PCONP |= (1 << 13) | (1 << 14);	// Enable clock to the peripheral

    PINSEL0	&= ~0x00000F0F;
	PINSEL0 |= 0x0000A05;	// port0.0~1, function 0x01, port0.4~5, function 0x10

	CAN1MOD = CAN2MOD = 1;	// Reset CAN
	CAN1IER = CAN2IER = 0;	// Disable Receive Interrupt
	CAN1GSR = CAN2GSR = 0;	// Reset error counter when CANxMOD is in reset

	CAN1BTR = CAN2BTR = can_btr;
	CAN1MOD = CAN2MOD = 0x04;	// CAN in normal operation mode

	// Install CAN interrupt handler
	install_irq( 23, (void *)CAN_Handler, 4 );
//	CAN1IER = CAN2IER = 0x01;		// Enable receive interrupts
	CAN1IER = 0x01;		// Enable receive interrupts
	CAN_SetACCF( ACCF_BYPASS );
	return( TRUE );
}

/******************************************************************************
** Function name:		CAN_SetACCF_Lookup
**
** Descriptions:		Initialize CAN, install CAN interrupt handler
**
** parameters:			bitrate
** Returned value:		true or false, false if initialization failed.
** 
******************************************************************************/
void CAN_SetACCF_Lookup( void )
{
	uint32_t address = 0;
	uint32_t i;
	uint32_t ID_high, ID_low;

	// Set explicit standard Frame  
	CAN_SFF_SA = address;
	for ( i = 0; i < ACCF_IDEN_NUM; i += 1 )
	{
		ID_low = (i << 29) | (EXP_STD_ID << 16);
		ID_high = ((i) << 13) | (EXP_STD_ID << 0);
		*((volatile uint32_t *)(CAN_MEM_BASE + address)) = ID_low | ID_high;
		address += 4; 
	}
		
	// Set group standard Frame 
	CAN_SFF_GRP_SA = address;
   	for ( i = 0; i < ACCF_IDEN_NUM; i += 1 )
	{
		ID_low = (i << 29) | (GRP_STD_ID_LOW << 16);
		ID_high = ((i) << 13) | (GRP_STD_ID_HIGH << 0);
		*((volatile uint32_t *)(CAN_MEM_BASE + address)) = ID_low | ID_high;
		address += 4; 
	}
 
	// Set explicit extended Frame 
	CAN_EFF_SA = address;
	for ( i = 0; i < ACCF_IDEN_NUM; i++  )
	{
		ID_low = (i << 29) | (EXP_EXT_ID << 0);
		*((volatile uint32_t *)(CAN_MEM_BASE + address)) = ID_low;
		address += 4; 
	}

	// Set group extended Frame 
	CAN_EFF_GRP_SA = address;
   	for ( i = 0; i < ACCF_IDEN_NUM; i++  )
	{
//		ID_low = (i << 29) | (EXT_ID[0] << 0);
//		*((volatile uint32_t *)(CAN_MEM_BASE + address)) = ID_low;
//		address += 4; 
//		ID_high = (i << 29) | (EXT_ID[1] << 0);
//		*((volatile uint32_t *)(CAN_MEM_BASE + address)) = ID_high;
//		address += 4; 
	}
   
	// Set End of Table 
 	CAN_EOT = address;
	return;
}

/******************************************************************************
** Function name:		CAN_SetACCF
**
** Descriptions:		Set acceptance filter and SRAM associated with	
**
** parameters:			ACMF mode
** Returned value:		None
**
** 
******************************************************************************/
void CAN_SetACCF( uint32_t ACCFMode )
{
	switch ( ACCFMode )
	{
		case ACCF_OFF:
		CAN_AFMR = ACCFMode;
		CAN1MOD = CAN2MOD = 1;	// Reset CAN
		CAN1IER = CAN2IER = 0;	// Disable Receive Interrupt
		CAN1GSR = CAN2GSR = 0;	// Reset error counter when CANxMOD is in reset
		break;

		case ACCF_BYPASS:
		CAN_AFMR = ACCFMode;
		break;

		case ACCF_ON:
		case ACCF_FULLCAN:
		CAN_AFMR = ACCF_OFF;
		CAN_SetACCF_Lookup();
		CAN_AFMR = ACCFMode;
		break;

		default:
		break;
	}
	return;
}

/******************************************************************************
** Function name:		CAN1_SendMessage
**
** Descriptions:		Send message block to CAN1	
**
** parameters:			pointer to the CAN message
** Returned value:		true or false, if message buffer is available,
**						message can be sent successfully, return TRUE,
**						otherwise, return FALSE.
** 
******************************************************************************/
uint32_t CAN1_SendMessage( CAN_MSG *pTxBuf )
{
//    uint32_t CANStatus;

	CANStatus = CAN1SR;
	if ( CANStatus & 0x00000004 )
	{
		CAN1TFI1 = pTxBuf->Frame & 0xC00F0000;
		CAN1TID1 = pTxBuf->MsgID;
		CAN1TDA1 = pTxBuf->DataA;
		CAN1TDB1 = pTxBuf->DataB;
		CAN1CMR = 0x21;
		return ( TRUE );
	}
	else if ( CANStatus & 0x00000400 )
	{
		CAN1TFI2 = pTxBuf->Frame & 0xC00F0000;
		CAN1TID2 = pTxBuf->MsgID;
		CAN1TDA2 = pTxBuf->DataA;
		CAN1TDB2 = pTxBuf->DataB;
		CAN1CMR = 0x41;
		return ( TRUE );
	}
	else if ( CANStatus & 0x00040000 )
	{	
		CAN1TFI3 = pTxBuf->Frame & 0xC00F0000;
		CAN1TID3 = pTxBuf->MsgID;
		CAN1TDA3 = pTxBuf->DataA;
		CAN1TDB3 = pTxBuf->DataB;
		CAN1CMR = 0x81;
		return ( TRUE );
	}
	else
	{
		return ( FALSE );
	}
}

/******************************************************************************
** Function name:		CAN2_SendMessage
**
** Descriptions:		Send message block to CAN2	
**
** parameters:			pointer to the CAN message
** Returned value:		true or false, if message buffer is available,
**						message can be sent successfully, return TRUE,
**						otherwise, return FALSE.
** 
******************************************************************************/
uint32_t CAN2_SendMessage( CAN_MSG *pTxBuf )
{
//    uint32_t CANStatus;
	CANStatus = CAN2SR;
	if ( CANStatus & 0x00000004 )
	{
		CAN2TFI1 = pTxBuf->Frame & 0xC00F0000;
		CAN2TID1 = pTxBuf->MsgID;
		CAN2TDA1 = pTxBuf->DataA;
		CAN2TDB1 = pTxBuf->DataB;
		CAN2CMR = 0x21;
		return ( TRUE );
	}
	else if ( CANStatus & 0x00000400 )
	{
		CAN2TFI2 = pTxBuf->Frame & 0xC00F0000;
		CAN2TID2 = pTxBuf->MsgID;
		CAN2TDA2 = pTxBuf->DataA;
		CAN2TDB2 = pTxBuf->DataB;
		CAN2CMR = 0x41;
		return ( TRUE );
	}
	else if ( CANStatus & 0x00040000 )
	{	
		CAN2TFI3 = pTxBuf->Frame & 0xC00F0000;
		CAN2TID3 = pTxBuf->MsgID;
		CAN2TDA3 = pTxBuf->DataA;
		CAN2TDB3 = pTxBuf->DataB;
		CAN2CMR = 0x81;
		return ( TRUE );
	}
	else
	{
		return ( FALSE );
	}
}

CAN_MSG * CAN1Getch(void)
{
  CAN_MSG * ch;
	
  if (can1_rx_insert_idx == can1_rx_extract_idx) // check if character is available
    return 0;

  ch = &can1_rx_buff[can1_rx_extract_idx++]; // get character, bump pointer
  can1_rx_extract_idx %= 64; // limit the pointer
 
  return ch;
}


CAN_MSG * CAN1GetFirstch(void)
{
  CAN_MSG * ch;
	
  if (First_Frame_insert_idx == First_Frame_extract_idx) // check if character is available
    return 0;

  ch = &First_Frame_buff[First_Frame_extract_idx++]; // get character, bump pointer
  First_Frame_extract_idx %= 4; // limit the pointer
 
  return ch;
}


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

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区三区四| 久久综合99re88久久爱| 中文字幕亚洲欧美在线不卡| 丰满少妇久久久久久久| 国产欧美日韩亚州综合| 成人av在线一区二区三区| 中文字幕中文在线不卡住| 99久久精品国产网站| 亚洲精品亚洲人成人网 | 久久成人免费网| 欧美不卡在线视频| 国产麻豆一精品一av一免费 | 亚洲精品国产成人久久av盗摄 | 欧美日韩国产美| 日本伊人午夜精品| 精品sm捆绑视频| 不卡的av网站| 亚洲午夜久久久| 欧美成人欧美edvon| 成人免费视频一区| 亚洲成人精品影院| 久久综合九色综合欧美98| aaa欧美日韩| 日韩国产欧美视频| 国产视频视频一区| 91福利视频在线| 久久国产精品露脸对白| 国产精品久久久久国产精品日日| 欧美性生活一区| 国产一区二区精品久久| 亚洲自拍偷拍九九九| 精品久久久久99| 色噜噜狠狠成人中文综合| 日韩精品一区第一页| 日本一区二区成人| 日韩欧美在线网站| 色噜噜狠狠一区二区三区果冻| 久久国产夜色精品鲁鲁99| ...av二区三区久久精品| 欧美一个色资源| 91麻豆.com| 国产乱码精品一品二品| 亚洲成人黄色小说| 国产精品短视频| 欧美不卡一二三| 欧美日韩久久不卡| 99国产精品一区| 国产呦萝稀缺另类资源| 亚洲成人tv网| 亚洲美女在线国产| 亚洲国产精品黑人久久久| 日韩午夜av一区| 欧美性猛交xxxxxx富婆| av男人天堂一区| 国产精品一区在线| 久久99久久精品| 亚洲一区中文在线| 国产精品久久久久久久久免费桃花| 日韩女优视频免费观看| 欧美日韩精品专区| 欧美色图12p| 91福利国产精品| 91女神在线视频| 成人h动漫精品| 成人sese在线| av电影天堂一区二区在线观看| 国产在线精品不卡| 久久黄色级2电影| 麻豆国产精品一区二区三区| 午夜伦理一区二区| 亚洲成人免费在线观看| 亚洲国产精品久久久久秋霞影院| 136国产福利精品导航| 中文字幕高清一区| 欧美国产1区2区| 国产精品久久久久精k8 | 一区二区三区在线观看国产| 国产午夜精品一区二区三区四区| 欧美成人一区二区| 久久你懂得1024| 国产清纯在线一区二区www| 久久亚洲一区二区三区明星换脸| 欧美一区二区三区不卡| 91精品欧美综合在线观看最新| 欧美日韩精品三区| 日韩欧美视频在线| 久久综合狠狠综合久久综合88 | 88在线观看91蜜桃国自产| 欧美日韩视频在线观看一区二区三区| 91麻豆文化传媒在线观看| 91丨国产丨九色丨pron| 日本韩国精品一区二区在线观看| 91偷拍与自偷拍精品| 欧美性色黄大片| 3d动漫精品啪啪| 精品国产污污免费网站入口| 久久久久久亚洲综合| 国产精品美女一区二区| 亚洲摸摸操操av| 五月婷婷激情综合| 日韩av一区二区在线影视| 日韩一区二区电影在线| 欧美高清视频www夜色资源网| 欧美在线小视频| 在线不卡中文字幕播放| 精品国产免费久久| 中文字幕不卡在线观看| 亚洲欧美另类久久久精品2019| 亚洲精品v日韩精品| 天天操天天色综合| 国精产品一区一区三区mba桃花| 国产69精品久久久久毛片| 欧美岛国在线观看| 中文字幕一区二区日韩精品绯色| 亚洲欧美日韩精品久久久久| 亚洲福利视频一区二区| 精品一区二区在线看| 99在线精品观看| 这里只有精品电影| 欧美激情一区三区| 亚洲h动漫在线| 国产在线精品免费av| 色欧美片视频在线观看| 欧美一区二区三区免费大片| 久久精品亚洲国产奇米99| 亚洲欧美电影一区二区| 免费亚洲电影在线| fc2成人免费人成在线观看播放| 欧美视频中文字幕| 国产性天天综合网| 亚洲第一福利视频在线| 国产精品一区在线观看乱码| 91黄色在线观看| 久久综合成人精品亚洲另类欧美| 亚洲人成人一区二区在线观看| 日韩成人dvd| 一本久久综合亚洲鲁鲁五月天 | 国产自产视频一区二区三区| 色综合视频一区二区三区高清| 日韩美女天天操| 亚洲成人av在线电影| 91在线精品一区二区| 欧美不卡视频一区| 视频一区二区中文字幕| 色哦色哦哦色天天综合| 国产欧美一区二区三区沐欲| 日韩av一区二区三区| 在线观看av一区二区| 中文字幕中文字幕中文字幕亚洲无线| 免费成人av资源网| 91麻豆精品国产91久久久久| 亚洲欧美偷拍另类a∨色屁股| 国产乱妇无码大片在线观看| 欧美成人a∨高清免费观看| 日韩电影在线免费| 欧美在线观看一区| 一区二区三区日韩在线观看| 99这里只有精品| 欧美激情一区二区三区四区| 国产在线精品不卡| 精品国产亚洲在线| 紧缚捆绑精品一区二区| 欧美一区二区三区婷婷月色 | 蜜桃av一区二区| 欧美日本乱大交xxxxx| 一区二区三区成人| 在线观看一区二区精品视频| 亚洲免费观看视频| 欧美影院精品一区| 亚洲综合一二区| 欧美视频一区二区三区四区| 一区二区日韩av| 欧美日韩一区二区三区视频| 亚洲国产欧美日韩另类综合 | 欧美亚一区二区| 亚洲电影一区二区| 欧美日本一区二区三区四区| 亚洲mv在线观看| 3d成人h动漫网站入口| 午夜成人免费视频| 日韩小视频在线观看专区| 老司机午夜精品| 久久蜜桃香蕉精品一区二区三区| 国产综合成人久久大片91| 国产欧美精品一区二区三区四区| 国产美女视频91| √…a在线天堂一区| 欧美天堂一区二区三区| 三级成人在线视频| 精品久久五月天| 成人免费高清在线观看| 亚洲免费观看高清完整版在线观看熊 | 欧美在线999| 日韩av一区二区三区四区| 精品福利一区二区三区| 国产a视频精品免费观看| 最好看的中文字幕久久| 欧美伊人久久大香线蕉综合69 | 亚洲影视资源网| 欧美一区二区日韩|