openocd调试Linux内核,openocd安装与调试
环境:
硬件:PC机ARM仿真器v8.00已下载好bit流的Xinlinx SoC开发板(其上有arm cortex-a9核)
软件:Redhat Linux6(或虚拟机)+ openocd
使用openocd下载程序,调试arm cortex-a9核。
一、openocd安装
下载libusb库安装或直接yum install libusb*
$ ./configure --prefix=/home/benben/openocd --enable-jlink
$ make #若编译有错根据提示信息修改
$ sudo make install
二、openocd使用
$ lsusb
能查到仿真器usb信息...
$ openocd -f em8302_jtag.cfg(其中引用了jlink.cfg与v7arm.cfg)#连接开发板
打印出一些无Error的信息...
$ telnet localhost 4444 #启动守护程序
> resume 0 #从0地址开始运行
> halt #暂停cpu
> mdw 0 12 #从0地址读12个数(32位)
>mww 地址 写的数#向某地址写数(32位)
>reg #查看寄存器
em8302_jtag.cfg内容
# The 8301 Board use jlink to Debug
source [find interface/jlink.cfg]
transport select jtag
# THe 8301 Board use a single v7arm chip
source [find target/v7arm.cfg]
echo "8302 Board Loaded."
# Set reset type and may be changed in some particular cases
reset_config trst_only
#reset_config separate
#reset_config trst_open_drain srst_open_drain
adapter_khz 200
# Wait after deasserting nTRST before starting new JTAG operations
#jtag_ntrst_delay 200
jlink.cfg内容(指定类型为jlink)
#
# Segger J-Link
#
# http://www.segger.com/jlink.html
#
interface jlink
# The serial number can be used to select a specific interface in case more than one
# is connected to the host.
#
# Segger software omits leading zeros in serial number displays,
# OpenOCD requires them.
#
# Example: Select J-Link with serial 123456789
#
# jlink serial 000123456789
v7arm.cfg(指定cpu信息)
if { [info exists CHIPNAME] } {
set _CHIPNAME $CHIPNAME
} else {
set _CHIPNAME ecictv7
}
# CoreSight Debug Access Port
if { [info exists DAP_TAPID] } {
set _DAP_TAPID $DAP_TAPID
} else {
set _DAP_TAPID 0x4ba00477
}
jtag newtap $_CHIPNAME dap -irlen 4 -ircapture 0x01 -irmask 0x0f \
-expected-id $_DAP_TAPID
#
# Cortex A9 target
#
# GDB target: Cortex-A9, using DAP, configuring only one core
# Base addresses of cores:
# core 0 - 0x1fffc000
# core 1 - 0x2fffc000
set _TARGETNAME1 $_CHIPNAME.cpu.0
set _TARGETNAME2 $_CHIPNAME.cpu.1
# A9 core 0
target create $_TARGETNAME1 cortex_a -chain-position $_CHIPNAME.dap \
-coreid 0 -dbgbase 0x80090000
# -coreid 0 -dbgbase 0xc0000000
#$_TARGETNAME1 configure -work-area-phys 0x80000000 -work-area-size 8096
$_TARGETNAME1 configure -event reset-start { adapter_khz 50 }
#$_TARGETNAME1 configure -event reset-assert-post "cycv_dbginit $_TARGETNAME1"
$_TARGETNAME1 configure -event gdb-attach { halt }
#smp mode cannot halt only one cpu core, have no idea, by yzq
# A9 core 1
#target create $_TARGETNAME2 cortex_a -chain-position $_CHIPNAME.dap \
# -coreid 1 -dbgbase 0xc0002000
#$_TARGETNAME2 configure -event reset-start { adapter_khz 1000 }
#$_TARGETNAME2 configure -event reset-assert-post "cycv_dbginit $_TARGETNAME2"
#$_TARGETNAME2 configure -event gdb-attach { halt }
#target smp $_CHIPNAME.cpu.1 $_CHIPNAME.cpu.0
proc cycv_dbginit {target} {
# General Cortex A8/A9 debug initialisation
cortex_a dbginit
}
openocd调试Linux内核,openocd安装与调试相关推荐
- Bochs调试Linux内核6 - 启动过程调试 - 跳到bootsect引导程序执行
接此,Bochs调试Linux内核5 - 启动过程调试 - 认识Bootsect.S_bcbobo21cn的专栏-CSDN博客 看一下,0x00007c11 这里是重复执行串传送:而后一条 ...
- Bochs调试Linux内核5 - 启动过程调试 - 认识Bootsect.S
先参阅 Bochs调试Linux内核 - 定位内核中的变量或数据结构_bcbobo21cn的专栏-CSDN博客 ,运行到<bochs:1>,输入vbreak 0x0000:0x ...
- 使用openocd调试Linux内核,openocd安装与调试
环境: 硬件:PC机ARM仿真器v8.00已下载好bit流的Xinlinx SoC开发板(其上有arm cortex-a9核) 软件:Redhat Linux6(或虚拟机) + openocd 使用o ...
- 使用openocd调试Linux内核,OpenOCD-JTAG调试
title: OpenOCD-JTAG调试 tags: ARM date: 2018-10-13 23:36:28 Todo [ ] JTAG 调试linux内核 [ ] linux下使用OpenOC ...
- 使用openocd调试Linux内核,OpenOCD-JTAG调试(示例代码)
目录 title: OpenOCD-JTAG调试 tags: ARM date: 2018-10-13 23:36:28 --- Todo [ ] JTAG 调试linux内核 [ ] linux下使 ...
- 使用 ftrace 调试 Linux 内核【转】
转自:http://blog.csdn.net/adaptiver/article/details/7930646 使用 ftrace 调试 Linux 内核,第 1 部分 http://blog.c ...
- 使用Bochs调试Linux内核初级入门
之所以能用Bochs调试Linux内核,还是因为Bochs做了一些工作: 安装完成以后如下:如果使用bochs.exe加载操作系统映像,就是在虚拟机中运行操作系统: 如果使用bochsdbg.exe加 ...
- qemu debug linux内核,在QEMU环境中使用GDB调试Linux内核
简介 对用户态进程,利用gdb调试代码是很方便的手段.而对于内核态的问题,可以利用crash等工具基于coredump文件进行调试.其实我们也可以利用一些手段对Linux内核代码进行gdb调试,qem ...
- Linux 内核的测试和调试(1)
Linux 内核的测试和调试(1) Linux 内核测试哲学 不管是开源还是闭源,所有软件的开发流程中,测试是一个重要的.不可或缺的环节,Linux 内核也不例外.开发人员自测.系统测试.回归测试.压 ...
最新文章
- Java this 心得
- 安卓实现定位功能的4种方式
- 【项目管理】范围管理
- C#中的类02:构造对象
- strcpy函数的实现
- 【渝粤题库】陕西师范大学500004 电动力学
- hbase简介(大数据技术)
- python中用socket检测端口_python基于socket函数实现端口扫描
- python存储机制_python学习之内存驻留机制简述
- 计算机c盘满了怎么搬家,c盘满了怎么办 c盘怎么搬家【搬家步骤】
- 数据:FIT2CLOUD飞致云连续进入云管理软件市场权威研究报告
- java编程中的di是什么_Diboot
- CMake windows下代理设置
- 【写文工具】常用文字表情
- Hi-End音箱真伪(3)-巴汉著文
- Bios工程师手边事—ACPI电源管理
- Project build error: Non-parseable POM D:\code\pom.xml: expected start tag name and not
- 安排CCleaner系统清理
- 处理数码照片的计算机需要配置,不仅要懂PS 浅谈修图电脑配置(基础篇)
- 还原分区失败怎么办?为什么会出现还原分区失败
热门文章
- 软件工程作业-软件案例分析
- linux 利用Google身份验证器配置ssh完成双重登录验证
- FineReport使用总结
- Webots 机器人仿真平台(二) 与ROS通讯
- wepy小程序(多张卡片)合成动画
- ESL第十六章 集成学习 汉明码、前向分段线性回归/前向逐步回归/Bet on Sparsity原则/噪信比/正则化路径/标准化L1间隔、学习集成/数值积分/集成生成/重要性采样/规则集成
- 腾讯专家工程师杨志华:混合云之争的开端与终途
- Canvas动态改变宽高解决拉伸问题
- c语言实训自我总结报告日记,C语言学习日记(1)-准备好工具
- 理解Apollo传感器标定文档