【MCAL】TC397+EB-tresos之CAN配置实战 - (CAN/CANFD)

news2024/12/26 23:39:46

本篇文章介绍了在TC397平台使用EB-tresos对CAN驱动模块进行配置的实战过程,不仅介绍了标准CAN的发送与接收,还介绍了CANFD的实现与调试以及扩展帧的使用。M_CAN是德国博世公司开发的IP,因为英飞凌的芯片完整的集成了这个IP,所以整体的配置都比较符合通用的芯片配置使用规范,如果读者有在其他平台实现CAN通信的经验,应该很容易就能上手本篇文章描述的配置实现过程。

目录

概述

环境与目标 

EB-tresos配置

Port配置

CAN配置 

CanGeneral

CanController

CanControllerBaudrateConfig

CanControllerFdBaudrateConfig(CANFD配置)

CanHardwareObject 

CanHwFilter 

IRQ配置

MCU配置

ResourceM配置 

CAN驱动调试 

标准CAN测试代码与结果

CANFD测试代码与结果

扩展帧测试代码与结果


概述

英飞凌公司AURIX™ TC397芯片内部集成了三路MCMCAN(CAN0,CAN1,CAN2),每路CAN支持4个node,MCMCAN使用了Bosch公司M_CAN的IP,其具有以下的功能特点。

  • 可配置的消息RAM,用于存储要发送或接收的消息。
  • 基于定时器的CAN帧传输和接收CAN帧的超时。
  • 通过中断压缩单元分组和发送中断信号。
  • 通过BPI访问保护。

英飞凌提供的CAN驱动程序负责提供符合AUTOSAR 4.2.2/4.4.0指定标准的CAN通信服务。M_CAN单元是底层CAN硬件单元,它由包含多个共享消息RAM(在AUTOSAR中称为硬件对象)的节点组成(在AUTOSAR中成为控制器)。CAN驱动程序提供服务为:

  • 初始化CAN控制器以控制CAN控制器的行为和状态。
  • 设置和修改CAN控制器的波特率配置。
  • 支持CAN和CANFD帧传输和接收。
  • 支持在轮询和中断模式下,帧成功传输通知以及专用FIFO消息的接收和总线其他事件通知。
  • 数据接收使用接收FIFO作为缓存。
  • Pretended网络模式处理。
  • 支持多次读/写周期功能。
  • 使用Tx队列进行多路传输。

每个CAN节点针对下列事件提供单独的中断线进行处理:

  • Bus-off事件。
  • 发送事件。
  • 专用消息接收事件处理。
  • FIFO0/1的溢出报警以及FIFO全事件处理。
  • 针对发送与接收的混合模式处理。

CAN驱动程序作为Post-Build的变体(未明确定义)来提供使用。因此,驱动程序支持带有预编译和符合Post-Build(构建后)配置结构体的配置参数。CAN驱动程序提供的API是具有防重入等多核特性,这意味着可以同时从多个核心调用使用它们。

下图为CAN驱动涉及的软硬件接口图(HSI):

英飞凌提供的CAN驱动程序使用使用M_CAN并遵守ISO 11898-1进行通信。此外,M_CAN还支持符合CANFD协议规范1.0的通信。驱动程序涉及的硬件特性如下:

  • M_CAN的IP中所有的CAN控制器以及消息RAM硬件资源都被用于实现CAN驱动程序。
  • CANFD最多支持64个字节的数据。
  • 多达64个专用的接收缓冲区。
  • 多达32个专用的发送缓冲区。
  • 两个可配置的接收FIFO。
  • 可配置的发送队列。
  • 每个控制器可以配置四个单独的中断,分别为Rx,Rx FIFOs,Tx,bus-off。

不支持的M_CAN特性如下:

  • 事件同步时间触发通信。
  • CAN错误记录。
  • 消息优先级。

CAN驱动程序使用M_CAN IP核中的以下的硬件事件:

  • CAN /CANFD帧的成功传输由标志(IR寄存器中的相关位)与中断通知。CAN驱动程序使用 FIFO新条目的TxEvent来处理对上层的通知。
  • 成功接收到CAN /CANFD帧将通过标志(IR寄存器中的相关位)和中断通知。CAN驱动程序使用接收中断通知上层。
  • 总线断开事件由标志(IR寄存器中的相关位)和中断通知。CAN驱动程序接收中断通知并通知上层。
  • Rx FIFO0溢出报警、RxFIFOO Full、RxFIFO1溢出报警、RxFIFO1 Full事件都路由到同一个ISR。通过FIFO处理接收到的数据,所有列出的标志都在CAN驱动程序中经过处理。

