s3c2416裸跑环境配置
最近刚刚开始学习ARM-linux,上周买了块tq2416的板子,给的Linux资料太复杂太深奥不愿看,等不及想要把2416跑起来。于是到处找相关裸跑资料,可是用2416的人实在少,网上的资料更少,裸跑的资料几乎是空白。最后在amobbs上找到一个相关的帖子http://www.amobbs.com/thread-5529091-1-1.html,并通过同事下载了Tifosi_分享的代码,再通过自己的摸索,终于实现s3c2416的裸跑,这里向Tifosi_及我那位同事渊哥表示感谢!
调试软件环境:Keil uVision 4.7,这里需要特别注意,有些版本的Keil支持s3c2416 Device,但是不能通过编译,例如Keil uVision 4.1,会提示不支持ARM926EJ-S
调试工具:J-link V8
目标板:tq2416,当然也可以是其它的板子,前提是引出JTAG引脚,这里一切描述以tq2416为例
Keil配置:下载安装好Keil uVision 4.7,创建一个新工程,进入target options对话框对编译环境设置,这里主要设置的地方是Target选项、Debug选项和Utilities选项
Target选项设置
这里使用2416的SRAM进行调试,但是我们这里似乎犯了一个错误,因为2416的用户手册上提供的memory map上明明标识SRAM的起始位置是0x40000000。其实我确实在这里犯了错误,而且这个错误持续了好几天才发现。2416最先启动的代码是IROM中固化的程序,IROM的地址是0x00000000,它负责将所选启动源的启动代码拷贝到SRAM,然后把SRAM的地址强制映射至0x00000000,至此,IROM消失了,运行的是SRAM中的代码。自然,0x40000000处不再有SRAM。这块被成为Steppingstone的SRAM一共64KB空间,上图所示将其前32KB设置成ROM,相当于程序存储器,后32KB设置成RAM,即数据存储器。

Debug选项配置
这里主要选择下调试工具(J-LINK),更重要的是添加一个配置脚本文件(如上图所示.\StartUp\Start.ini文件),这个脚本文件可以通过J-LINK在调试之前使CPU执行命令,这里主要是载入可执行文件以及设置程序执行起始地址,脚本文件内容如下:
FUNC void SetupForStart (void)
{
SP = 0x0000f000;
PC = 0x00000000;
}
LOAD .\Object\s3c2416.axf INCREMENTAL
SetupForStart();
接下来设置Utilities选项,参照下图即可

Utilities选项配置
完成上述设置后,保存,即完成了编译调试环境设置。接下来需要写一段代码,以验证2416能否正常运行,代码比较简单,是用汇编写的计算1+...+100和的小程序。在工程"s3c2416"中,新建一个"s3c2416_Add.s"文件,写入以下代码:
AREA RESET, CODE, READONLY;, ALIGN = 3
ARM
;PRESERVE8 ENTRY LDR R0,=0x00 ;R0=0
LDR R1,=0x00 ;R1=0
LDR R2,=0x00008000 ;R2=0x00008000
ADDER ADD R0,R0,#0x01 ;R0++
ADD R1,R1,R0 ;R1+=R0
CMP R0,# ;R0==100?LOOP:ADDER
BEQ LOOP
B ADDER STR R1,[R2] ;*(0x00008000)=R1
LOOP B LOOP ;while(1);
END
上述代码的大概思路是:R0为计数器,从1到100;R1为累加器,记录每次相加的结果;R2是一个指向0x00008000的指针,最终的结果将保存至上述地址;程序开始时先初始化寄存器的值,然后进入循环累加,累加结束后将结果保存至0x00008000处,最终进入一个死循环。保存文件与设置,编译,无错误后便可开始调试。调试前需要保证J-link驱动装好,并且与开发板上的JTAG口接好。

