247 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			247 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/**********************************************************************
 | 
						||
* $Id$		lpc43xx_can.h			2011-06-02
 | 
						||
*//**
 | 
						||
* @file		lpc43xx_can.h
 | 
						||
* @brief	Contains all macro definitions and function prototypes
 | 
						||
* 			support for CAN firmware library on lpc43xx
 | 
						||
* @version	1.0
 | 
						||
* @date		02. June. 2011
 | 
						||
* @author	NXP MCU SW Application Team
 | 
						||
*
 | 
						||
* Copyright(C) 2011, NXP Semiconductor
 | 
						||
* All rights reserved.
 | 
						||
*
 | 
						||
***********************************************************************
 | 
						||
* Software that is described herein is for illustrative purposes only
 | 
						||
* which provides customers with programming information regarding the
 | 
						||
* products. This software is supplied "AS IS" without any warranties.
 | 
						||
* NXP Semiconductors assumes no responsibility or liability for the
 | 
						||
* use of the software, conveys no license or title under any patent,
 | 
						||
* copyright, or mask work right to the product. NXP Semiconductors
 | 
						||
* reserves the right to make changes in the software without
 | 
						||
* notification. NXP Semiconductors also make no representation or
 | 
						||
* warranty that such application will be suitable for the specified
 | 
						||
* use without further testing or modification.
 | 
						||
* Permission to use, copy, modify, and distribute this software and its
 | 
						||
* documentation is hereby granted, under NXP Semiconductors<72>
 | 
						||
* relevant copyright in the software, without fee, provided that it
 | 
						||
* is used in conjunction with NXP Semiconductors microcontrollers.  This
 | 
						||
* copyright, permission, and disclaimer notice must appear in all copies of
 | 
						||
* this code.
 | 
						||
**********************************************************************/
 | 
						||
 | 
						||
/* Peripheral group ----------------------------------------------------------- */
 | 
						||
/** @defgroup C_CAN C_CAN (Controller Area Network)
 | 
						||
 * @ingroup LPC4300CMSIS_FwLib_Drivers
 | 
						||
 * @{
 | 
						||
 */
 | 
						||
 | 
						||
#ifndef __lpc43xx_CAN_H
 | 
						||
#define __lpc43xx_CAN_H
 | 
						||
 | 
						||
/* Includes ------------------------------------------------------------------- */
 | 
						||
#include "LPC43xx.h"
 | 
						||
#include "lpc_types.h"
 | 
						||
 | 
						||
 | 
						||
#ifdef __cplusplus
 | 
						||