环境与目标 

本文使用的为英飞凌提供的开发板KIT_A2G_TC397XA_TFT,收发器采用TLE9251V(CAN FDcapable),板卡上选焊的是P10.2与P10.3与TC387相连。

涉及的软件如下。

  • EB-tresos:用于生成动态代码,具体工程搭建参考《【AUTOSAR MCAL】MCAL基础与EB tresos工程新建》。
  • HighTech:用于编译生成elf文件,具体的工程搭建参考《【MCAL】HighTec集成TC3xx对应MCAL的Demo》。
  • UDE 5.2:用于下载和调试程序。

涉及的参考文档如下表。

序号参考资料内容
1《Infineon-AURIX_TC39x-UserManual-v02_00-EN》英飞凌TC39x用户手册
2《ApplicationKitManual-TC3X7-ADAS-V21.pdf》开发板KIT_A2G_TC397XA_TFT说明
3《MC-ISAR_TC3xx_UM_Can_17_McmCan.pdf》英飞凌提供的TC3xx芯片CAN用户手册

 配置目标如下:

  1. 正常收发标准CAN报文。
  2. 正常收发CANFD报文。
  3. 正常收发扩展帧报文。

EB-tresos配置

MCAL的配置主要涉及以下四个部分。

  • Port配置:根据连接的TC397引脚,配置相应的CAN收发引脚复用功能。
  • MCU配置:配置CAN时钟。
  • CAN配置:主要完成CAN控制器相关的所有配置,控制器通用配置,波特率等。
  • IRQ配置:完成中断相关配置。


Port配置

根据刚才提到开发板原理,我们使用了P10.2作为CANRX,P10.3作为CANTX。查找芯片手册,可得CAN发送需要通过RXDE来关联,CAN发送需要配置成ALT6。可以看出我们使用的是node是CAN02。

下图为P10.2的配置。

下图为P10.3的配置。


CAN配置 

CanGeneral

该容器包含与每个CAN驱动单元相关的参数。主要需要关心的配置项如下。

  • CanDevErrorDetection:打开或关闭默认错误跟踪程序 (Det) 检测和通知。
  • CanMultiCoreErrorDetect  :打开或关闭多核默认错误跟踪器 (Det) 检测和通知。
  • CanMainFunctionModePeriod:该参数描述循环调用Can_MainFunction_Mode的周期。单位为秒。轮询调度才有效果,在这里不可以配置,在后面才可以配置。
  • CanTimeoutDuration:指定在检测到超时之前阻塞函数的最大时间。单位为秒。


CanController

这里边重要的配置比较多,对应的是一个CAN控制器的配置。

  • CanBusoffProcessing:Busoff处理用中断还是轮询的选择。
  • CanControllerLoopbackEnable:指定控制器是否启用内部回环模式(发送与接收内部连接,用作测试)。
  • CanRxInputSelection:接收输入线端口引脚选择,根据上面Port配置提到的P10.2对应RXDE。
  • CanControllerBaseAddress:CAN控制器的基址。因为我们使用的是CAN02,则基地址查询手册可知为0xF0208900。

  • CanRxProcessing:接收方式是中断还是轮询。
  • CanTxProcessing:发送方式是中断还是轮询。
  • CanWakeupProcessing:唤醒方式是中断还是轮询。
  • CanControllerDefaultBaudrate:参考为CAN控制器配置的波特率配置的容器。
  • CanPeripheralBusClockRef:参考为CPU外设总线时钟的配置,该配置在 MCU 驱动程序配置中设置。


CanControllerBaudrateConfig

该容器包含CAN控制器的位时序相关配置参数。在介绍相关的参数前我们先介绍以下采样点的概念,如下图所示,采样点是can控制器对can线上电平单bit数据采样的时刻。

  • CanControllerBaudRate :控制器的波特率,单位为Kbps。
  • CanControllerPropSeg:指定以时间量子(最小时间单位)表示的传播延迟,对应上图的Delay。
  • CanControllerSeg1:在时间量子中指定相位段1。
  • CanControllerSeg2:在时间量子中指定相位段2。
  • CanControllerSyncJumpWidth:由于再同步,相位 SEG1 可能会延长或相位 SEG2 可能会缩短。相位缓冲器段的加长或缩短量由再同步跳变宽度(SJW)给出的上限。

