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

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

?? can.c

?? LPC2368上通過驗證的CAN通訊程序
?? 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 "LPC23xx.h"					/* LPC23xx definitions */
#include "type.h"
#include "irq.h"
#include "can.h"

// Receive Queue: one queue for each CAN port
extern CAN_MSG MsgBuf_RX1, MsgBuf_RX2;
extern volatile DWORD CAN1RxDone, CAN2RxDone;

DWORD CANStatus;
DWORD CAN1RxCount = 0, CAN2RxCount = 0;
DWORD CAN1ErrCount = 0, CAN2ErrCount = 0;

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

  // initialize destination pointer
  pDest = (DWORD *)&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
  return;
}

/******************************************************************************
** Function name:		CAN_ISR_Rx2
**
** Descriptions:		CAN Rx2 interrupt handler
**
** parameters:			None
** Returned value:		None
** 
******************************************************************************/
void CAN_ISR_Rx2( void )  
{
  DWORD *pDest;

  // initialize destination pointer
  pDest = (DWORD *)&MsgBuf_RX2;
  *pDest = CAN2RFS;  // Frame

  pDest++;
  *pDest = CAN2RID; // ID

  pDest++;
  *pDest = CAN2RDA; // Data A

  pDest++;
  *pDest = CAN2RDB; // Data B

  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) __irq 
{		
//  IENABLE;			/* handles nested interrupt */

  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 );
  }
//  IDISABLE;
  VICVectAddr = 0;		/* Acknowledge Interrupt */
  return;
}

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

  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


	//DENGTING RESET the can_btr
	can_btr=0;
	//Set BRP divider of CCLOCK
	can_btr|=(12 << 0);  //1/4 of CCLCK	PcanClck=36Mhz
	can_btr|=(4 << 14);	//SJW = 2 QT
	can_btr|=(6 << 16);//TESG1 4 QT
	can_btr|=(9 << 20);//TESG2 6 QT
	can_btr|=(0 << 23);	//SAMPLE 1 times

	// 1 + 7 + 10  = 36/2/4/18 =  0.25M == 250K

  CAN1BTR = CAN2BTR = can_btr;

#if LOCAL_SELF_TEST
  CAN1MOD = CAN2MOD = 1 << 2;	// CAN in self test mode
  CAN1CMR = CAN2CMR	= 1 << 4;	// Self Reception Request.
#else
  CAN1MOD = CAN2MOD = 0x0;		// CAN in normal operation mode
#endif

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