extern "C"
 | 
						||
{
 | 
						||
#endif
 | 
						||
 | 
						||
/* Public Macros -------------------------------------------------------------- */
 | 
						||
/** @defgroup C_CAN_Public_Macros  C_CAN Public Macros
 | 
						||
 * @{
 | 
						||
 */
 | 
						||
 | 
						||
/** In BASIC_MODE IF1 registers are used directly as TX buffer, IF2 registers are used as RX buffer.
 | 
						||
 * If not BASIC_MODE use message objects and IF registers to communicate with message buffers
 | 
						||
 */
 | 
						||
#define BASIC_MODE 		0
 | 
						||
 | 
						||
/** In Silent Mode, the CAN controller is able to receive valid data frames and valid remote
 | 
						||
 * frames, but it sends only recessive bits on the CAN bus, and it cannot start a transmission
 | 
						||
 */
 | 
						||
#define SILENT_MODE		0
 | 
						||
 | 
						||
/** In Loop-back Mode, the CAN Core treats its own transmitted messages as received messages
 | 
						||
 * and stores them (if they pass acceptance filtering) into a Receive Buffer.
 | 
						||
 */
 | 
						||
#define LOOPBACK_MODE	0
 | 
						||
 | 
						||
/** Enables receiving remote frame requests */
 | 
						||
#define REMOTE_ENABLE	1
 | 
						||
 | 
						||
/**
 | 
						||
 * @}
 | 
						||
 */
 | 
						||
 | 
						||
/* Private Macros -------------------------------------------------------------- */
 | 
						||
/** @defgroup C_CAN_Private_Macros  C_CAN Private Macros
 | 
						||
 * @{
 | 
						||
 */
 | 
						||
 | 
						||
/** MAX CAN message obj */
 | 
						||
#define CAN_MSG_OBJ_MAX			0x0020
 | 
						||
/** MAX data length */
 | 
						||
#define CAN_DLC_MAX				8
 | 
						||
 | 
						||
/********************************************************************//**
 | 
						||
 *  BRP+1 = Fpclk/(CANBitRate * QUANTAValue)
 | 
						||
 * QUANTAValue = 1 + (Tseg1+1) + (Tseg2+1)
 | 
						||
 * QUANTA value varies based on the Fpclk and sample point
 | 
						||
 * e.g. (1) sample point is 87.5%, Fpclk is 48Mhz
 | 
						||
 * the QUANTA should be 16
 | 
						||
 * 		(2) sample point is 90%, Fpclk is 12.5Mhz
 | 
						||
 * the QUANTA should be 10
 | 
						||
 * 		 Fpclk = Fclk /APBDIV
 | 
						||
 * or
 | 
						||
 *  BitRate = Fcclk/(APBDIV * (BRP+1) * ((Tseg1+1)+(Tseg2+1)+1))
 | 
						||
 */
 | 
						||
 | 
						||
/*********************************************************************//**
 | 
						||
 * @brief CAN Bit Timing Values definitions at 8Mhz
 | 
						||
 **********************************************************************/
 | 
						||
/** Bitrate: 100K */
 | 
						||
#define CAN_BITRATE100K12MHZ           0x00004509
 | 
						||
/** Bitrate: 125K */
 | 
						||
#define CAN_BITRATE125K12MHZ           0x00004507
 | 
						||
/** Bitrate: 250K */
 | 
						||
#define CAN_BITRATE250K12MHZ           0x00004503
 | 
						||
/** Bitrate: 500K */
 | 
						||
#define CAN_BITRATE500K12MHZ            0x00004501
 | 
						||
/** Bitrate: 1000K */
 | 
						||
#define CAN_BITRATE1000K12MHZ          0x00004500
 | 
						||
 | 
						||
/*********************************************************************//**
 | 
						||
 * @brief CAN Bit Timing Values definitions at 16Mhz
 | 
						||
 **********************************************************************/
 | 
						||
/** Bitrate: 100K */
 | 
						||
#define CAN_BITRATE100K16MHZ          0x00005809
 | 
						||
/** Bitrate: 125K */
 | 
						||
#define CAN_BITRATE125K16MHZ          0x00005807
 | 
						||
/** Bitrate: 250K */
 | 
						||
#define CAN_BITRATE250K16MHZ          0x00005803
 | 
						||
/** Bitrate: 500K */
 | 
						||
#define CAN_BITRATE500K16MHZ          0x00005801
 | 
						||
 | 
						||
 | 
						||
/*********************************************************************//**
 | 
						||
 * @brief CAN Bit Timing Values definitions at 24Mhz
 | 
						||
 **********************************************************************/
 | 
						||
/** Bitrate: 100K */
 | 
						||
#define CAN_BITRATE100K24MHZ          0x00007E09
 | 
						||
/** Bitrate: 125K */
 | 
						||
#define CAN_BITRATE125K24MHZ          0x0000450F
 | 
						||
/** Bitrate: 250K */
 | 
						||
#define CAN_BITRATE250K24MHZ          0x00004507
 | 
						||
/** Bitrate: 500K */
 | 
						||
#define CAN_BITRATE500K24MHZ          0x00004503
 | 
						||
/** Bitrate: 1000K */
 | 
						||
#define CAN_BITRATE1000K24MHZ         0x00004501
 | 
						||
 | 
						||
/**
 | 
						||
 * @}
 | 
						||
 */
 | 
						||
 | 
						||
 | 
						||
/* Public Types --------------------------------------------------------------- */
 | 
						||
/** @defgroup CAN_Public_Types CAN Public Types
 | 
						||
 * @{
 | 
						||
 */
 | 
						||
 | 
						||
/*********************************************************************//**
 | 
						||
 * @brief CAN enumeration
 | 
						||
 **********************************************************************/
 | 
						||
 | 
						||
/**
 | 
						||
 * @brief CAN interface register type definition
 | 
						||
 */
 | 
						||
typedef enum CCAN_IFREG
 | 
						||
{
 | 
						||
	CMDREQ = 0,				/**< Command request */
 | 
						||
	CMDMSK = 1,				/**< Command mask */
 | 
						||
	MSK1 = 2,				/**< Mask 1 */
 | 
						||
	MSK2 = 3,				/**< Mask 2 */
 | 
						||
	ARB1 = 4,				/**< Arbitration 1 */
 | 
						||
	ARB2 = 5,				/**< Arbitration 2 */
 | 
						||
	MCTRL = 6,				/**< Message control */
 | 
						||
	DA1 = 7,				/**< Data A1 */
 | 
						||
	DA2 = 8,				/**< Data A2 */
 | 
						||
	DB1 = 9,				/**< Data B1 */
 | 
						||
	DB2 = 10				/**< Data B2 */
 | 
						||
}CCAN_IFREG_Type;
 | 
						||
 | 
						||
/**
 | 
						||
 * @brief CAN Clock division rate type definition
 | 
						||
 */
 | 
						||
typedef enum CCAN_CLKDIV
 | 
						||
{
 | 
						||
	CLKDIV1		= 0,
 | 
						||
	CLKDIV2		= 1,
 | 
						||
	CLKDIV3		= 2,
 | 
						||
	CLKDIV5		= 3,
 | 
						||
	CLKDIV9		= 4,
 | 
						||
	CLKDIV17	= 5,
 | 
						||
	CLKDIV33	= 6,
 | 
						||
	CLKDIV65	= 7
 | 
						||
}CCAN_CLKDIV_Type;
 | 
						||
 | 
						||
 | 
						||
/********************************************************************//**
 | 
						||
* @brief Data structure definition for a CAN message
 | 
						||
**********************************************************************/
 | 
						||
/**
 | 
						||
 * @brief CAN message object structure
 | 
						||
 */
 | 
						||
typedef struct
 | 
						||
{
 | 
						||
    uint32_t	id;		/**< ID of message, if bit 30 is set then this is extended frame */
 | 
						||
    uint32_t 	dlc;	/**< Message data length */
 | 
						||
    uint8_t	data[8]; 	/**< Message data */
 | 
						||
} message_object;
 | 
						||
 | 
						||
/**
 | 
						||
 * @brief CAN call-back function
 | 
						||
 */
 | 
						||
typedef void (*MSG_CB)(uint32_t msg_no);
 | 
						||
 | 
						||
/**
 | 
						||
 * @}
 | 
						||
 */
 | 
						||
 | 
						||
 | 
						||
 | 
						||
/* Public Functions ----------------------------------------------------------- */
 | 
						||
/** @defgroup CAN_Public_Functions CAN Public Functions
 | 
						||
 * @{
 | 
						||
 */
 | 
						||
 | 
						||
void CAN_IRQHandler (void);
 | 
						||
void CAN_Init( uint32_t BitClk, CCAN_CLKDIV_Type ClkDiv , MSG_CB Tx_cb, MSG_CB Rx_cb);
 | 
						||
 | 
						||
void CAN_ConfigureRxMessageObjects( void );
 | 
						||
void CAN_RxInt_MessageProcess( uint8_t MsgObjNo );
 | 
						||
void CAN_TxInt_MessageProcess( uint8_t MsgObjNo );
 | 
						||
 | 
						||
void CAN_Send(uint8_t msg_no, uint32_t *msg_ptr );
 | 
						||
void CAN_Recv(uint8_t msg_no, uint32_t *msg_ptr, Bool RemoteEnable);
 | 
						||
void CAN_ReadMsg(uint32_t msg_no, message_object* buff);
 | 
						||
/**
 | 
						||
 * @}
 | 
						||
 */
 | 
						||
 | 
						||
#ifdef __cplusplus
 | 
						||
}
 | 
						||
#endif
 | 
						||
 | 
						||
 | 
						||
#endif /* __lpc43xx_CAN_H */
 | 
						||
 | 
						||
/**
 | 
						||
 * @}
 | 
						||
 */
 | 
						||
/*****************************************************************************
 | 
						||
**                            End Of File
 | 
						||
******************************************************************************/
 |