网上有很多给出CAN控制输入频率,期待CAN波特率与采样点位置( (1+SEG1) / (1+SEG1+SEG2)),即可以输出对应的参数配置,如下图所示为针对ST芯片的一个计算参数的小工具,也可以根据公式进行手算。

MCAL配置如下图。


CanControllerFdBaudrateConfig(CANFD配置)

这个可选的容器包含CAN控制器CANFD帧可变速率的位时序相关配置参数,用于CANFD帧中控制场中的BRS位到ACK场之前(含CRC分界符)的传输速率。如果该容器存在,则控制器支持CANFD帧。需要关注的配置如下。

  • CanControllerTxBitRateSwitch:配置是否使用第二波特率(CANFD波特率)用于发送,这里我们取消勾选,因为我们需要在支持CANFD消息的网络中传输传统CAN 2.0消息。(例如:便于CAN的选择性唤醒。)在这些情况下,有必要支持CAN-FD消息和传统CAN消息交替传输。这问题可以通过在调用Can_17_McmCan_Write函数的时候,利用CanId参数中没有用到的高位,来使用哪种类型的帧,从而在数据帧的级别上实现交替发送。


CanHardwareObject 

在FullCAN架构(一个Buffer对应一个ID的报文)下,一个HWObject(Hardware Object)只能处理单个CanId,所以我们需要根据应用层接收以及发送报文数量建立相应的CanHardwareObject。

下面我们介绍一下各配置项的含义。

  •  CanHandleType:指定硬件对象的类型(FULL-CAN或BASIC-CAN)。由于FULL CAN特性是最常用的,所以CanHandleType配置参数的默认值设置为FULL。
  • CanHwObjectCount:用于实现一个HOH的硬件对象的数量。如果是HRH,这个参数定义硬件中元素的数量。FIFO或影子缓冲区的数量,在HTH的情况下,它定义了用于多路传输或用于FullCAN HTH的硬件FIFO的硬件对象的数量。
  • CanHwFIFOThreshold:指定触发中断以复制数据的Rx_FIFO缓冲区的阈值大小。
  • CanIdType:指定CanHwFilterCode值是否为标准帧ID(11位),扩展帧ID(29位),还是CANID可以为标准帧或者扩展帧。
  • CanObjectId:保存HRH()或HTH的句柄ID。这个参数的值在给定的CAN驱动程序中是唯一的,它应该从0开始,没有任何间隙。
  • CanObjectType:邮箱类型是接收还是发送。
  • CanControllerRef:HOH所关联的CAN控制器的参考。

我们需要先建立接收报文的HWObject,再建立发送的,下面是实验用到的整体配置。


CanHwFilter 

这个容器只对接收的HWObject(HRH)有效,包含硬件过滤器的配置(接收ID与ID_Mask)。发送的HWObject不需要配置。


IRQ配置

每个CAN节点一组,每组四个节点。

根据下图手册,找到CAN02对应的中断线。

对应的中断为一类中断和服务路由到CPU0(都为默认配置,不需要修改),最终中断配置如下。


MCU配置

配置CAN时钟源频率,需要注意的配置如下。

  • mcumcanclocksourcesselection:用于选择不同的时钟源,MCAN_CLOCK_SOURCE_MCANI_SEL1时钟源为fMCANI,MCAN_CLOCK_SOURCE_OSC_SEL2时钟源为Main oscillator。


ResourceM配置 

配置使用资源,分配核,在Core0中添加CAN,并关联CanController_0。


CAN驱动调试 

标准CAN测试代码与结果

测试代码如下,主要包含一个初始化的过程和以50ms为周期发送报文。

uint8 Buffer_TX0[8];
uint8 Buffer_RX0[8] ;
Can_PduType TestPduInfo[ ] =
{
	{0,8, 0x100, Buffer_RX0 },
	{0,8, 0x510, Buffer_TX0 },
};
 
Can_ReturnType Can_Return = CAN_OK;
 
