Booting dircetly into Redlink FW from flash
Booting dircetly into Redlink FW from flash
Hello,
the usual way to use the Redlink FW is a two-step approach:
- First the MCU of the probe enumerates as a DFU device.
- Then the Redlink Server downloads the current Redlink FW into SRAM
and the probe re-enumerates as a different HID device (VID 0x21BD, PID 0006) which is the probe FW.
This works quite fine, but if your target MCU also boots into USB at the same time the probe boots,
then the host cannot know which device is the probe and which one is the target.
In this scenario it would be desirable to flash the (current) Redlink FW once into the internal flash of the probe MCU and then directly boot from flash.
The probe would then enumerate as the"probe HID" device directly.
Can this be done easily, i.e. is there a Redlink FW that is relocated for start from internal flash?
We plan to deploy quite a lot (40+) of these "hard coded debuggers" for edu purposes in two labs.
The probes are already designed and tested with the LPC4320 (and up) and work fine so far.
AFAIK they could run on some LPC18xx as well. If so, does this require a different Redlink FW?
We just use the JTAG debug interface, no SWD, trace port or other fancy stuff.
Best regards,
Mike
First of all, redlink is designed to run on known NXP debug probe hardware only.
It is only tested on such probes, and we make no guarantees as to its use on other hardware.
Also redlink firmware will only run LPC43xx, there is no LPC18xx variant.
But those points aside, if you hardware had SPIFI flash then you should be able to program the image into that -
the LPC43xx bootloader would download it into RAM on startup).
LPCScrypt could be used to do this.
But there is no redlink firmware build available that could run from internal flash. < run from SRAM always >
Note that you mention LPC4320 - which of course has no internal flash.
If you are using internal flash then the simplest solution might be to try using CMSIS-DAP firmware,
which is designed to programmed and run from flash ......
http://www.lpcware.com/lpclink2-config-tool
Regards,
LPCXpresso Support
Update:
I decided to stick with the Redlink FW, because according to the documentation the CMSIS/DAP version cannot debug the multicore targets.
So I just wrote a "bootloader stub" residing in internal flash
- which copies the current Redlink FW (stored in internal flash as a BLOB also) to SRAM,
- sets up VTOR and the SP for SRAM operation and
- then jump to the "new" reset vector, i.e. starts the FW.
Works fine on a LPC4327.
Our "microboards" now enumerate immediately as "LPCLINK2 redlink" devices
and work as expected with LPCXpresso as JTAG probes.
Thanks for your help and clarification even on a project that is well "out of support scope".
Regards,
Mike
Glad to hear that you now have a solution that works for you.
You should take note though that the redlink firmware provided with one version of LPCXpresso may not work with,
or may not provide support for some features, when used with a future LPCXpresso release.
Thus I would recommend that you update the firmware you have flashed when you update to a new LPCXpresso version.
Also regarding the CMSIS-DAP firmware for LPC-Link2:
you are correct that using this firmware you can currently only connect from LPCXpresso to the M4 core inside the LPC43xx parts.
Allowing connections via CMSIS-DAP to the M0 core(s) is something we do intend to support in a future release LPCXpresso release though.
Regards,
LPCXpresso Support
Booting dircetly into Redlink FW from flash的更多相关文章
- 【转载】Serial NOR Flash and U-Boot
转载自:http://blackfin.uclinux.org/doku.php?id=bootloaders:u-boot:serial-flash U-Boot supports serial N ...
- 创建squashfs
SquashFS 通常的livecd都有一个这个文件,是核心的文件系统 SquashFS 也是一个只读的文件系统,它可以将整个文件系统压缩在一起,存放在某个设备,某个分区或者普通的文件中.如果您将其压 ...
- Bug搬运工-CSCvg37458:ISR4K goes into booting loop with "flash:" in boot statement
ISR4K升级的时候要注意了! 很可能会碰到如下的问题: ISR4K goes into booting loop with "flash:" in boot statement ...
- [转]uboot中SPI Flash Booting配置
转自:https://e2echina.ti.com/question_answer/dsp_arm/sitara_arm/f/25/t/124834 最近和人一起调试SPI FLASH的配置问题,做 ...
- s3c2440 移值u-boot-2016.03 第2篇 支持Nand flash启动
1, 要求:在4K 的代码以内,完成 NOR NAND 类型判断,初始化 NAND 复制自身到 SDRAM ,重定向. 2, 在 /arch/arm/cpu/arm920t/ 文件夹里 添加一个 in ...
- LPC18xx LPC43xx LPC4370 Bootrom USB DFU FPB - Flash Patch and Breakpoint Unit
What is the difference between a Bootrom vs bootloader on ARM systems Bootrom Bootrom (or Boot ROM) ...
- Android eMMC Booting
Android eMMC Booting Contents [hide] 1 eMMC binaries 1.1 Creating the GPT table 1.2 Modifying .IMG F ...
- Android gingerbread eMMC booting
Android gingerbread eMMC booting This page is currently under construction. The content of this page ...
- Booting ARM Linux
来源:linux-2.6.30.4/Documentation/arm/Booting ARM Linux Booting ARM Linux ================= ...
随机推荐
- python代码在IDE下调试设置命令行参数
带命令行参数的代码在IDE下调试,需要把参数赋值,本文mark一下具体的命令行参数在代码中赋值方法. if __name__ == "__main__": sys.argv = [ ...
- Android 中关于 【Cursor】 类的介绍
转自(http://www.cnblogs.com/TerryBlog/archive/2010/07/05/1771459.html) 使用过 SQLite 数据库的童鞋对 Cursor 应该不陌生 ...
- elasticsearch RTF版本介绍
说明:elastic search官方版本没有集成中文分词以及各种插件,需要手动配置,手动编译jar,对Windows用户很不友好.下载地址:https://github.com/medcl/elas ...
- nginx:在centos中自启动
参考网址:http://www.jb51.net/article/120545.htm # vi /etc/init.d/nginx #!/bin/sh # Name:nginx4comex # ng ...
- vue 数组
今天项目中发现的一个问题: 在vue项目中输出一个数组,明明有俩个值:0,6,但是length为1 正常的是这样的 结果研究发现,是vue源码的问题,具体内容如下: 转载自:http://www.cn ...
- tensorflow variable的保存和修改(加载一部分variable到新的model中)
link: https://www.tensorflow.org/guide/saved_model 中文博客:https://blog.csdn.net/Searching_Bird/article ...
- 为什么尽量别用 setInterval
为什么尽量别用setInterval 在开发一个在线聊天工具时,经常会有过多少毫秒就重复执行一次某操作的需求.“没问题”,大家都说,“用setInterval好了.”我觉得这个点子很糟糕. 原因之 ...
- python生成器、装饰器、正则
包子来了[4],被[mayun]吃了! 包子来了[4],被[mahuateng]吃了! 做了两个包子 包子来了[5],被[mayun]吃了! 包子来了[5],被[mahuateng]吃了! 做了两个包 ...
- Build OpenJDK9 on macOS Sierra
1. Get the source code: hg clone http://hg.openjdk.java.net/jdk9/jdk9 jdk9 cd jdk9 sh get_source.sh ...
- js+ajax+springmvc实现无刷新文件上传
话不多说直接上代码 <%@ page language="java" contentType="text/html; charset=UTF-8" pag ...