近期在做一个小产品,是基于S32K144为MCU的板子。在调试过程中发现,虽然采用Jlink可以连接上,但是无法用S32DS的Debug模式进行调试。也就是.elf文件无法下载进入FLASH,而错误提示总是如下:
(1)Failed to download RAMCode
(2)Failed to Read Memory xxx
而且让人崩溃的是焊接了10套板子,有百分之八九十会有这种现象,现象还是一模一样。
首先是怀疑焊接有问题,焊接了N次,也换过N次MCU,最终的结果都是一样的。
xxxxx:真是让人欲哭无泪
网上遍历了各种帖子,也搜寻了各种官方的文档,然而没有任何作用。并不是各位大牛不牛,只能说没有对症下药

既然焊接确保了,电压也测量了,阻抗也测量了,Debug设置也没问题,那是否是复位和晶振的问题,一查复位,还真是有问题,出现了谜之一样的波形:三角波形状的复位信号。抱着试试看的心里,看各位广大的网友是否也遇到类似的情况,还真找到了一遍很相关的S32K1xx系列MCU应用指南之芯片锁死(lockup)复位原因分析与恢复方法详解 (qq.com)
刚开始以为看了希望,按照上面的步骤一步步稳扎稳打,通过SWD读取MDM-AP状态寄存器的命令:
(1)SWDWriteDP 2 0x01000000 //SELECT[31:24] = 0x01选择MDM-AP,且设置DPACC寄存器的SELECT[7:4] = 0x0
(2)SWDReadAP 0 //通过AP index(A[3:2]=0b00)读取MDM-AP状态寄存器
(3)SWDReadAP 0 //dump out真实的AP寄存器值
然后出现了如下界面:

根据读取的指令确定FLASH已经初始化成功,就开始给FLASH解锁,解锁指令就是unlock Kinetis,出现了比较友好的结果:unlock device ok
以为看到了未来,开始又尝试用S32DS的debug模式下载程序,然后问题依旧!!!!!!!令人很抓狂的。
是不是复位的RC值不对,换了几组RC后,问题依旧存在。
进一步抓狂!!!!!!!!!!!!!!!
在尝试了N次 unlock Kinetis后,也没有成效,又研究了这个帖子S32K1xx系列MCU应用指南之芯片锁死(lockup)复位原因分析与恢复方法详解 (qq.com)
是不是没有mass erase的原因,但是直接输入mass erase没有任何反应,Jlink Command根本不识别,后参考Jlink command的Help ,发现Erase指令,如下图:

直接输入Erase,果真能Erase,然后S32DS Debug还是不行。愤慨了,再Erase下,结果再也连不上Jlink了,MCU变成砖了。愤慨没用,继续搬砖

令人跟崩溃的,换了MCU,采用Jlink的UI界面手动擦除,结果MCU又变成砖了。又一次躺倒在希望的道路上
既然已经死了N次,再来一次,换了颗MCU后,尝试了下Jliink UI界面的如下指令,如下图所示

既然出现了奇迹,如下图所示,擦写、下载、验证都是OK的,重新上电,跑马灯起来了,整个世界都亮了。

重生后的喜悦是必然的,但是到底是什么原因了,原来官方的手册写的很明白,当FLASH Memory的安全机制是激活的时候,仿真器是可以连上,但是没法读取Flash Memory的内容的,就出现了Debug模式下的:Failed to Read Memory xxx。

