S32K144-EVB开发板CAN实例代码

时间: 2023-10-01 14:06:50 浏览: 161
RAR

S32K144-EVB_QSG_REV4.1.1pptx.rar_DEMO_S32K144-EVB_QSG_s32K144

star5星 · 资源好评率100%
以下是S32K144-EVB开发板CAN实例代码: ```c #include "S32K144.h" #include "can.h" #include "clocks_and_modes.h" #include "gpio.h" #include "interrupt_manager.h" #define CAN0_TX_PIN 27U #define CAN0_RX_PIN 26U #define CAN0_TX_MUX 2U #define CAN0_RX_MUX 2U #define CAN0_RX_MSG_BUF_NUM (4U) #define CAN0_BASE_ADDR (0x40024000U) #define CAN0_RX_FIFO_ID (0x100U) #define CAN0_RX_FIFO_NUM (8U) static uint8_t can0RxMsgBuf[CAN0_RX_MSG_BUF_NUM][CAN_MESSAGE_BUFFER_MAX_PAYLOAD_SIZE]; void Can0_RxIsr(void); void InitCan0(void) { /* Enable clock for PORTA */ PCC->PCCn[PCC_PORTA_INDEX] |= PCC_PCCn_CGC_MASK; /* Configure CAN0_TX_PIN and CAN0_RX_PIN as alternative function (Alt2) */ PORTA->PCR[CAN0_TX_PIN] = PORT_PCR_MUX(CAN0_TX_MUX); PORTA->PCR[CAN0_RX_PIN] = PORT_PCR_MUX(CAN0_RX_MUX); /* Set the bit rate to 500 kbps with a 8 MHz clock */ const uint32_t can0ClkFreq = 8000000U; const uint32_t baudRate = 500000U; const uint32_t prescaler = (can0ClkFreq / (baudRate * 20U)) - 1U; CAN0->CTRL1 &= ~CAN_CTRL1_CLKSRC_MASK; CAN0->CTRL1 |= CAN_CTRL1_CLKSRC(1U); CAN0->CTRL1 |= CAN_CTRL1_PRESDIV(prescaler); /* Enable CAN0 */ PCC->PCCn[PCC_FlexCAN0_INDEX] |= PCC_PCCn_CGC_MASK; /* Enable individual RX FIFO filters */ CAN0->MCR |= CAN_MCR_IRMQ_MASK; /* Enable RX FIFO */ CAN0->MCR |= CAN_MCR_RFEN_MASK; /* Configure RX FIFO ID filter */ CAN0->RXFIFO.IDTABLE[0] = 0x80000000U; CAN0->RXFIFO.IDTABLE[1] = 0x80000000U; /* Configure RX FIFO filter element */ CAN0->RXIMR[CAN0_RX_FIFO_NUM] = 0xFFFFFFFFU; CAN0->RXMGMASK = 0x80000000U; CAN0->RXFGMASK = 0x80000000U; /* Enable RX FIFO interrupt */ CAN0->IMASK1 |= CAN_IMASK1_BUF5M_MASK; /* Configure RX message buffers */ for (uint32_t msgBufIdx = 0U; msgBufIdx < CAN0_RX_MSG_BUF_NUM; msgBufIdx++) { /* Configure RX message buffer filter */ CAN0->RAMn[msgBufIdx].ID = (CAN_RAMn_ID_STD(0x7FFU) | CAN_RAMn_IDE_MASK); /* Configure RX message buffer payload size */ CAN0->RAMn[msgBufIdx].CS = CAN_CS_DLC(CAN_MESSAGE_BUFFER_MAX_PAYLOAD_SIZE); /* Configure RX message buffer for reception */ CAN0->RAMn[msgBufIdx].CS |= CAN_CS_CODE(CAN_CS_CODE_RX_INACTIVE); } /* Configure NVIC for RX FIFO interrupt */ const IRQn_Type can0RxIrqId = IRQ_CAN0_ORed_Message_buffer; INT_SYS_EnableIRQ(can0RxIrqId); INT_SYS_SetPriority(can0RxIrqId, 3U); } void Can0_RxIsr(void) { uint32_t msgBufIdx = 0U; /* Read RX FIFO and dispatch messages */ while (CAN0->IFLAG1 & CAN_IFLAG1_BUF5I_MASK) { /* Clear RX FIFO interrupt flag */ CAN0->IFLAG1 |= CAN_IFLAG1_BUF5I_MASK; /* Read RX FIFO element */ const uint32_t fifoElemIdx = 0U; const uint32_t fifoElemAddr = (CAN0_BASE_ADDR + 0x00000C00U + (fifoElemIdx * 0x10U)); uint32_t fifoElemData[4] = {0U}; for (uint32_t i = 0U; i < 4U; i++) { fifoElemData[i] = (*(volatile uint32_t *)(fifoElemAddr + (i * 4U))); } /* Process RX FIFO element */ if ((fifoElemData[0] & CAN_RAMn_IDE_MASK) == CAN_RAMn_IDE_MASK) { /* Extended ID */ const uint32_t rxMsgId = (fifoElemData[0] & CAN_RAMn_ID_MASK_EXT); const uint8_t rxMsgDlc = (fifoElemData[1] & CAN_RAMn_CS_DLC_MASK); uint8_t rxMsgPayload[CAN_MESSAGE_BUFFER_MAX_PAYLOAD_SIZE] = {0U}; for (uint32_t i = 0U; i < (rxMsgDlc >> 2U); i++) { ((uint32_t *)rxMsgPayload)[i] = fifoElemData[i + 2U]; } /* Find free RX message buffer and configure it for reception */ for (msgBufIdx = 0U; msgBufIdx < CAN0_RX_MSG_BUF_NUM; msgBufIdx++) { if ((CAN0->RAMn[msgBufIdx].CS & CAN_CS_CODE_MASK) == CAN_CS_CODE_RX_INACTIVE) { break; } } if (msgBufIdx < CAN0_RX_MSG_BUF_NUM) { /* Configure RX message buffer filter */ CAN0->RAMn[msgBufIdx].ID = (CAN_RAMn_ID_EXT(rxMsgId) | CAN_RAMn_IDE_MASK); /* Configure RX message buffer payload size */ CAN0->RAMn[msgBufIdx].CS = CAN_CS_DLC(rxMsgDlc); /* Configure RX message buffer for reception */ CAN0->RAMn[msgBufIdx].CS |= CAN_CS_CODE(CAN_CS_CODE_RX_FULL); /* Copy RX message payload */ for (uint32_t i = 0U; i < CAN_MESSAGE_BUFFER_MAX_PAYLOAD_SIZE; i++) { can0RxMsgBuf[msgBufIdx][i] = rxMsgPayload[i]; } } else { /* RX message buffer not available */ } } else { /* Standard ID */ } } } void SendCan0Msg(const uint32_t msgId, const uint8_t * const msgPayload, const uint32_t msgPayloadSize) { /* Find free TX message buffer and configure it for transmission */ uint32_t txMsgBufIdx = 0U; for (txMsgBufIdx = 0U; txMsgBufIdx < CAN0_TX_MSG_BUF_NUM; txMsgBufIdx++) { if ((CAN0->RAMn[txMsgBufIdx].CS & CAN_CS_CODE_MASK) == CAN_CS_CODE_TX_INACTIVE) { break; } } if (txMsgBufIdx < CAN0_TX_MSG_BUF_NUM) { /* Configure TX message buffer ID */ CAN0->RAMn[txMsgBufIdx].ID = (CAN_RAMn_ID_STD(msgId) | CAN_RAMn_IDE_MASK); /* Configure TX message buffer payload size */ CAN0->RAMn[txMsgBufIdx].CS = CAN_CS_DLC(msgPayloadSize); /* Copy TX message payload */ for (uint32_t i = 0U; i < msgPayloadSize; i++) { can0TxMsgBuf[txMsgBufIdx][i] = msgPayload[i]; } /* Configure TX message buffer for transmission */ CAN0->RAMn[txMsgBufIdx].CS |= CAN_CS_CODE(CAN_CS_CODE_TX_INACTIVE); } else { /* TX message buffer not available */ } } int main(void) { /* Init board hardware */ InitClocksAndModes(); InitGpio(); InitCan0(); /* Send CAN message */ const uint32_t msgId = 0x123U; const uint8_t msgPayload[] = {0x11U, 0x22U, 0x33U}; const uint32_t msgPayloadSize = sizeof(msgPayload); SendCan0Msg(msgId, msgPayload, msgPayloadSize); /* Main loop */ while (1U) { /* Do nothing */ } } ``` 这个例程中,我们使用了S32K144-EVB开发板上的CAN0模块,并且配置了一个接收FIFO和四个接收消息缓冲区。在初始化过程中,我们设置了CAN0的波特率为500 kbps,并且启用了CAN0模块和RX FIFO中断。在主函数中,我们发送了一个CAN消息,并且在接收中断处理函数Can0_RxIsr中读取并处理了接收到的CAN消息。
阅读全文

