最近刚刚开始学习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执行命令,这里主要是载入可执行文件以及设置程序执行起始地址,脚本文件内容如下:

  1. FUNC void SetupForStart (void)
  2. {
  3. SP = 0x0000f000;
  4. PC = 0x00000000;
  5. }
  6. LOAD .\Object\s3c2416.axf INCREMENTAL
  7. SetupForStart();

接下来设置Utilities选项,参照下图即可

Utilities选项配置

完成上述设置后,保存,即完成了编译调试环境设置。接下来需要写一段代码,以验证2416能否正常运行,代码比较简单,是用汇编写的计算1+...+100和的小程序。在工程"s3c2416"中,新建一个"s3c2416_Add.s"文件,写入以下代码:

  1. AREA RESET, CODE, READONLY;, ALIGN = 3
  2. ARM
  3. ;PRESERVE8
  4.  
  5. ENTRY
  6.  
  7. LDR R0,=0x00 ;R0=0
  8. LDR R1,=0x00 ;R1=0
  9. LDR R2,=0x00008000 ;R2=0x00008000
  10. ADDER ADD R0,R0,#0x01 ;R0++
  11. ADD R1,R1,R0 ;R1+=R0
  12. CMP R0,# ;R0==100?LOOP:ADDER
  13. BEQ LOOP
  14. B ADDER
  15.  
  16. STR R1,[R2] ;*(0x00008000)=R1
  17. LOOP B LOOP ;while(1);
  18. END

上述代码的大概思路是:R0为计数器,从1到100;R1为累加器,记录每次相加的结果;R2是一个指向0x00008000的指针,最终的结果将保存至上述地址;程序开始时先初始化寄存器的值,然后进入循环累加,累加结束后将结果保存至0x00008000处,最终进入一个死循环。保存文件与设置,编译,无错误后便可开始调试。调试前需要保证J-link驱动装好,并且与开发板上的JTAG口接好。

调试界面

点击调试按钮,进入调试界面,调试开始,可以单步执行,观察各寄存器的值及程序的执行步骤。程序的逻辑很简单,对或错关系不大,最重要的意义在于——终于能够使s3c2416裸跑了!

s3c2416裸跑环境配置的更多相关文章

  1. 关于《s3c2416裸跑环境配置》一文的一些补充

    <s3c2416裸跑环境配置>一文已经发表很长一段时间了,前两天突然收到邮件提示有人回复,原来网友jxyggg按照文中所讲去调试,却始终不能成功.问题的描述见原文后的回复,经过QQ交流,问 ...

  2. IOS-Appium 自动化测试——环境配置及模拟器、真机跑测试

    在MAC环境下配置IOS的appium的自动化测试环境,主要包含三个部分: 一.环境配置 1.安装homebrew(homebrew可以提供MAC OS无法提供的很多套件) ruby -e " ...

  3. Electron的环境配置

    原文地址http://huisky.com/blog/161218121551123 本文介绍了Electron的环境配置,包括Electron下载.nodejs下载安装.NPM+Bower安装配置. ...

  4. windows 7下React Native环境配置

    React Native 是 Facebook 推出的一个用 Java 语言就能同时编写 ios,android,以及后台的一项技术,它可以做到实时热更新 .FaceBook 也号称这们技术是 “Le ...

  5. win7 x64 vs2010 directShow开发环境配置

    近来工作需要,要用dirrectShow写一个视频播放的demo验证自己的想法.开发环境配置了好久都没有成功,最后终于弄完,现在记录下来,以后有同学遇到同样问题,可以以此法解决. windows SD ...

  6. cocos2dx && Lua 环境配置

    需要的材料: 1.vs2013 2.python-2.7.3(2.7.x高于2.7的版本可能会出现错误) 3.Sublime Text 2(破解的) 4.cocos2dx-3.2 步骤: 1.安装vs ...

  7. 深度学习主机环境配置: Ubuntu16.04 + GeForce GTX 1070 + CUDA8.0 + cuDNN5.1 + TensorFlow

    深度学习主机环境配置: Ubuntu16.04 + GeForce GTX 1070 + CUDA8.0 + cuDNN5.1 + TensorFlow 最近在公司做深度学习相关的学习和实验,原来一直 ...

  8. 史上最详细Windows版本搭建安装React Native环境配置 转载,比官网的靠谱亲测可用

    史上最详细Windows版本搭建安装React Native环境配置   2016/01/29 |  React Native技术文章 |  Sky丶清|  95条评论 |  33530 views ...

  9. odoo8.0+PyCharm4.5开发环境配置

    终于把odoo的开发环境配置好,现把相关经验教训做个记录分享: odoo8.0+PyCharm4.5开发环境配置(剑飞花 373500710) 1.最佳兼容搭配包 试过各种组合 GreenOdoo+p ...

随机推荐

  1. Effective Java Item4:Enforce noninstantiability with a private constructor

    Item4:Enforce noninstantiability with a private constructor 通过构造私有化,禁止对象被实例化. public class UtilClass ...

  2. Feedly使用技巧

    1:用Chrome的话推荐这个应用:RSS Subscription Extension下载地址:https://chrome.google.com/webstore/detail/rss-subsc ...

  3. VC 隐藏托盘图标

    苦苦寻找的隐藏托盘图标的方法,今天终于搞定,献给大家! #include <atlbase.h> #include <atlconv.h> #include <CommC ...

  4. jquery href属性和click事件冲突

    a标签的定义如下: <a href="javascript:void(0);">test</a> jquery中的click事件: $("a&qu ...

  5. MVC 部分视图

    ASP.NET MVC 里的部分视图,相当于 Web Form 里的 User Control.我们的页面往往会有许多重用的地方,可以进行封装重用. 使用部分视图有以下优点:   1. 可以简写代码. ...

  6. C++内存泄露检測原理

    转自:http://hi.baidu.com/jasonlyy/item/9ca0cecf2c8f113a99b4981c 本文针对 linux 下的 C++ 程序的内存泄漏的检測方法及事实上现进行探 ...

  7. Picasso – Android系统的图片下载和缓存类库

    Picasso – Android系统的图片下载和缓存类库 Picasso 是Square开源的一个用于Android系统下载和缓存图片的项目.该项目和其他一些下载图片项目的主要区别之一是:使用4.0 ...

  8. Android Notification使用及取消

    //发送通知 NotificationManager manger = (NotificationManager) this.getSystemService(NOTIFICATION_SERVICE ...

  9. extern C的作用详解

    extern "C"的主要作用就是为了能够正确实现C++代码调用其他C语言代码.加上extern "C"后,会指示编译器这部分代码按C语言的进行编译,而不是C+ ...

  10. JS--显示类型转换Number—隐式类型转换

    显示类型转换 (强制类型转换):Number()parseInt()parseFloat() Number是整体转换--能够把一个看起来像数字的字符串转成数字--尽量去转换能转的都转了 var a = ...