void Can_DemoFunction(void)
{
    IrqCan_Init();
	SRC_CAN_CAN0_INT0.B.SRE = 1;
	SRC_CAN_CAN0_INT1.B.SRE = 1;
	SRC_CAN_CAN0_INT2.B.SRE = 1;
	SRC_CAN_CAN0_INT3.B.SRE = 1;
	Can_17_McmCan_Init(&Can_17_McmCan_Config);
	Can_17_McmCan_SetControllerMode(Can_17_McmCanConf_CanController_CanController_0, CAN_T_START);
	Can_17_McmCan_EnableControllerInterrupts(Can_17_McmCanConf_CanController_CanController_0);
	uint8 i;
	/*-----------------test the can   ---------------------*/
	for(i = 0; i < 8; i++)
	{
		Buffer_TX0[i]= i;
	}
	TestPduInfo[1].id = 0x666;
    while(1)
    {
	    Can_Return = Can_17_McmCan_Write(Can_17_McmCanConf_CanHardwareObject_CanHardwareObject_StandTx, &TestPduInfo[1]);
        Delay(50);
    }
}

CAN帧ID为0x666的报文被以50ms正常发送。

接收结果测试则发送CANID为0x100,Data为0x11 0x22 0x33 0x00的CAN报文,通过调试器仿真在CanIf接收回调里打断点来查看是否接收成功如下图。


CANFD测试代码与结果

代码如下,与标准帧不同的地方在于数据为64字节,而CANID是或上了0x40000000,例如本例子的0x123就要设置为0x40000123,从而控制发送CANFD帧。

uint8 tx_data_Fd[64] =
{ 0x39, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88, 0x99, 0x11, 0x22, 0x33,
  0x44, 0x55, 0x66, 0x77, 0x88, 0x99, 0x01, 0x02, 0x15, 0x16, 0x17, 0x18, 0x91,
  0x92, 0x93, 0x94, 0x95, 0x96, 0x97, 0x98
};
/* CAN Frame PDU Info for FD */
Can_PduType PduInfo_FD[] =
{
  {2,  32, 0x40000123, tx_data_Fd },
  {2,  32, 0x40000111, tx_data_Fd },
};
 
Can_ReturnType Can_Return = CAN_OK;
 
void Can_DemoFunction(void)
{
    IrqCan_Init();
	SRC_CAN_CAN0_INT0.B.SRE = 1;
	SRC_CAN_CAN0_INT1.B.SRE = 1;
	SRC_CAN_CAN0_INT2.B.SRE = 1;
	SRC_CAN_CAN0_INT3.B.SRE = 1;
	Can_17_McmCan_Init(&Can_17_McmCan_Config);
	Can_17_McmCan_SetControllerMode(Can_17_McmCanConf_CanController_CanController_0, CAN_T_START);
	Can_17_McmCan_EnableControllerInterrupts(Can_17_McmCanConf_CanController_CanController_0);
    while(1)
    {
		Can_Return = Can_17_McmCan_Write(Can_17_McmCanConf_CanHardwareObject_CanHardwareObject_CANFD, &PduInfo_FD[0]);
        Delay(50);
    }
}

测试需要的CANoe设置500k为控制器波特率,5000k为数据域波特率。

测试结果如下图 

扩展帧测试代码与结果

代码如下,注意ID是或上了一个0x80000000,表明发送的为扩展帧。

uint8 tx_data_1[8] = {0x91, 0x92, 0x93, 0x94, 0x95, 0x96, 0x97, 0x98 };
Can_PduType PduInfo_ExtId[] =
{
  {0, 8, 0x9AAAAAAA, tx_data_1},
  {0, 8, 0x81111111, tx_data_1}
};
 
Can_ReturnType Can_Return = CAN_OK;
 
void Can_DemoFunction(void)
{
    IrqCan_Init();
	SRC_CAN_CAN0_INT0.B.SRE = 1;
	SRC_CAN_CAN0_INT1.B.SRE = 1;
	SRC_CAN_CAN0_INT2.B.SRE = 1;
	SRC_CAN_CAN0_INT3.B.SRE = 1;
	Can_17_McmCan_Init(&Can_17_McmCan_Config);
	Can_17_McmCan_SetControllerMode(Can_17_McmCanConf_CanController_CanController_0, CAN_T_START);
	Can_17_McmCan_EnableControllerInterrupts(Can_17_McmCanConf_CanController_CanController_0);
    while(1)
    {
	    Can_Return = Can_17_McmCan_Write(Can_17_McmCanConf_CanHardwareObject_CanHardwareObject_Extern, &PduInfo_ExtId[0]);
        Delay(50);
    }
}

