NXP RT1060学习总结 - fsl_flexcan 基础CAN函数说明 -1

概要

CAN测试源码:
https://download.csdn.net/download/qq_35671135/89425377

根据fsl_flexcan.h文件从文件末尾往前面梳理,总共30个基础CAN函数;
该文章只梳理常规CAN,增强型CAN后面再单独梳理。
使用的是RT1064开发板进行测试。

1、FlexCAN IRQ句柄函数

函 数 :void FLEXCAN_TransferHandleIRQ(CAN_Type *base, flexcan_handle_t *handle);
说 明 :这个函数处理FlexCAN错误、消息缓冲区和Rx FIFO IRQ请求
参 数 :base FlexCAN外设基地址
参 数 :handle FlexCAN句柄指针
返回值:无

2、终止从Rx FIFO进程接收的中断驱动消息

函 数 :void FLEXCAN_TransferAbortReceiveFifo(CAN_Type *base, flexcan_handle_t *handle);
说 明 :这个函数终止从Rx FIFO进程接收的中断驱动的消息
参 数 :base FlexCAN外设基地址
参 数 :handle FlexCAN句柄指针
返回值:无

3、中止中断驱动的消息接收进程

函 数 :void FLEXCAN_TransferAbortReceive(CAN_Type *base, flexcan_handle_t *handle, uint8_t mbIdx);
说 明 :这个函数中止中断驱动的消息接收进程
参 数 :base FlexCAN外设基地址
参 数 :handle FlexCAN句柄指针
参 数 :mbIdx FlexCAN消息缓冲区索引
返回值:无

4、中止中断驱动的消息发送进程

函 数 :void FLEXCAN_TransferAbortSend(CAN_Type *base, flexcan_handle_t *handle, uint8_t mbIdx);
说 明 :这个函数终止中断驱动的消息发送进程
参 数 :base FlexCAN外设基地址
参 数 :handle FlexCAN句柄指针
参 数 :mbIdx FlexCAN消息缓冲区索引
返回值:

5、按句柄获取邮箱的时间戳的详细索引

函 数 :uint32_t FLEXCAN_GetTimeStamp(flexcan_handle_t *handle, uint8_t mbIdx);
说 明 :然后函数只能在调用非阻塞数据传输(TX/RX) API时使用,在TX/RX数据传输完成后(用户可以通过handler的回调函数获得状态),我们可以通过句柄获得邮箱的时间戳的详细索引,详细的非阻塞数据传输API (TX/RX)包含:

 *   -FLEXCAN_TransferSendNonBlocking					//CAN 无堵塞发送
 *   -FLEXCAN_TransferFDSendNonBlocking			//CANFD   无堵塞发送
 *   -FLEXCAN_TransferReceiveNonBlocking			//CAN 无堵塞接收
 *   -FLEXCAN_TransferFDReceiveNonBlocking		//CANFD 无堵塞接收
 *   -FLEXCAN_TransferReceiveFifoNonBlocking		//can fifo 无堵塞接收

参 数 :handle FlexCAN句柄指针
参 数 :mbIdx FlexCAN消息缓冲区索引
返回值:存储在句柄中的邮箱时间戳的索引。

6、获取中断非阻塞接收期间的遗留Rx Fifo传输状态。

函 数 :status_t FLEXCAN_TransferGetReceiveFifoCount(CAN_Type *base, flexcan_handle_t *handle, size_t *count);
说 明 :
参 数 :base FlexCAN外设基地址
参 数 :handle FlexCAN句柄指针
参 数 :count 到目前为止,非阻塞事务接收到的CAN消息数
返回值:kStatus_InvalidArgument 计数无效
返回值:kStatus_Success 成功返回计数

7、使用IRQ从Rx FIFO接收CAN消息

函 数 :status_t FLEXCAN_TransferReceiveFifoNonBlocking(CAN_Type *base, flexcan_handle_t *handle, flexcan_fifo_transfer_t *pFifoXfer);
说 明 :此函数使用IRQ接收消息。这是一个非阻塞函数,它会立即返回。当接收到所有消息时,将调用receive回调函数。
参 数 :base FlexCAN外设基地址
参 数 :handle FlexCAN句柄指针
参 数 :pFifoXfer FlexCAN Rx FIFO传输结构。参见@ref flexcan_fifo_transfer_t。
返回值:kStatus_Success 启动Rx FIFO接收进程成功
返回值:kStatus_FLEXCAN_RxFifoBusy Rx FIFO目前正在使用中

8、使用IRQ接收CAN消息

函 数 :status_t FLEXCAN_TransferReceiveNonBlocking(CAN_Type *base, flexcan_handle_t *handle, flexcan_mb_transfer_t *pMbXfer);
说 明 :此函数使用IRQ接收消息。这是一个非阻塞函数,它会立即返回。当消息被接收时,将调用receive回调函数。
参 数 :base FlexCAN外设基地址
参 数 :handle FlexCAN句柄指针
参 数 :pMbXfer FlexCAN消息缓冲区传输结构。参见#flexcan_mb_transfer_t。
返回值:kStatus_Success 启动消息缓存接收进程成功
返回值:kStatus_FLEXCAN_RxBusy 接收消息的缓存正在使用

9、使用IRQ发送消息

