资讯详情

关于S32K汽车通用MCU,NXP工程师总结的10个超实用Tips

S32K144是NXP推出的基于ARM Cortex-M4F汽车级内核通用MCU系列S32K1xx第一台高性能单片机。本文首先简要介绍S32K系列MCU电影中的核心和资源信息,然后列出S32K软件开发和硬件设计FAQ,供您参考。

”S32K系列MCU概览

S32K1xx是S32K系列MCU第一代产品,其中S32K11x系列核心是ARM Cortext M0 ,它是2014年8月前量产的KEA系列MCU与升级产品相比KEA,其CAN的IP从之前的MSCAN升级到FlexCAN,并且支持BOSCH最新的CAN-FD,大大提高了CAN总线通信带宽的另一个特点是增加了通道eDMA,可以完成外设和内存之间的数据移动,减少CPU负担增加了MCU此外,存储管理增加了系统处理能力MPU——存储器保护单元和RAM和Flash可支持最大24KB和256KB。

S32K14x系列核心是ARM Cortex-M4F,带DSP指令集和单精度浮点处理单元(FPU), 最高频率可以运行到112MHz,其计算性能大大提高,能够提供相对于150MHz的PowerPC e200z内核的计算能力,其CAN最多支持3个FlexCAN,且全部支持CAN-FD(S32K148),RAM和Flash256也是最大的支持KB (RAM) 和2MB (Flash),管脚包装支持LQFP-64至最多LQFP-176,外设ADC有两个独立的12-bit精度SAR型ADC模块(每个模块有16个通道,共32个通道),支持FlexIO以及硬件加密模块CSEc,以及更丰富的定时器timer模块、S32K148还扩展了以太网(ENET)、QSPI(支持外扩NOR Flash,支持线性地址映射,本地代码执行),ETM Trace(高级调试跟踪功能)和串行音频接口(SAI)支持极大地丰富了外设接口和功能可扩展性。

S32K1xx系列MCU支持功能安全ISO-26262 ASIL-B等级,NXP提供安全手册(Safety Manual)和FMEDA以及安全支持,帮助客户实现未来汽车电子产品的功能安全要求。

此外,S32K1xx系列MCU提供免费的软件开发集成环境——S32DS for ARM,以及集成Processor Expert图像配置外设底层驱动(LLD)软件开发套件(SDK),用户可以快速熟悉使用本系列MCU,并快速完成产品原型验证,大大缩短了产品开发周期,满足了汽车电子产品快速发展的市场需求。

1

S32K1xx系列MCU内核及外设资源

2

S32K11x与S32K14x系列MCU对比

3

S32K1xx与KEA MCU引脚兼容性

S32K1xx系列MCU与KEA该系列之间的引脚兼容性如下表所示,可以实现相同的引脚包装pin-to-pin当后期需要增加功能和扩大存储器时,可以实现无缝升级。S32K1xx系列和下一代S32K2xx该系列还将扩大引脚pin-to-pin兼容。

4

S32K1xx的part number命名规则

Tips

从part number的X位有对芯片工作最大频率的限制,如果该字母为M或者H的S32K14x part,这意味着它不能运行112MHz的HSRUM模式。

S32K14x系列MCU有RUN、HSRU和VLPR三种操作模式和STOP1/2与VLPS等三种低功耗模式,其相互转换状态机如下图所示:

时钟源、系统/核心时钟、总线时钟和Flash时钟频率限制如下:

  • HSRUN只需要80多个内核频率MHz使用前,低于等于80MHz是推荐使用RUN运行模式。

  • S32K14x系列MCU的内核Cortex-M4F要跑到112MHz必须将其配置为高速运行模式(HSRUN),环境温度不大于105°,在这种模式下不允许正确Flash擦除和编程操作。

  • VLPR——Very Low Power RUN模式限制系统/内核频率和总线频率为4MHz,而Flash时钟为1MHz,其目的是在低功耗模式下长期工作,减少(周期性)唤醒时的功耗,从而进一步降低系统功能;该模式下不允许Flash擦除和编程操作。

S32K1xx系列MCU的ADC我们以前使用的模块和模块S12系列MCU的ADC模块有所差异,如果单独使用ADC模块只能通过单通道软件触发采样,都是通过ADC状态和控制寄存器SC1A,配置ADCH选择具体的单次采用通道,其采用结果也从ADC数据结果寄存器RA读取:

要实现多个通道的单次触发,需要配合相应的通道PDB模块只能通过硬件触发来实现:

S32K1xx具有补偿功能的高精度(0误差.12 ppm ~3906 ppm)的RTC——与以往不同的是,实时时钟模块S08/S12(X)以及KEA的RTI模块,它可以支持外部32.768KHz有源晶振输入或内部IRC (eg.128KHz LPO) 分频得到的1KHz LPO1K_CLK参考时钟作为参考时钟;其中外部32.768KHz有源晶振输入可以提供足够的精度保证。