相关推荐

最新推荐

recommend-type

S32K144 SPI速率

在本案例中,我们关注的是NXP的S32K144单片机如何实现SPI通信速率的调试与优化。S32K144是一款高性能、低功耗的微控制器,具有丰富的外设接口,包括SPI。 首先,SPI速率的调整主要依赖于系统时钟和SPI模块的分频...
recommend-type

S32K148 CAN波特率和采样点计算

S32K148是一款由NXP半导体公司生产的微控制器,其内建了CAN接口,因此理解和正确计算CAN波特率和采样点对于使用该芯片进行CAN通信至关重要。 首先,我们来详细解析CAN Bit Time的计算公式: 1. CAN波特率计算: ...
recommend-type

S32K144的LPSPI使用配置详解

本文将详细讲解如何在NXP的S32K144微控制器上配置和使用LPSPI(Low Pin Count Serial Peripheral Interface)。LPSPI是一种低引脚数的串行外设接口,它与传统的SPI(Serial Peripheral Interface)相似,但通常提供...
recommend-type

关于S32K系列驱动之----SPI(SDK)开发分享.docx

在本文档中,我们将深入探讨S32K系列微控制器(MCU)的SPI(Serial Peripheral Interface)驱动开发,特别是基于SDK144/6芯片的DEMO版本。SPI是一种同步串行通信协议,广泛应用于各种外设的连接,如传感器、存储器等...
recommend-type

