关于S32K汽车通用MCU,NXP工程师总结的10个超实用Tips_s32k1 开漏-程序员宅基地

技术标签: 硬件  NXP  

“ 

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总线的通信带宽,另一个特点是增加了4个通道的eDMA,可以完成外设与内存之间的数据搬移,减轻CPU负担,提高了MCU的系统处理能力,此外存储器管理增加了MPU——存储器保护单元,并且RAM和Flash可以支持到最大24KB和256KB。

 

S32K14x系列的内核是ARM Cortex-M4F,带DSP指令集和单精度浮点数处理单元(FPU), 且最高频率可运行到112MHz,其计算性能大大提高,能够提供相对于150MHz的PowerPC e200z4内核的计算能力,其CAN最多支持3个FlexCAN,且全部支持CAN-FD(S32K148),RAM和Flash也最大支持到256KB (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模式。

 

 

a)关于运行模式和内核速度

 

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

 

 

 

各种模式下可用的时钟源、系统/内核时钟、总线时钟和Flash时钟频率限制如下:

 

 

注意:

  • HSRUN模式只有需要内核频率大于80MHz时才使用,低于等于80MHz是推荐使用RUN运行模式。

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

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

     

 

b)S32K1xx系列MCU的ADC模块使用

 

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

 

 

要想实现单次触发多个通道采用则需要配合相应的PDB模块通过硬件触发的方式才能实现:

 

 

c)关于片内集成的RTC模块

 

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

支持的软件开发集成环境

 

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

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

  • IAR System:推荐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

支持的软件下载和调试器

  

  • 调试器(debugger):

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

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

 

  • 编程器(programmer):

       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)

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/king110108/article/details/94215291

智能推荐

python中文显示不出来_解决Python词云库wordcloud不显示中文的问题-程序员宅基地

文章浏览阅读2.6k次。解决Python词云库wordcloud不显示中文的问题2018-11-25背景:wordcloud是基于Python开发的词云生成库,功能强大使用简单。github地址:https://github.com/amueller/word_cloudwordcloud默认是不支持显示中文的,中文会被显示成方框。安装:安装命令:pip install wordcloud解决:经过测试发现不支持显示中文..._词云python代码无法输出文字

台式计算机cpu允许温度,玩游戏cpu温度多少正常(台式电脑夏季CPU一般温度多少)...-程序员宅基地

文章浏览阅读1.1w次。随着炎热夏季的到来,当玩游戏正爽的时候,电脑突然死机了,自动关机了,是不是有想给主机一脚的冲动呢?这个很大的原因是因为CPU温度过高导致的。很多新手玩家可能都有一个疑虑,cpu温度多少以下正常?有些说是60,有些说是70,到底多高CPU温度不会死机呢?首先我们先看看如何查看CPU的温度。下载鲁大师并安装,运行鲁大师软件,即可进入软件界面,并点击温度管理,即可看到电脑各个硬件的温度。鲁大师一般情况下..._台式机玩游戏温度多少正常

小白自学Python日记 Day2-打印打印打印!_puthon打印任务收获-程序员宅基地

文章浏览阅读243次。Day2-打印打印打印!我终于更新了!(哭腔)一、 最简单的打印最最简单的打印语句: print(“打印内容”)注意:python是全英的,符号记得是半角下面是我写的例子:然后进入power shell ,注意:你需要使用cd来进入你保存的例子的文件夹,保存时名字应该取为xxx.py我终于知道为什么文件夹取名都建议取英文了,因为进入的时候是真的很麻烦!如果你没有进入正确的文件夹..._puthon打印任务收获

Docker安装:Errors during downloading metadata for repository ‘appstream‘:_"cenerrors during download metadata for repository-程序员宅基地

文章浏览阅读1k次。centos8问题参考CentOS 8 EOL如何切换源? - 云服务器 ECS - 阿里云_"cenerrors during download metadata for repository \"appstream"

尚硅谷_谷粒学苑-微服务+全栈在线教育实战项目之旅_基于微服务的在线教育平台尚硅谷-程序员宅基地