/******************************************************************************
** Function name:		CAN_SetACCF_Lookup
**
** Descriptions:		
**
** parameters:			
** Returned value:		
** 
******************************************************************************/
void CAN_SetACCF_Lookup( void )
{
  DWORD address = 0;
  DWORD i;
  DWORD ID_high, ID_low;

  // Set explicit standard Frame  
  CAN_SFF_SA = address;
  for ( i = 0; i < ACCF_IDEN_NUM; i += 2 )
  {
	ID_low = (i << 29) | (EXP_STD_ID << 16);
	ID_high = ((i+1) << 13) | (EXP_STD_ID << 0);
	*((volatile DWORD *)(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 += 2 )
  {
	ID_low = (i << 29) | (GRP_STD_ID << 16);
	ID_high = ((i+1) << 13) | (GRP_STD_ID << 0);
	*((volatile DWORD *)(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 DWORD *)(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) | (GRP_EXT_ID << 0);
	*((volatile DWORD *)(CAN_MEM_BASE + address)) = ID_low;
	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( DWORD 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.
** 
******************************************************************************/
DWORD CAN1_SendMessage( CAN_MSG *pTxBuf )
{
  DWORD CANStatus;

  CANStatus = CAN1SR;
  if ( CANStatus & 0x00000004 )
  {
	CAN1TFI1 = pTxBuf->Frame & 0xC00F0000;
	CAN1TID1 = pTxBuf->MsgID;
	CAN1TDA1 = pTxBuf->DataA;
	CAN1TDB1 = pTxBuf->DataB;
#if LOCAL_SELF_TEST
	CAN1CMR = 0x30;
#else
	CAN1CMR = 0x21;
#endif
	return ( TRUE );
  }
  else if ( CANStatus & 0x00000400 )
  {
	CAN1TFI2 = pTxBuf->Frame & 0xC00F0000;
	CAN1TID2 = pTxBuf->MsgID;
	CAN1TDA2 = pTxBuf->DataA;
	CAN1TDB2 = pTxBuf->DataB;
#if LOCAL_SELF_TEST
	CAN1CMR = 0x50;
#else
	CAN1CMR = 0x41;
#endif
	return ( TRUE );
  }
  else if ( CANStatus & 0x00040000 )
  {	
	CAN1TFI3 = pTxBuf->Frame & 0xC00F0000;
	CAN1TID3 = pTxBuf->MsgID;
	CAN1TDA3 = pTxBuf->DataA;
	CAN1TDB3 = pTxBuf->DataB;
#if LOCAL_SELF_TEST
	CAN1CMR = 0x90;
#else
	CAN1CMR = 0x81;
#endif
	return ( TRUE );
  }
  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.
** 
******************************************************************************/
DWORD CAN2_SendMessage( CAN_MSG *pTxBuf )
{
  DWORD CANStatus;

  CANStatus = CAN2SR;
  if ( CANStatus & 0x00000004 )
  {
	CAN2TFI1 = pTxBuf->Frame & 0xC00F0000;
	CAN2TID1 = pTxBuf->MsgID;
	CAN2TDA1 = pTxBuf->DataA;
	CAN2TDB1 = pTxBuf->DataB;
#if LOCAL_SELF_TEST
	CAN2CMR = 0x30;
#else
	CAN2CMR = 0x21;
#endif
	return ( TRUE );
  }
  else if ( CANStatus & 0x00000400 )
  {
	CAN2TFI2 = pTxBuf->Frame & 0xC00F0000;
	CAN2TID2 = pTxBuf->MsgID;
	CAN2TDA2 = pTxBuf->DataA;
	CAN2TDB2 = pTxBuf->DataB;
#if LOCAL_SELF_TEST
	CAN2CMR = 0x50;
#else
	CAN2CMR = 0x41;
#endif
	return ( TRUE );
  }
  else if ( CANStatus & 0x00040000 )
  {	
	CAN2TFI3 = pTxBuf->Frame & 0xC00F0000;
	CAN2TID3 = pTxBuf->MsgID;
	CAN2TDA3 = pTxBuf->DataA;
	CAN2TDB3 = pTxBuf->DataB;
#if LOCAL_SELF_TEST
	CAN2CMR = 0x90;
#else
	CAN2CMR = 0x81;
#endif
	return ( TRUE );
  }
  return ( FALSE );
}
/******************************************************************************
**                            End Of File
******************************************************************************/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品欧美一区二区三区| 成人av网址在线观看| 91成人在线免费观看| 亚洲人快播电影网| va亚洲va日韩不卡在线观看| 亚洲欧美一区二区三区孕妇| 精品视频999| 麻豆视频一区二区| 精品三级在线看| 成人免费电影视频| 亚洲一区二区三区美女| 91精品国产91久久久久久一区二区| 日韩二区三区在线观看| 精品理论电影在线观看| caoporen国产精品视频| 亚洲国产日韩a在线播放性色| 91精品国产综合久久久蜜臀图片| 开心九九激情九九欧美日韩精美视频电影 | 欧美日本在线一区| 激情综合一区二区三区| 国产精品久久久久久久裸模| 欧美日韩一区二区在线观看视频| 蜜臂av日日欢夜夜爽一区| 中文字幕国产一区二区| 精品视频999| 高清国产一区二区| 视频一区在线播放| 中文字幕不卡三区| 欧美日韩国产精品自在自线| 国产mv日韩mv欧美| 亚洲国产日韩综合久久精品| 国产亚洲欧美一级| 欧美二区三区的天堂| 国产成人精品一区二区三区四区 | 国产精品―色哟哟| 欧美日韩三级视频| 成人激情免费网站| 奇米影视一区二区三区| 亚洲另类在线视频| 国产亚洲欧洲一区高清在线观看| 欧美偷拍一区二区| 不卡视频在线看| 精品一区二区三区久久久| 亚洲欧美国产毛片在线| 国产喷白浆一区二区三区| 欧美理论在线播放| 日本道色综合久久| 成人丝袜视频网| 国产一区二区主播在线| 蜜臀av性久久久久av蜜臀妖精 | 2023国产一二三区日本精品2022| 欧美特级限制片免费在线观看| 国产精品亚洲专一区二区三区 | 美腿丝袜在线亚洲一区| 亚洲欧美二区三区| 国产精品三级久久久久三级| 欧美刺激午夜性久久久久久久| 欧美主播一区二区三区| 成+人+亚洲+综合天堂| 国产精品一区二区91| 麻豆91小视频| 免费高清视频精品| 蜜臀国产一区二区三区在线播放| 亚洲国产精品影院| 亚洲国产精品一区二区www| 亚洲天堂a在线| 18成人在线视频| 亚洲图片欧美激情| 亚洲四区在线观看| 亚洲欧美自拍偷拍色图| 国产精品久久久久久妇女6080| 久久色在线观看| 国产欧美视频一区二区三区| 国产日韩亚洲欧美综合| 日本一二三四高清不卡| 国产精品午夜久久| 亚洲欧洲成人精品av97| 最新高清无码专区| 国产精品国产三级国产三级人妇| 国产精品久久久久久一区二区三区| 欧美国产乱子伦| 1024成人网| 亚洲精品高清在线| 五月激情综合色| 美国毛片一区二区| 国产一区二区三区不卡在线观看 | 波多野结衣在线一区| 99re这里只有精品6| 色综合天天综合狠狠| 色综合色狠狠综合色| 在线亚洲免费视频| 91精品国产福利在线观看| 欧美tk丨vk视频| 国产精品视频一二三区| 亚洲视频图片小说| 日韩黄色片在线观看| 国内精品伊人久久久久av一坑| 国产乱子轮精品视频| av不卡一区二区三区| 欧美日韩精品欧美日韩精品| 精品久久久久一区二区国产| 国产欧美一二三区| 亚洲国产日韩a在线播放| 久久99国产精品久久99 | 欧美另类z0zxhd电影| 亚洲精品一区二区三区在线观看| 国产拍揄自揄精品视频麻豆| 一区二区三区欧美在线观看| 日本不卡一二三| 成人一区在线观看| 欧美日韩久久久一区| 久久综合视频网| 一区二区激情小说| 激情综合网最新| 欧美在线观看禁18| 久久久精品免费观看| 亚洲国产视频在线| 国产高清不卡二三区| 欧美日韩精品一二三区| 欧美激情资源网| 日本成人在线不卡视频| aaa国产一区| 久久五月婷婷丁香社区| 亚洲自拍欧美精品| 国产激情精品久久久第一区二区| 91成人看片片| 国产亚洲精品bt天堂精选| 亚洲高清免费在线| 成人黄色国产精品网站大全在线免费观看 | 99久久99久久综合| 亚洲精品一区二区三区影院| 一区二区三区成人在线视频| 国产一区二区三区免费观看| 一本色道久久综合亚洲aⅴ蜜桃| 91精品综合久久久久久| 成人欧美一区二区三区| 免费看黄色91| 精品视频全国免费看| 国产精品护士白丝一区av| 日韩av电影天堂| 成人免费不卡视频| 精品国产精品一区二区夜夜嗨| 亚洲综合丝袜美腿| 99久久婷婷国产| 久久久三级国产网站| 琪琪久久久久日韩精品| 色拍拍在线精品视频8848| 国产精品乱人伦中文| 极品少妇xxxx精品少妇| 日韩午夜激情av| 日本三级亚洲精品| 欧美熟乱第一页| 亚洲欧美国产77777| 91香蕉视频污在线| 日本一区免费视频| 国产精品1区2区3区在线观看| 欧美一区二区不卡视频| 日韩中文字幕麻豆| 欧美体内she精高潮| 亚洲激情在线播放| 在线观看日韩毛片| 玉足女爽爽91| 91亚洲精品乱码久久久久久蜜桃| 日本一区二区三区四区在线视频| 国产精品996| 久久久综合视频| 精品一区二区三区在线视频| 日韩午夜在线播放| 首页国产欧美久久| 欧美日韩精品一区视频| 丝袜亚洲另类欧美| 欧美精品成人一区二区三区四区| 一个色综合网站| 91美女视频网站| 亚洲一区二区不卡免费| 精品污污网站免费看| 偷窥国产亚洲免费视频| 久久久蜜臀国产一区二区| 国产成人丝袜美腿| 中文av字幕一区| 91原创在线视频| 一区二区三区国产精华| 欧美中文字幕不卡| 亚洲综合自拍偷拍| 在线观看精品一区| 成人欧美一区二区三区1314| 色婷婷国产精品| 亚洲小少妇裸体bbw| 精品女同一区二区| 韩日欧美一区二区三区| 国产精品麻豆99久久久久久| jizzjizzjizz欧美| 日日夜夜精品视频免费| 久久影院视频免费| 成人av电影免费观看| 亚洲福利视频三区| 在线观看国产91| 另类成人小视频在线| 国产精品久久久久永久免费观看| 色婷婷精品久久二区二区蜜臂av|