Ubuntu下使用OpenOCD通过Jlink烧写HEX到STM32

本文地址:http://blog.csdn.net/smarxx/article/details/8486052,转载请保留

本文前提:

    1、OpenOCD(v0.6)已经装好,并且打开Jlink功能

    2、OpenOCD 已经能够正确识别Jlink。

    3、OpenOCD 可以访问Jlink设备(udev允许普通用户访问Jlink)

一、链接到STM32

打开一个终端,输入下面命令通过jlink连接到stm32:

smx@smx-Think:~$ openocd -f interface/jlink.cfg -f target/stm32f1x.cfg

说明:

    1、jlink.cfg 位于 /usr/share/openocd/scripts/interface/,无需输入jlink.cfg的完整路径, 但是如果省略“interface/”,则会提示无法找到文件。

    2、stm32f1x.cfg 位于/usr/share/openocd/scripts/target。

    “ /usr/share/openocd/scripts/” 存放着OpenOCD的相关脚本,如果通过源码编译安装OpenOCD的话,也可以在源码所在文件夹的tcl文件夹找到这些脚本。

如果看到下面的提示,则说明OpenOCD已经能够通过Jlink控制STM32了。

Open On-Chip Debugger 0.6.1 (2012-12-28-16:52)
Licensed under GNU GPL v2
For bug reports, read
	http://openocd.sourceforge.net/doc/doxygen/bugs.html
Info : only one transport option; autoselect 'jtag'
adapter speed: 1000 kHz
adapter_nsrst_delay: 100
jtag_ntrst_delay: 100
cortex_m3 reset_config sysresetreq
Info : J-Link initialization started / target CPU reset initiated
Info : J-Link ARM V8 compiled May 20 2010 17:07:46
Info : J-Link caps 0xb9ff7bbf
Info : J-Link hw version 80000
Info : J-Link hw type J-Link
Info : J-Link max mem block 9464
Info : J-Link configuration
Info : USB-Address: 0xff
Info : Kickstart power on JTAG-pin 19: 0xffffffff
Info : Vref = 2.672 TCK = 1 TDI = 0 TDO = 0 TMS = 0 SRST = 0 TRST = 0
Info : J-Link JTAG Interface ready
Info : clock speed 1000 kHz
Info : JTAG tap: stm32f1x.cpu tap/device found: 0x3ba00477 (mfg: 0x23b, part: 0xba00, ver: 0x3)
Info : JTAG tap: stm32f1x.bs tap/device found: 0x16410041 (mfg: 0x020, part: 0x6410, ver: 0x1)
Info : stm32f1x.cpu: hardware has 6 breakpoints, 4 watchpoints

二、连接到OpenOCD守护程序

打开另一个终端,输入一下命令连接到OpenOCD守护程序。后面的所有命令都是在这个终端运行的。

smx@smx-Think:/mnt/d/VC_Work/Backup$ telnet localhost 4444
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
Open On-Chip Debugger
> 
说明:

    成功通过Jlink连接到STM32上之后,OpenOCD会监听本机的4444端口。通过telnet登录上去,之后就可以控制OpenOCD干些什么了。


三、烧写程序到STM32

在打开的第二个终端执行以下命令,把程序/foo/bar.hex写入STM32。

> halt                                                               
target state: halted
target halted due to debug-request, current mode: Thread 
xPSR: 0x01000000 pc: 0x080002c2 msp: 0x20000710
> flash write_image erase /foo/bar.hex
auto erase enabled
wrote 28672 bytes from file /foo/bar.hex in 1.814544s (15.431 KiB/s)
> reset
JTAG tap: stm32f1x.cpu tap/device found: 0x3ba00477 (mfg: 0x23b, part: 0xba00, ver: 0x3)
JTAG tap: stm32f1x.bs tap/device found: 0x16410041 (mfg: 0x020, part: 0x6410, ver: 0x1)
> 

说明:

    1、halt : 

        挂起STM32,相当于关机,不执行halt,无法把程序写入STM32的Flash

    2、flash write_image erase /foo/bar.hex :

         flash write_image: 写入镜像,支持的类型有bin文件、hex文件、elf文件、s19文件(Motorola s19)、mem、builder,详情参见OpenOCD手册关于Flash命令章节

        erase:写入程序前先擦除Flash用到的扇区。如果要写入程序的所有扇区已经用“Flash erase_sector”命令擦除过,则可以去掉“erase”选项。

       /foo/bar.hex:指定要写入的程序bar.hex,位于/foo/。

    3、reset:

       复位STM32

四、OpenOCD的其他命令

       1、查看flash的bank序号:

> flash banks
#0 : stm32f1x.flash (stm32f1x) at 0x08000000, size 0x00010000, buswidth 0, chipwidth 0
>
      由返回的信息(#0)可以知道,bank序号是0。bank序号在某些指令上要用到。

      2、查看Flash擦除状态:

> flash erase_check 0   
Target not halted
unknown error when checking erase state of flash bank #0 at 0x08000000
	#  0: 0x00000000 (0x400 1kB) erase state unknown
	#  1: 0x00000400 (0x400 1kB) erase state unknown
	#  2: 0x00000800 (0x400 1kB) erase state unknown
……
	# 60: 0x0000f000 (0x400 1kB) erase state unknown
	# 61: 0x0000f400 (0x400 1kB) erase state unknown
	# 62: 0x0000f800 (0x400 1kB) erase state unknown
	# 63: 0x0000fc00 (0x400 1kB) erase state unknown
in procedure 'flash'
>
说明:

    flash erase_check命令后面的“0”就是bank序号。

    3、擦除指定区域

> flash erase_sector 0 61 63
erased sectors 62 through 63 on flash bank 0 in 0.053325s
> 

说明:

    命令后面的三个参数“0 61 63”,分别为bank序号,起始扇区,终止扇区

    4、设置jtag速度

> adapter_khz 10000
adapter speed: 10000 kHz
> 

说明:

    参数10000为jtag速度,单位是Khz。


备注:

    本文所列命令在OpenOCD0.6.1上执行通过。OpenOCD命令并不是固定不变的。不同版本对应命令可能有所不同。最好查看一下对应版本的手册。

你可能感兴趣的:(Linux,stm32)