文章浏览阅读2.7k次,点赞3次,收藏11次。SpringBoot+Maven+MabatisPlusmaven在新建springboot项目引入RELEASE版本出错maven在新建springboot项目引入RELEASE版本出错maven详解maven就是通过pom.xml中的配置,就能够从仓库获取到想要的jar包。仓库分为:本地仓库、第三方仓库(私服)、中央仓库springframework.boot:spring-boot-starter-parent:2.2.1.RELEASE’ not found若出现jar包下载不了只有两_基于微服务的在线教育平台尚硅谷

随便推点

网络学习第六天(路由器、VLAN)_路由和vlan-程序员宅基地

文章浏览阅读316次。路由的概念路由器它称之为网关设备。路由器就是用于连接不同网络的设备路由器是位于OSI模型的第三层。路由器通过路由决定数据的转发。网关的背景:当时每家计算机厂商,用于交换数据的通信程序(协议)和数据描述格式各不相同。因此,就把用于相互转换这些协议和格式的计算机称为网关。路由器与三层交换器的对比路由协议对比路由器的作用:1.路由寻址2.实现不同网络之间相连的功能3.通过路由决定数据的转发,转发策略称为 路由选择。VLAN相关技术什么是VLAN?中文名称叫:虚拟局域网。虚_路由和vlan

设置div背景颜色透明度,内部元素不透明_div设置透明度,里面的内容不透明-程序员宅基地

文章浏览阅读2.8w次,点赞6次,收藏22次。设置div背景颜色透明度,内部元素不透明:.demo{  background-color:rgba(255,255,255,0.15) } 错误方式:.demo{ background-color:#5CACEE;opacity:0.75;} 这样会导致div里面的元素内容和背景颜色一起变透明只针对谷歌浏览器的测试_div设置透明度,里面的内容不透明

Discuz!代码大全-程序员宅基地

文章浏览阅读563次。1.[ u]文字:在文字的位置可以任意加入您需要的字符,显示为下划线效果。2.[ align=center]文字:在文字的位置可以任意加入您需要的字符,center位置center表示居中,left表示居左,right表示居右。5.[ color=red]文字:输入您的颜色代码,在标签的中间插入文字可以实现文字颜色改变。6.[ SIZE=数字]文字:输入您的字体大小,在标签的中间插入文..._discuzcode 大全

iOS NSTimer定时器-程序员宅基地

文章浏览阅读2.6k次。iOS中定时器有三种,分别是NSTimer、CADisplayLink、dispatch_source,下面就分别对这三种计时器进行说明。一、NSTimerNSTimer这种定时器用的比较多,但是特别需要注意释放问题,如果处理不好很容易引起循环引用问题,造成内存泄漏。1.1 NSTimer的创建NSTimer有两种创建方法。方法一:这种方法虽然创建了NSTimer,但是定时器却没有起作用。这种方式创建的NSTimer,需要加入到NSRunLoop中,有NSRunLoop的驱动才会让定时器跑起来。_ios nstimer

Linux常用命令_ls-lmore-程序员宅基地

文章浏览阅读4.8k次,点赞17次,收藏51次。Linux的命令有几百个,对程序员来说,常用的并不多,考虑各位是初学者,先学习本章节前15个命令就可以了,其它的命令以后用到的时候再学习。1、开机 物理机服务器,按下电源开关,就像windows开机一样。 在VMware中点击“开启此虚拟机”。2、登录 启动完成后,输入用户名和密码,一般情况下,不要用root用户..._ls-lmore

MySQL基础命令_mysql -u user-程序员宅基地

文章浏览阅读4.1k次。1.登录MYSQL系统命令打开DOS命令框shengfen,以管理员的身份运行命令1:mysql -u usernae -p password命令2:mysql -u username -p password -h 需要连接的mysql主机名(localhost本地主机名)或是mysql的ip地址(默认为:127.0.0.1)-P 端口号(默认:3306端口)使用其中任意一个就OK,输入命令后DOS命令框得到mysql>就说明已经进入了mysql系统2. 查看mysql当中的._mysql -u user

推荐文章

热门文章

相关标签