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 ...
随机推荐
- Effective Java Item4:Enforce noninstantiability with a private constructor
Item4:Enforce noninstantiability with a private constructor 通过构造私有化,禁止对象被实例化. public class UtilClass ...
- Feedly使用技巧
1:用Chrome的话推荐这个应用:RSS Subscription Extension下载地址:https://chrome.google.com/webstore/detail/rss-subsc ...
- VC 隐藏托盘图标
苦苦寻找的隐藏托盘图标的方法,今天终于搞定,献给大家! #include <atlbase.h> #include <atlconv.h> #include <CommC ...
- jquery href属性和click事件冲突
a标签的定义如下: <a href="javascript:void(0);">test</a> jquery中的click事件: $("a&qu ...
- MVC 部分视图
ASP.NET MVC 里的部分视图,相当于 Web Form 里的 User Control.我们的页面往往会有许多重用的地方,可以进行封装重用. 使用部分视图有以下优点: 1. 可以简写代码. ...
- C++内存泄露检測原理
转自:http://hi.baidu.com/jasonlyy/item/9ca0cecf2c8f113a99b4981c 本文针对 linux 下的 C++ 程序的内存泄漏的检測方法及事实上现进行探 ...
- Picasso – Android系统的图片下载和缓存类库
Picasso – Android系统的图片下载和缓存类库 Picasso 是Square开源的一个用于Android系统下载和缓存图片的项目.该项目和其他一些下载图片项目的主要区别之一是:使用4.0 ...
- Android Notification使用及取消
//发送通知 NotificationManager manger = (NotificationManager) this.getSystemService(NOTIFICATION_SERVICE ...
- extern C的作用详解
extern "C"的主要作用就是为了能够正确实现C++代码调用其他C语言代码.加上extern "C"后,会指示编译器这部分代码按C语言的进行编译,而不是C+ ...
- JS--显示类型转换Number—隐式类型转换
显示类型转换 (强制类型转换):Number()parseInt()parseFloat() Number是整体转换--能够把一个看起来像数字的字符串转成数字--尽量去转换能转的都转了 var a = ...