那需要怎么解除安装机制呢,官方手册也说了,就是trigger a mass erase。
那上文尝试的几次Erase怎么还变砖了,那就是擦除的方式不对,导致mass erase disable,这样无法连接上仿真器,这个时候的方法是采用后门钥匙,但这是天方夜谭,除非你找到原厂支持。
因此,不要随便擦除,还是按照Jlink自带的Production Programming就行擦除下载。
5.tips
当使用Jlink UI执行Production Programming没有证书,可以私信。
文章目录1.开发板选择*用到的资源2.串口通信(个人理解)3.代码分析(注释比较详细)1.主函数2.串口1配置3.串口2配置以及中断函数4.注意问题5.源码链接1.开发板选择我用的是STM32F103RCT6的板子,不过代码大概在F103系列的板子上都可以运行,我试过在野火103的霸道板上也可以,主要看一下串口对应的引脚一不一样就行了,不一样的就更改一下。*用到的资源keil5软件这里用到了两个串口资源,采集数据一个,串口通信一个,板子对应引脚如下:串口1,TX:PA9,RX:PA10串口2,TX:PA2,RX:PA32.串口通信(个人理解)我就从串口采集传感器数据这个过程说一下我自己的理解,
LL库和HAL库简介LL:Low-Layer,底层库HAL:HardwareAbstractionLayer,硬件抽象层库LL库和hal库对比,很精简,这实际上是一个精简的库。LL库的配置选择如下:在STM32CUBEMX中,点击菜单的“ProjectManager”–>“AdvancedSettings”,在下面的界面中选择“AdvancedSettings”,然后在每个模块后面选择使用的库总结:1、如果使用的MCU是小容量的,那么STM32CubeLL将是最佳选择;2、如果结合可移植性和优化,使用STM32CubeHAL并使用特定的优化实现替换一些调用,可保持最大的可移植性。另外HAL和L
目录一、ESP32简单介绍二、ESP32Wi-Fi模块介绍三、ESP32Wi-Fi编程模型四、ESP32Wi-Fi事件处理流程 五、ESP32Wi-Fi开发环境六、ESP32Wi-Fi具体代码七、ESP32Wi-Fi代码解读6.1主程序app_main7.2自定义代码wifi_init_sta()八、ESP32Wi-Fi连接验证8.1测试方法8.2服务器模拟工具sscom58.3测试代码8.4测试结果前言为了开发一款亚马逊物联网产品,开始入手ESP32模块。为了能够记录自己的学习过程,特记录如下操作过程。一、ESP32简单介绍ESP32是一套Wi-Fi(2.4GHz)和蓝牙(4.2)双模解决方
有道无术,术尚可求,有术无道,止于术。本系列SpringBoot版本3.0.4本系列SpringSecurity版本6.0.2本系列SpringAuthorizationServer版本1.0.2源码地址:https://gitee.com/pearl-organization/study-spring-security-demo文章目录前言1.OAuth2AuthorizationServerMetadataEndpointFilter2.OAuth2AuthorizationEndpointFilter3.OidcProviderConfigurationEndpointFilter4.N
在我的代码中,我需要使用各种算法(包括CRC32)对文件进行哈希处理。因为我还在Digest系列中使用其他加密哈希函数,所以我认为为它们维护一个一致的接口(interface)会很好。为了记录,我确实找到了digest-crc,一颗完全符合我要求的gem。问题是,Zlib是标准库的一部分,并且有一个我想重用的CRC32工作实现。此外,它是用C编写的,因此它应该提供与digest-crc相关的卓越性能,后者是纯ruby实现。实现Digest::CRC32一开始看起来非常简单:%w(digestzlib).each{|f|requiref}classDigest::CRC32一切正常:
我正在尝试在我的机器上安装win32-apigem,但在构建native扩展时我遇到了一些问题:$geminstallwin32-api--no-ri--rdocTemporarilyenhancingPATHtoincludeDevKit...Buildingnativeextensions.Thiscouldtakeawhile...C:\Programs\dev_kit\bin\make.exe:***Couldn'treservespaceforcygwin'sheap,Win32error0ERROR:Errorinstallingwin32-api:ERROR:Failed
我在Windows上运行ruby1.9.2并试图移植在Ruby1.8中工作的代码。该代码使用以前运行良好的Open4.popen4。对于1.9.2,我做了以下事情:通过geminstallPOpen4安装了POpen4需要POpen4通过require'popen4'尝试像这样使用POpen4:Open4.popen4("cmd"){|io_in,io_out,io_er|...}当我这样做时,我得到了错误:nosuchfiletoload--win32/open3如果我尝试安装win32-open3(geminstallwin32-open3),我会收到错误消息:win32-op
DellInspiron5488加内存32G 原装内置内存仅仅8G,目前看,真的太小了! 1.内存型号Dell5488内存型号:DDR42666。笔记本有两个内存插槽,原装占了一个,还能扩展一个。 2.买内存如果买Dell原装笔记本内存,8G就得500块左右。 我咨询了一下,三星的笔记本内存,可以兼容。16G,299块(2023年2月23日,京东价) Dell5488内存组合,最多只能插两根16G内存。 我于是买了两根三星16G内存。装上,很爽😄 跑国产系统统信UOS,再也看不到用交换区了,32G内存,爽!
本文代码使用HAL库。文章目录前言一、MCP4017的重要特性二、MCP4017计算RBW阻值三、MCP4017地址四、MCP4017读写函数五、CubeMX创建工程(利用ADC测量MCP4017电压)、对应代码:总结前言一、MCP4017的重要特性蓝桥杯板子上的是MCP4017T-104ELT,如图1。MCP4017是一个可编程电阻,通过写入的数值可以改变电阻的大小。重点在于6引脚(W),5引脚(B
STM32OTA应用开发——通过USB实现OTA升级目录STM32OTA应用开发——通过USB实现OTA升级前言1环境搭建2功能描述3BootLoader的制作4APP的制作5烧录下载配置6运行测试结束语前言什么是OTA?百度百科:空中下载技术(Over-the-AirTechnology;OTA),是通过移动通信的空中接口实现对移动终端设备及SIM卡数据进行远程管理的技术。经过公网多年的应用与发展,已十分成熟,网络运营商通过OTA技术实现SIM卡远程管理,还能提供移动化的新业务下载功能。实际上,现在我们所说的OTA比百度百科的定义还要更广泛,OTA的形式已经不再局限于手机和SIM卡,只要涉及