FTP上传下载工具,支持上传下载文件夹、支持进度更新.7z

FTP上传下载工具,支持上传下载文件夹、支持进度更新.7z
recommend-type

创建个性化的Discord聊天机器人教程

资源摘要信息:"discord_bot:用discord.py制作的Discord聊天机器人" Discord是一个基于文本、语音和视频的交流平台,广泛用于社区、团队和游戏玩家之间的通信。Discord的API允许开发者创建第三方应用程序,如聊天机器人(bot),来增强平台的功能和用户体验。在本资源中,我们将探讨如何使用Python库discord.py来创建一个Discord聊天机器人。 1. 使用discord.py创建机器人: discord.py是一个流行的Python库,用于编写Discord机器人。这个库提供了一系列的接口,允许开发者创建可以响应消息、管理服务器、与用户交互等功能的机器人。使用pip命令安装discord.py库,开发者可以开始创建和自定义他们的机器人。 2. discord.py新旧版本问题: 开发者在创建机器人时应确保他们使用的是与Discord API兼容的discord.py版本。本资源提到的机器人是基于discord.py的新版本,如果开发者有使用旧版本的需求,资源描述中指出需要查看相应的文档或指南。 3. 命令清单: 机器人通常会响应一系列命令,以提供特定的服务或功能。资源中提到了一些默认前缀“努宗”的命令,例如:help命令用于显示所有公开命令的列表;:epvpis 或 :epvp命令用于进行某种搜索。 4. 自定义和自托管机器人: 本资源提到的机器人是自托管的,并且设计为高度可定制。这意味着开发者可以完全控制机器人的运行环境、扩展其功能,并将其部署在他们选择的服务器上。 5. 关键词标签: 文档的标签包括"docker", "cog", "discord-bot", "discord-py", 和 "python-bot"。这些标签指示了与本资源相关的技术领域和工具。例如,Docker可用于容器化应用程序,使得机器人可以在任何支持Docker的操作系统上运行,从而提高开发、测试和部署的一致性。标签"python-bot"强调了使用Python语言创建Discord机器人的重要性,而"cog"可能是指在某些机器人框架中用作模块化的代码单元。 6. 文件名称列表: 资源中的"discord_bot-master"表明这是从一个源代码仓库获取的,可能是GitHub上公开的项目。"master"通常是指项目的主分支或主要版本。 总结: 通过本资源,开发者可以学习到如何利用Python和discord.py库来创建功能丰富的Discord聊天机器人。资源涵盖了安装库、创建命令响应、自托管机器人、以及如何根据新旧版本API进行适配等内容。这不仅对初学者入门,对有经验的开发者进一步学习和提升技能也是有价值的。通过理解这些知识点,开发者可以构建出适合他们需要的自定义机器人,进而为Discord社区提供附加价值。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【Eclipse软件终极指南】:油藏数值模拟新手到专家的必经之路