调试界面
点击调试按钮,进入调试界面,调试开始,可以单步执行,观察各寄存器的值及程序的执行步骤。程序的逻辑很简单,对或错关系不大,最重要的意义在于——终于能够使s3c2416裸跑了!
s3c2416裸跑环境配置的更多相关文章
- 关于《s3c2416裸跑环境配置》一文的一些补充
<s3c2416裸跑环境配置>一文已经发表很长一段时间了,前两天突然收到邮件提示有人回复,原来网友jxyggg按照文中所讲去调试,却始终不能成功.问题的描述见原文后的回复,经过QQ交流,问 ...
- IOS-Appium 自动化测试——环境配置及模拟器、真机跑测试
在MAC环境下配置IOS的appium的自动化测试环境,主要包含三个部分: 一.环境配置 1.安装homebrew(homebrew可以提供MAC OS无法提供的很多套件) ruby -e " ...
- Electron的环境配置
原文地址http://huisky.com/blog/161218121551123 本文介绍了Electron的环境配置,包括Electron下载.nodejs下载安装.NPM+Bower安装配置. ...
- windows 7下React Native环境配置
React Native 是 Facebook 推出的一个用 Java 语言就能同时编写 ios,android,以及后台的一项技术,它可以做到实时热更新 .FaceBook 也号称这们技术是 “Le ...
- win7 x64 vs2010 directShow开发环境配置
近来工作需要,要用dirrectShow写一个视频播放的demo验证自己的想法.开发环境配置了好久都没有成功,最后终于弄完,现在记录下来,以后有同学遇到同样问题,可以以此法解决. windows SD ...
- cocos2dx && Lua 环境配置
需要的材料: 1.vs2013 2.python-2.7.3(2.7.x高于2.7的版本可能会出现错误) 3.Sublime Text 2(破解的) 4.cocos2dx-3.2 步骤: 1.安装vs ...
- 深度学习主机环境配置: Ubuntu16.04 + GeForce GTX 1070 + CUDA8.0 + cuDNN5.1 + TensorFlow
深度学习主机环境配置: Ubuntu16.04 + GeForce GTX 1070 + CUDA8.0 + cuDNN5.1 + TensorFlow 最近在公司做深度学习相关的学习和实验,原来一直 ...
- 史上最详细Windows版本搭建安装React Native环境配置 转载,比官网的靠谱亲测可用
史上最详细Windows版本搭建安装React Native环境配置 2016/01/29 | React Native技术文章 | Sky丶清| 95条评论 | 33530 views ...
- odoo8.0+PyCharm4.5开发环境配置
终于把odoo的开发环境配置好,现把相关经验教训做个记录分享: odoo8.0+PyCharm4.5开发环境配置(剑飞花 373500710) 1.最佳兼容搭配包 试过各种组合 GreenOdoo+p ...
随机推荐
- MYSQL错误解决:ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' ( ...
- PYTHON线程知识再研习A
前段时间看完LINUX的线程,同步,信息号之类的知识之后,再在理解PYTHON线程感觉又不一样了. 作一些测试吧. thread:模块提供了基本的线程和锁的支持 threading:提供了更高级别,功 ...
- CCI_chapter 19 Moderate
19 1 Write a function to swap a number in place without temporary variables void swap(int &a, i ...
- ECMAScript 5/6/7兼容性速查表
http://kangax.github.io/compat-table/es5/ 秒查ECMAScript在各大浏览器的兼容性,点击右上角按钮可以“在5/6/7/非标”之间切换.做JavaScrip ...
- Linux 硬连接和软连接的原理 (in使用)
引子 目前,UNIX的文件系统有很多种实现,例如UFS(基于BSD的UNIX文件系统).ext3.ext4.ZFS和Reiserfs等等. 不论哪一种文件系统,总是需要存储数据.硬盘的最小存储单位是扇 ...
- Linux企业级项目实践之网络爬虫(23)——系统测试:找出系统中的bug
为了验证爬虫的业务流程.性能和健壮性需要进行测试. 软件测试是描述一种用来促进鉴定软件的正确性.完整性.安全性和质量的过程.软件测试的经典定义是:在规定的条件下对程序进行操作,以发现程序错误,衡量软件 ...
- bzoj2325 [ZJOI2011]道馆之战
Description 口袋妖怪(又名神奇宝贝或宠物小精灵)红/蓝/绿宝石中的水系道馆需要经过三个冰地才能到达馆主的面前,冰地中的每一个冰块都只能经过一次.当一个冰地上的所有冰块都被经过之后,到下一个 ...
- phpcms:四、尾部包含
四.尾部包含1.包含尾部文件:{template "content","footer"}2.栏目列表调用(关于我们| 联系方式| 版权声明| 招聘信息|):{p ...
- 基本NT式驱动代码结构
#include <ntddk.h> void DriverUnload(IN PDRIVER_OBJECT DriverObject);NTSTATUS MyCreateClose(IN ...
- WPF 实现控件间拖拽内容
想实现这样一个常用功能:在ListBox的一个Item上点住左键,然后拖拽到另外一个控件(如ListView中),松开左键,数据已经拖拽过来. 步骤如下: 1. 设置ListBox 的AllowDro ...