测试结果如下。


十六宿舍 原创作品,转载必须标注原文链接。

©2023 Yang Li. All rights reserved.

欢迎关注 『十六宿舍』,大家喜欢的话,给个👍,更多关于嵌入式相关技术的内容持续更新中。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1484686.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【电路笔记】-RC网络-时间常数

时间常数 文章目录 时间常数1、概述2、RC 电路的时间常数3、示例14、示例25、RC瞬态放电曲线6、示例37、总结Tau τ \tau τ 是 RC 电路在阶跃变化输入条件下从一种稳态条件变为另一种稳态条件所需的时间常数。 1、概述 Tau,符号 τ \tau τ,是电气和电子计算中使用的希腊字…

C++_数据结构_数据的输入

作用 用于从键盘获取数据 关键字 cin >> 变量示例

Jenkins的Pipeline概念

文章目录 Pipeline什么是Jenkins Pipeline声明式和脚本式Pipeline语法为何使用PipelinePipeline概念PipelineNodeStageStep Pipeline语法概述声明式Pipeline脚本式Pipeline Pipeline示例 参考 Pipeline 什么是Jenkins Pipeline Jenkins Pipeline是一套插件&#xff0c;它支持…

YOLOv9有效改进|使用空间和通道重建卷积SCConv改进RepNCSPELAN4

专栏介绍&#xff1a;YOLOv9改进系列 | 包含深度学习最新创新&#xff0c;主力高效涨点&#xff01;&#xff01;&#xff01; 一、改进点介绍 SCConv是一种即插即用的空间和通道重建卷积。 RepNCSPELAN4是YOLOv9中的特征提取模块&#xff0c;类似YOLOv5和v8中的C2f与C3模块。 …

国内chatgpt写作软件,chatgpt国内使用

随着人工智能技术的不断发展&#xff0c;国内涌现出了一些基于ChatGPT模型的写作软件&#xff0c;这些软件不仅能够实现智能化的文章写作&#xff0c;还支持批量生成各种类型的文章。本文将深入探讨国内ChatGPT写作软件&#xff0c;以及它们在批量文章创作方面的应用与优势。 C…

STM32作为SPI slave与主机异步通信

背景 最近被测试提了个BUG&#xff0c;说某款产品在用户按下前面板的按键后&#xff0c;对应的按键灯没有亮起来。前面板跟主机是通过SPI口通信&#xff0c;前面板是从机&#xff0c;从机想要主动发送消息&#xff0c;需要通过GPIO中断来通知主机&#xff1a; 上图前面板是ST…

php源码 单色bmp图片取模工具 按任意方式取模 生成字节数组 自由编辑点阵

http://2.wjsou.com/BMP/index.html 想试试chatGPT4生成&#xff0c;还是要手工改 php 写一个网页界面上可以选择一张bmp图片&#xff0c;界面上就显示这张bmp图片&#xff0c; 点生成取模按钮&#xff0c;在图片下方会显示这张bmp图片的取模数据。 取模规则是按界面设置的&a…

蓝桥ACM培训-搜索

前言&#xff1a; 今老师讲了了dfs,虽然我自己之前也自学了一点点&#xff0c;但我还是感觉做题并不是很顺&#xff0c;尤其是今天最后一题&#xff0c;我调试了一下午都没过&#xff0c;还需要积累经验呀。 正文&#xff1a; Problem:A 白与黑-搜索&#xff1a; #include &l…

DbSchema导出HTML/PDF版表结构

一、连接数据库 登录成功默认显示当前用户的所有资源&#xff08;表、视图、序列、方法、触发器等&#xff09;&#xff0c;如果不操作将导出此用户的全部信息。 至此连接数据库完成 二、表结构导出 本次不想给用户全部导出&#xff0c;只给导出几张&#xff0c;选择需要…

IPO观察丨“闷头做手机”的龙旗科技,如何拓宽价值边界?