函 数 :status_t FLEXCAN_TransferSendNonBlocking(CAN_Type *base, flexcan_handle_t *handle, flexcan_mb_transfer_t *pMbXfer);
说 明 :这个函数使用IRQ发送消息。这是一个非阻塞函数,它会立即返回。当消息发出后,send回调函数被调用。
参 数 :base FlexCAN外设基地址
参 数 :handle FlexCAN句柄指针
参 数 :pMbXfer FlexCAN消息缓冲区传输结构。参见#flexcan_mb_transfer_t。
返回值:kStatus_Success 启动消息缓存发送进程成功
返回值:kStatus_FLEXCAN_RxBusy 发送消息的缓存正在使用

10、初始化FlexCAN句柄

函 数 :void FLEXCAN_TransferCreateHandle(CAN_Type *base, flexcan_handle_t *handle, flexcan_transfer_callback_t callback, void *userData);
说 明 :这个函数初始化FlexCAN句柄,它可以用于其他FlexCAN事务性api。通常,对于指定的FlexCAN实例,调用此API一次以获得初始化句柄。
参 数 :base FlexCAN外设基地址
参 数 :handle FlexCAN句柄指针
参 数 :callback 回调函数
参 数 :userData 回调函数的参数。
返回值:无

未完,待续……

  • 21
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RT1021-EVK是NXP公司推出的一款基于i.MX RT1021处理器的评估开发板,它支持多种通信接口,包括CAN和UART。CAN是一种面向实时应用的通信协议,而UART是一种异步串行通信协议。下面我们来分析一下如何将CAN通信转换为UART通信,并给出相应的代码示例。 在RT1021-EVK上,CAN通信和UART通信的实现都需要使用相应的外设模块。CAN通信需要使用FlexCAN模块,而UART通信需要使用UART模块。要将CAN通信转换为UART通信,需要通过中断的方式获取CAN数据帧,然后将数据帧转换为UART数据,发送到UART总线上。 下面是CAN转UART的代码示例,仅供参考: ```c #include "fsl_flexcan.h" #include "fsl_uart.h" #define CAN_MSG_BUF_NUM 9U #define CAN_MSG_BUF_SIZE sizeof(flexcan_frame_t) flexcan_handle_t flexcanHandle; flexcan_mb_transfer_t rxXfer; flexcan_frame_t rxFrame; uart_handle_t uartHandle; uint8_t uartTxBuffer[CAN_MSG_BUF_SIZE]; void FLEXCAN_UserRxCallback(CAN_Type *base, flexcan_handle_t *handle, uint32_t mbIdx, void *userData) { UART_SendDataBlocking(UART5, uartTxBuffer, CAN_MSG_BUF_SIZE); } int main(void) { flexcan_config_t flexcanConfig; flexcan_rx_mb_config_t mbConfig; uart_config_t uartConfig; uint32_t i; BOARD_InitPins(); BOARD_BootClockRUN(); BOARD_InitDebugConsole(); /* Configure the FlexCAN module */ FLEXCAN_GetDefaultConfig(&flexcanConfig); flexcanConfig.baudRate = 500000U; FLEXCAN_Init(CAN1, &flexcanConfig, CLOCK_GetFreq(kCLOCK_IpgClk)); /* Configure the FlexCAN RX message buffer */ mbConfig.format = kFLEXCAN_FrameFormatStandard; mbConfig.type = kFLEXCAN_FrameTypeData; mbConfig.id = 0x123U; FLEXCAN_SetRxMbConfig(CAN1, RX_MESSAGE_BUFFER_NUM, &mbConfig, true); /* Create the FlexCAN handle */ FLEXCAN_TransferCreateHandle(CAN1, &flexcanHandle, FLEXCAN_UserRxCallback, NULL); /* Configure the UART module */ UART_GetDefaultConfig(&uartConfig); uartConfig.baudRate_Bps = 115200U; uartConfig.enableTx = true; uartConfig.enableRx = false; UART_Init(UART5, &uartConfig, CLOCK_GetFreq(kCLOCK_IpgClk)); /* Create the UART handle */ UART_TransferCreateHandle(UART5, &uartHandle, NULL, NULL); /* Start the FlexCAN module */ FLEXCAN_Start(CAN1); while (1) { /* Wait for the FlexCAN message */ rxXfer.mbIdx = RX_MESSAGE_BUFFER_NUM; rxXfer.frame = &rxFrame; FLEXCAN_TransferReceiveNonBlocking(CAN1, &flexcanHandle, &rxXfer); /* Convert FlexCAN message to UART message */ for (i = 0; i < CAN_MSG_BUF_SIZE; i++) { uartTxBuffer[i] = ((uint8_t *)&rxFrame)[i]; } /* Send UART message */ UART_TransferSendBlocking(UART5, &uartHandle, uartTxBuffer, CAN_MSG_BUF_SIZE); } } ``` 在这个示例中,我们使用了FlexCAN模块和UART模块,其中FlexCAN用于接收CAN数据帧,UART用于发送UART数据。在主循环中,我们使用FLEXCAN_TransferReceiveNonBlocking函数FlexCAN模块中接收CAN数据帧,并将其转换为UART数据,然后使用UART_TransferSendBlocking函数将UART数据发送到UART总线上。同时,在CAN数据帧接收完成后,我们通过中断的方式调用了FLEXCAN_UserRxCallback函数,在该函数中可以进行一些额外的处理,例如打印日志或修改数据。 需要注意的是,由于CAN和UART是两种不同的通信协议,因此在转换数据时需要进行一些协议转换,例如将CAN数据帧的格式转换为UART数据的格式。此外,由于CAN和UART的数据传输速率有所不同,因此在转换数据时需要考虑数据传输的速率和延迟,以确保数据的正确性和实时性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值