![【Eclipse软件终极指南】:油藏数值模拟新手到专家的必经之路](https://ucc.alicdn.com/pic/developer-ecology/ajpxbl4ljzs5k_9cbe41a1e6e34e6a87c7f49567bdef32.jpeg?x-oss-process=image/resize,s_500,m_lfit) 参考资源链接:[油藏数值模拟基础:ECLIPSE软件详解](https://wenku.csdn.net/doc/2v49ka4j2q?spm=1055.2635.3001.10343) # 1. Eclipse软件概述及应用领域 ## 1.1 软
recommend-type

mvn 命令打包时 指定jdk 的版本、和环境变量

当使用`mvn`命令打包时,有时确实需要指定特定版本的Java Development Kit (JDK) 或设置环境变量,特别是当你的项目依赖于某个特定版本或者你需要在不同的JDK环境下进行构建。以下是两个关键的部分: 1. **指定JDK版本**: 如果你想强制`mvn`使用特定的JDK版本,可以在`.mvn/wrapper/maven-wrapper.properties`文件中添加`maven.jdk.home`属性,然后更新其值指向你想要使用的JDK安装路径。例如: ``` maven.jdk.home=/path/to/jdk-version ```
recommend-type

RequireJS实现单页应用延迟加载模块示例教程

资源摘要信息:"example-onepage-lazy-load是一个基于RequireJS的单页或多页应用程序示例项目,该项目展示了如何实现模块的延迟加载。延迟加载是一种编程技术,旨在在需要时才加载应用程序的某些部分,从而提高应用程序的初始加载速度和性能。RequireJS是一个JavaScript文件和模块加载器,它能够管理JavaScript文件的依赖关系,并且通过异步加载模块,可以进一步优化页面加载性能。 在这个示例项目中,开发者可以了解到如何使用RequireJS来实现模块的懒加载。这涉及到了几个关键点: 1. 将应用程序分为多个模块,这些模块在不立即需要时不会被加载。 2. 使用RequireJS的配置来定义模块之间的依赖关系,以及如何异步加载这些依赖。 3. 通过合并JavaScript文件,减少页面请求的数量,这有助于降低服务器负载并减少延迟。 4. 利用RequireJS的优化器(r.js)来拆分构建目标,生成更小的文件,这有助于加速应用的启动时间。 RequireJS的工作原理基于模块化编程的概念,它允许开发者将JavaScript代码拆分成逻辑块,每一个块都包含特定的功能。这些模块可以被定义为依赖其他模块,RequireJS则负责按照正确的顺序加载这些模块。它提供了一个全局的`require()`函数,开发者可以通过这个函数来声明他们的代码依赖和加载其他模块。 这个示例项目也强调了模块化和代码组织的重要性。项目的布局设计得非常简单明了,通常包含以下几个部分: - `build`目录:存放RequireJS优化器的配置文件(如option.js),用于指定如何打包和优化模块。 - `www`目录:包含所有静态资源,比如HTML页面、样式表和图片等。这个目录的结构旨在让静态资源独立于应用逻辑,便于部署和维护。 在项目中使用RequireJS可以带来几个显著的好处: - 模块化能够改善代码的组织和维护性。 - 异步加载可以减少页面加载时间,提升用户体验。 - 通过合并和压缩文件,可以减少HTTP请求的数量,加快页面渲染速度。 关于`r.js`,它是RequireJS项目中的一个命令行工具,用于自动化模块的打包和优化过程。它能够读取RequireJS的配置文件,自动处理依赖关系,合并模块,并输出优化后的文件。这对于生产环境中的代码部署尤其有用,因为它能够将多个JavaScript文件压缩成一个或几个较小的文件,从而减少网络传输的负担。 总结来说,这个示例项目演示了如何使用RequireJS来实现延迟加载和模块化,这对于优化现代Web应用的性能和管理大型代码库至关重要。开发者可以借鉴这个项目来提高自己的JavaScript应用性能,以及更好地理解和应用RequireJS的特性和最佳实践。"