提到手机代工&#xff0c;许多人会想起依靠iPhone订单发家的富士康。但近年来&#xff0c;随着国内智能手机供应链愈发成熟&#xff0c;龙旗科技、闻泰科技和华勤技术等一批国产手机代工厂快速崛起&#xff0c;业绩强劲增长之余&#xff0c;还迈进了二级市场。 比如&#xff0…

吴恩达deeplearning.ai:通过偏差与方差进行诊断

以下内容有任何不理解可以翻看我之前的博客哦&#xff1a;吴恩达deeplearning.ai专栏 文章目录 偏差与方差高偏差高方差合适的模型理解偏差与方差 总结 当你构建神经网络的时候&#xff0c;几乎没有人能够在一开始就将神经系统构建得十分完美。因此构建神经网络最重要的是直到…

BUGKU 头等舱

头等舱 打开环境&#xff0c;什么都没有&#xff0c;使用BP抓包&#xff0c;发送到重发器里&#xff0c;看响应得到flag

LeetCode 热题 100 | 图论(二)

目录 1 基础知识 1.1 什么是拓扑排序 1.2 如何进行拓扑排序 1.3 拓扑排序举例 2 207. 课程表 3 210. 课程表 II 菜鸟做题&#xff0c;语言是 C 1 基础知识 1.1 什么是拓扑排序 含义&#xff1a;根据节点之间的依赖关系来生成一个有序的序列。 应用&#xff1a…

详细了解C++中的namespace命名空间

键盘敲烂&#xff0c;月薪过万&#xff0c;同学们&#xff0c;加油呀&#xff01; 目录 键盘敲烂&#xff0c;月薪过万&#xff0c;同学们&#xff0c;加油呀&#xff01; 一、命名空间的理解 二、&#xff1a;&#xff1a;作用域运算符 三、命名空间&#xff08;namespace&…

勒索病毒最新变种.helper勒索病毒来袭,如何恢复受感染的数据?

尊敬的读者&#xff1a; 在数字时代&#xff0c;我们享受着科技带来的便利&#xff0c;但与此同时&#xff0c;网络安全威胁也在不断演变。其中&#xff0c;勒索病毒是一种极具破坏力的威胁&#xff0c;而.helper勒索病毒更是最新的变种之一。当你的文件被.helper勒索病毒加密…

SparkStreaming在实时处理的两个场景示例

简介 Spark Streaming是Apache Spark生态系统中的一个组件&#xff0c;用于实时流式数据处理。它提供了类似于Spark的API&#xff0c;使开发者可以使用相似的编程模型来处理实时数据流。 Spark Streaming的工作原理是将连续的数据流划分成小的批次&#xff0c;并将每个批次作…

redis04 发布与订阅

一种消息通信模式&#xff1a;发布者&#xff08;pub&#xff09;发布消息&#xff0c;订阅者&#xff08;sub&#xff09;接收消 息。 redis客户端可以订阅任意数量的频道。 发布订阅流程图 发布和订阅实现 打开两个窗口订阅channel1频道&#xff0c;再打开一个窗口向chan…

ssh连接github报错:ssh_exchange_identification: Connection closed by remote host

报错截图&#xff1a;ssh_exchange_identification: Connection closed by remote host 配置步骤&#xff1a; 生成新的 SSH 密钥并将其添加到 ssh-agent - GitHub 文档 这个报错是我在寒武纪MLU270的dcoker环境中遇到的&#xff0c;但是在windows系统中可以通过SSH的方式git…

Excel 按奇数偶数列处理数据

目录 一. 需求背景1.1 获取偶数列的数据1.2 奇偶列数据互换 二. 解决方式2.1 为列添加奇偶辅助列2.2 通过公式将奇偶列互换 一. 需求背景 1.1 获取偶数列的数据 ⏹ 最近在整理歌单&#xff0c;发现部分歌曲没有歌词&#xff0c;于是打算自己制作一份。 从网上找到了歌词&…

从下一代车规MCU厘清存储器的发展(1)

目录 1.车规MCU制程工艺朝28nm进发 2.MCU存储器概述 3.MCU大厂的选择 3.1 瑞萨自研STT-MRAM 3.2 ST专注PCM 3.3 英飞凌和台积电联手RRAM 3.4 NXP如何计划eNVM 4.小结 1.车规MCU制程工艺朝28nm进发 随着英飞凌发布了关于AURIX TC4xx系列即将量产的新闻&#xff0c;国际…