ST40 自制 JTAG 适配器
// 文章首发于 https://zhuanlan.zhihu.com/p/28762429
// 但是不知道为什么搜索引擎还没有收录,便在博客再次发布。
0. 引言
意法半导体生产的 SH4 架构的 ST40 CPU 被广泛地用于机顶盒中。
对于DIY家庭硬件来说,救砖途径十分重要,尤其是在 FLASH 由于误操作被清空时,不能使用 u-boot 之类的 bootloader,JTAG 几乎就成了唯一较方便的救转方式。
(当然还可以用编程器直接写 FLASH,不过贴片的 FLASH 芯片用烙铁拆还是有点小怕。)
而对于 ST40 CPU 来说,需要购买 ST 官方的 ST Micro Connect 仿真器,才可使用 JTAG 进行调试与运行程序,价格比较昂贵,其实这样的一个 JTAG 适配器,是可以自己DIY制作的。
1. 准备
- FT4232 或者 FT2232 系列模块
- 双母头杜邦线若干
- 目标板(此处为 STb7100 板子)
- PC(Fedora 14 x86 与 Windows)
- 万用表
2. 操作
2.1 目标板 JTAG
首先在目标板上,找到 JTAG 针脚(一般为20针),可以利用 Google 搜索一下板子的 Datasheet,比如我的 STb7100 板子可以在这找到:
http://www.avi-plus.com/download/STb7100MB.pdf
翻阅找到有关 JTAG 的一页,可以看到针脚是这样定义的,如下图。
由于板子上的 JTAG 针脚没有标记,而偶数针脚均为 GND,因此利用万用表测试各针脚与 GND 的连通性,能够找到所有偶数针脚,便可确定各针脚的定义。
(注意:第 7 针应为nASEBRK;第 17 针也可叫nRST)
2.2 FTDI 模块
对于 FTDI 的芯片,国内存在着大量山寨芯片,一般淘宝上比较便宜的那种,十拿九稳就是山寨芯片了,虽然功能没有影响,但性能有不同,还是强烈建议购买正版。
比较方便的模块之一是 UM232H,国内淘宝存在如下两种:前者应为国内小厂商自己山寨的模块,后者应为 FTDI 官方版本,都可以用。
一般来说,模块购买后,应该是空的,即没有进行烧写程序的;当然如果有,也不影响。
基本的思路就是将 FTDI 模块的 VID 和 PID 修改为 ST Micro Connect 对应的值,达到欺骗的效果。
将购买的模块连接至 PC,前往 FTDI 官网下载驱动后安装,下载使用 MProg 对其进行烧写。首先扫描设备 Device -> Scan,然后读取数据 Tools -> Read and Parse,进入编辑模式后,可修改其数据,修改后如下图。
之后使用闪电图标进行烧写,就完成了欺骗第一步,如果你发现烧写后发现信息错误,可以在 FTDI 的驱动 INF 文件中,加入你设备当前的 VID 和 PID,对你的设备重新安装该驱动,即可识别为 FTDI 设备,便可再次使用 MProg 进行烧写操作。
下图为连线图,使用了 FTDI 官方模块作为图例。对于 FTDI 官方模块来说,需要使用跳线帽对其电源进行设置:VIO 与 3V3,5V0 和 USB 连接;而对于山寨模块来说,一般不需要考虑电源,厂商都已经设置好,因此可直接看左下侧的连线。
根据下图将 UM232H 模块与目标板 JTAG 相连。
(注意:GND 在此可不连)
2.3 工具集
目前暂未找到 Windows 下的 ST Micro Connect 驱动程序,估计 ST 官方的 FTP 有,不过前些年流传的用户名和密码失效了。
ST 其实有个专用的 Toolset 和 Package 的,Toolset 的下载地址(Windows):
ST40 Micro Toolset R5.3.0. Get the software safe and easy.
目前我的解决方案是使用 STLinux 内置的工具集,需要安装 STLinux,下载地址:
http://archive.stlinux.com/stlinux/2.4/iso/STLinux-2.4-sh4-20141119.iso
也就是说 Windows 有工具集但缺驱动,而 Linux 下要安装一个大东西。
这玩意儿坑的我非常厉害,等有空了我再单独发一篇文章。
2.4 工具集使用
如果安装了 STLinux 或者 Toolset 并有驱动,可以打开其提供的 gdb。
对于我的 STb7100 来说,使用 mb411 的包,
Windows 下使用
(gdb) sh4tp STMCLT2333A:mb411:st40
Linux 下使用
(gdb) sh4tp STMCLT2333_A:mb411:st40
接下来就可以加载程序了,可以加载 ELF 格式的程序
(gdb) load /home/st/bootloader/u-boot
继续执行
(gdb) continue
理论上现在的串口就可以使用了。
A. 参考资料
[1] How to JTAG Interface STMCLT Clone (Rev 2) http://www.avi-plus.com/images/fbfiles/files/HOWTO_JTAG_Interface_STMCLT_Clone_REV2.pdf
[2] ST40 / STb71xx JTAG interfacing
ST40 自制 JTAG 适配器的更多相关文章
- 用TTL线在CFE环境下拯救半砖wrt54g路由器
缘起:路由器被刷成半砖 Linksys wrt54gs v4路由器,已刷入 tomato-dualwlan 1.23.使用数年,未出现任何故障. 在日用的wifi网络上,通过web界面刷入了错误的to ...
- 自制USB wifi信号放大天线
这是我的usb wifi天线第一个版本,灵感来自: http://www.instructables.com/id/EQARE4I72GEPUCHTHU/ http://www.usbwifi.orc ...
- SPI、I2C、I2S、UART、GPIO、SDIO、CAN、JTAG的区别及使用方法。
SPI 全称及由来:SPI接口的全称是"Serial Peripheral Interface",意为串行外围接口,是Motorola首先在其MC68HCXX系列处理器上定义的. ...
- OpenOCD安装与使用(JTAG调试)
本文介绍openocd开源软件的安装以及搭配JTAG对Xilinx u500VC707devkit的调试 PC OS: Ubuntu20.04 LTS Target ARCH: riscv64 JTA ...
- Android—万能ListView适配器
ListView是开发中最常用的控件了,但是总是会写重复的代码,浪费时间又没有意义. 最近参考一些资料,发现一个万能ListView适配器,代码量少,节省时间,总结一下分享给大家. 首先有一个自定义的 ...
- 打造android偷懒神器———ListView的万能适配器
如果你去做任何一个项目,我相信你都会跟我有一样的经历,最最普遍的就是列表显示ListView,当然,写N个自定义的适配器也是情理之中.虽说程序员本身就是搬砖,做这些枯燥无味的重复的事情也是理所当然,但 ...
- 打造android偷懒神器———RecyclerView的万能适配器
转载请注明出处谢谢:http://www.cnblogs.com/liushilin/p/5720926.html 很不好意思让大家久等了,本来昨天就应该写这个的,无奈公司昨天任务比较紧,所以没能按时 ...
- ListView和Adapter数据适配器的简单介绍
ListView 显示大量相同格式数据 常用属性: listSelector listView每项在选中.按下等不同状态时的Drawable divider ...
- Android应用项目中BaseAdapter、SimpleAdapter和ArrayAdapter中的三种适配器
一.写在前面: 本次我们来讲解一下Android应用中三个适配器:BaseAdapter.SimpleAdapter和ArrayAdapter.其中常见的是BaseAdapter,也是个人推荐使用的适 ...
随机推荐
- Swing-布局管理器之GridLayout(网格布局)-入门
注:本文内容源自于三十一.Java图形化界面设计——布局管理器之GridLayout(网格布局),笔者在学习过程中根据自身理解修改了部分代码. 网格布局特点: l 使容器中的各组件呈M行×N列的网格 ...
- 2017Java课程设计201521123007
1. 课程设计博客链接 项目地址 2. 个人负责模块或任务说明 ps:一个人做的项目 一个登录jsp文件,登录成功转入商品界面, 一个商品jsp文件,显示所有商品信息,数据从MySql数据库导入,可以 ...
- 201521123022 《Java程序设计》 第十四周学习总结
1. 本章学习总结 2. 书面作业 Q1. MySQL数据库基本操作 建立数据库,将自己的姓名.学号作为一条记录插入.(截图,需出现自己的学号.姓名),在自己建立的数据库上执行常见SQL语句(截图) ...
- 201521123101 《Java程序设计》第13周学习总结
1. 本周学习总结 2. 书面作业 1. 网络基础 1.1 比较ping www.baidu.com与ping cec.jmu.edu.cn,分析返回结果有何不同?为什么会有这样的不同? 1.2 te ...
- jstl-初步认知
JSTL是java提供的JSP标签库 1,在项目中加入 jsf-api.jar jsf-impl.jar jstl-1.2.jar 三个包 2, 如何在jsp页面引入标签库 使用 <@tagli ...
- JVM菜鸟进阶高手之路六(JVM每隔一小时执行一次Full GC)
转载请注明原创出处,谢谢! 上次分析详细地址在:http://www.jianshu.com/p/a6236cd39e2d 以为上次问题是rmi的问题就此结束了,但是问题并没有结束,其实本次问题不是r ...
- XML(二)之DTD——XML文件约束
前面介绍了XML的作用和基本的格式,今天我给大家分享的是关于XML的约束.废话不多说,我们直接来正题! 一.DTD简介 1.1.DTD概述 DTD(Document Type Definition,文 ...
- 王者荣耀_KEY
WZRY 为了排位赛的Cjj神,最近耗尽气力来打WZRY. Cjj神最近有N局预约的排位赛,其中第i局需要耗时Li的时间.因为浓浓的Gay情,Cjj神不能改变这些排位赛的的顺序.作为一个很有(mei) ...
- MongDB开启权限认证
在生产环境中MongoDB已经使用有一段时间了,但对于MongoDB的数据存储一直没有使用到权限访问(MongoDB默认设置为无权限访问限制),最近在酷壳网看了一篇技术文章(https://cools ...
- vue.js项目构建
这里构建的vue.js项目依赖node服务器运行. 项目搭建完整步骤: 安装node.js ,转至nodeJs网站http://nodejs.cn/ 下载nodeJs进行安装. 安装完毕检查nodeJ ...