Tips

  • S32K1xx的RTC只支持外部有源32.768KHz晶振输入不能支持无源32.768KHz晶振输入作为参考时钟。

  • 在最低功耗模式下VLPS不能正常工作(在OFF状态),这意味着功耗低于1mA时Tips,S32K1xx的RTC不能继续提供实时时钟。

支持软件开发工具SDK使用

1

支持软件开发集成环境

  • S32DS for ARM v1.3/v2.0(http://www.nxp.com/s32ds)

  • 推荐V 5.20以上版本,通过Software Packs以正确的方式实现S32K系列MCU的支持: Keil Microcontroller Development Kit (MDK)(http://www2.keil.com/mdk5)

  • 推荐v 7.8以上版本(IAR Embedded Workbench for ARM)

Tips

  1. S32DS NXP针对其最新32位汽车MCU基于软件开发的集成环境eclipse架构和GNU工具链(gcc以及编译器和链接器gdp调试软件)免费工具,其他可通过上述官方网站链接下载,通过个人电子邮件账户登录下载获取安装激活码;关于S32DS的使用,请关注我的微信微信官方账号车电子expert阅读S32DS使用tips系列文章。

  2. 对于Keil的MDK,请下载5.通过安装20以上的版本Software Packs实现对S32K系列MCU正常,安装S32K的pack之后,可以获得S32K系列MCU启动文件,Flash算法文件、默认链接文件(分散加载文件)和SDK(RTM1.0版本)。

  3. IAR是S32K系列MCU的AutoSARS MCAL如果用户想使用默认支持的编译工具,S32K系列MCU的AutoSARS MCAL建议安装和使用应用程序IAR Embedded Workbench for ARM。

2

支持软件下载和调试器

nbsp;    PEmicro: U-Multilink/ U-Multilink[FX]

       Segger: J-Link V9.4及以上版本 + 软件J-Link V6.00d以上

 

       PEmicro: Cyclone MAX/Cyclone universal / Cyclone universal [FX]

 

Tips

 

  • 推荐客户使用低成本的J-Link调试器开发和调试S32K系列MCU,但一定切记,淘宝网购买J-Link时,买v9.4以上版本的J-Link,并安装使用最新的J-Link上位机软件(建议至少v6.00d以上版本)。如果使用J-Link v9及之前版本的J-Link(比如v7和v8),则无法识别S32K系列MCU,也不能在其上位机软件中找到S32K的算法文件;其J-Link硬件也不能通过更新固件的方式升级到V9.4以上版本。

     

  • 推荐客户使用专业的Flash编程量产工具Cyclone MAX/Cyclone universal / Cyclone universal [FX]作为产线批量编程,以避免编程过程对S32K造成EOS损伤。

 

3

SDK介绍及使用

 

S32K系列MCU提供的SDK——Software Development Kit是基于ARM的CMSIS (Cortex-M Microcontroller Software Interface Standard) 标准开发的,并可以通过Processor Expert图像化配置生成S32K系列MCU的内核外设底层驱动程序、启动文件和链接文件,其中还集成了LIN协议栈和FreeRTOS实时操作系统,方便用户快速上手,用户只需少量的精力和学习就可以完成外设底层驱动开发。

 

 

 

SDK除了支持S32DS之外,还支持S32K的其他第三方软件开发工具,比如Keil的MDK和IAR或者Greenhill的MULTI IDE。

      

(SDK的软件虽然经过了相应的测试,并提供相应的测试报告和结果,但其具有免责协议,用户使用到实际的产品中时,还是需要做产品整体软件质量测试,才能保证产品的可靠性和稳定性)

      

Tips

 

 

需要在初始化ADC模块之后,调用ADC摸采集外部信号之前调用SDK中提供的自动校准函数:

void ADC_DRV_AutoCalibration(const uint32_t instance)

 

  1. 不同的SDK版本之间可能存在差异,S32K144推荐使用SDK RTM 1.0版本,S32K142和S32K148等part只有SDK V0.8.4(S32DS for ARM v2.0 IDE安装包中自带的SDK)及以上版本才可以支持,具体每个SDK版本之间的差异和相对于上一版本的bug 修复,请参考其安装目录下的ReleaseNotes.pdf

     

     

  2. SDK集成了几乎所有外设底层驱动的demo工程用户可以通过S32DS新建工程的菜单栏File-->Create S32DS Project from Example导出到用户worksapce下参考学习。

     

     

  3. 为了获得datasheet规范的ADC总不可调整(校准)误差——TUE = ±4LSB(Typical):

     

     

     

  4. S32K1xx的低功耗和工作运行模式切换通过调用SDK的Power_manager模块的POWER_SYS_SetMode()完成。

     

 

 

 

 

硬件设计注意事项

 

1

电源和复位电路设计

 

S32K系列MCU的系统电源管脚,每一个电源pin都需要加一个0.1uF的解耦合(decouple)电容,并且在PCB Layout时尽量靠近MCU电源管脚放置,以保证其内部电源能够稳定工作。

 

 

 

S32K1xx系列MCU的外部复位管脚为低有效,其内部为开漏和若上拉,所以在设计其外部电路时,建议加一个4.7/10KΩ的上拉电阻为VDD且并联一个0.1uF的滤波电容以滤除偶发性的外部干扰,增强系统的抗干扰能力。

 

Tips

 

  • S32K1xx系列MCU的RESET管脚可以通过配置Flash选项寄存器(FTFE-FOPT,位于地址0x40D的Flash字节)控制其复位后默认的功能是复位管脚还是其他功能(PTA5H或者TCLK1)。

     

  • 若RESET_PIN_CFG = 0,则下次POR复位之后,RESET管脚的复位功能将被关闭,只能通过整片擦除(mass erase)并设置MDM-AP寄存器产生系统复位从而恢复。

 

 

 

 

 

2

晶振和时钟电路设计

 

S32K14x系列MCU支持4~40MHz的外部无源晶振或者50MHz以内的有源晶振作为系统PLL的参考时钟源:

 

 

其中,使用外部无源晶振时,典型的电路连接如下图:

 

Tips

 

  1. 需要根据选择的晶振,匹配相应的负载电容Cx和Cy(一般为若干pF)。

     

  2. 为了提高晶振电路的抗干扰能力,建议在时钟信号周围大面积铺地(也称作包地技术),在其附近不走高速数字信号以目标交叉干扰,并尽量靠近MCU时钟信号管脚放置晶振电路,越近越好。

 

 

 

3

调试接口电路设计

 

S32K14系列MCU支持SWD和JTAG两种调试协议,而S32K11x系列MCU只支持SWD协议,所以为了兼容两种调试接口,推荐使用10-pin如下接口:

 

 

 

相应的信号线外部上拉和下拉电阻(通常为10KΩ)连接如下:

 

 

 

Tips

 

  • 虽然MCU管脚内部有相应的内部上拉和下拉电阻,为了可靠还是强烈推荐用户在设计调试接口电路时加上外部的上拉和下拉电阻。

 

  • 调试接口的信号走线尽量避免过长或过孔(因为调试时时钟信号最高可达25MHz),并进入靠近MCU放置,并远离ECU外壳对外接口的裸露空间区域,以提高EMC特性。

 

4

其他硬件电路设计及EMC考虑

 

在设计S32K系列MCU的ADC外部电路时,需要串联一个限流电阻RL,并设计一个RC滤波电路,其电容和电阻值的选取需要保证信号最大幅度变化时内部的设置的采样时间内内部采样电容能够完全反映外部信号的变化:

 

其内部等效电路及参数如下:

 

Tips

 

更多S32K系列MCU的硬件设计指南请参考应用笔记:AN5426, Hardware Design Guidelines for S32K1xx Microcontrollers (REV 1)

 

 

参考文档

 

  • S32K14x Series Reference Manual (REV 4);

  • S32K1xx Data Sheet (REV 4)

  • AN5425, Power Management for S32K14x (REV 0)

  • AN5426, Hardware Design Guidelines for S32K1xx Microcontrollers (REV 1)

  • S32K144_0N57U Errata (REV 2)

  • S32K144_0N47T Errata (REV 1)

  • S32K14x Series Safety Manual (REV 3)

 

Tips

 

更多最新的文档和应用笔记请关注官网更新:http://www.nxp.com/s32k

 

 

总结

 

S32K1xx系列MCU的第一颗LQFP-64及LQFP-100封装的S32K144(Cortex M4F内核、64KB SRAM、512KB Flash,集成3路FlexCAN (其中FlexCAN0支持CAN-FD、3路SPI和2个独立SAR 12-bit精度ADC)的part已经于今年6月份正式量产,目前已经有很多客户在评估和使用S32K144,后续S32K148、S32K142以及S32K11x都会陆续量产。

 

本文中介绍的S32K1xx系列MCU的功能介绍和SW/HW开发常见问题和设计使用Tips,希望能够帮助正在使用或者即将选择S32K的工程师加快产品开发和MCU选型速度。

 

标签: kit电容器套件

锐单商城拥有海量元器件数据手册IC替代型号,打造 电子元器件IC百科大全!

 锐单商城 - 一站式电子元器件采购平台  

 深圳锐单电子有限公司