DIY编程器网

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 95|回复: 0
打印 上一主题 下一主题

bf561的loader过程

[复制链接]
跳转到指定楼层
楼主
发表于 2012-1-16 16:38:28 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
近来开始用BF 561设计图像匹配系统。所以把这一过程的所得记录在此,以便与大家共享。
  在程序下载这个环节上遇到如下一些问题:
  visual dsp++5.0下针对BF561开发板的烧写flash的程序,不能正常下载,重新编译一下才可以。
  在开发bf561时,尤其是当使用sdram空间时尤其小心flash内的内容,因为当开发的代码需要使用sdram空间时,sdram必须已经被初始化过,不然会导致出现异常中断。所以在调试程序前先给flash内烧一个带有初始化sdram的代码,就没有这个问题了,不然在开发程序的时候,还的经常注意这个问题。
  BF561开发板上的一个可能的bug:当boot模式选择为:从flash启动时,若flash内的程序有问题,则仿真器连不上bf561,需要更改boot方式才可以。这可能是个bug,技术支持也这样认为。
  Init code 一般包括初始化sdram,设置pll等工作,前者是为了程序正常使用sdram,后者是为了loader过程比较快的完成。
  Init code文件的注意事项:
  要有rts指令。因为loader在辨认出是initcode时,采用call指令来调用init代码,所以为了保证程序能够正常执行下去,initcode中必须有rts指令
  推荐把astat,rets,Rx,Px全都压栈。
  下边是一个init code的简单例子,在该实例中只是初始化了sdram
  #include
  .section program;
  /********************************************************************/
  [--SP] = ASTAT; // Save registers onto Stack
  [--SP] = RETS;
  [--SP] = (R7:0);
  [--SP] = (P5:0);
  /********************************************************************/
  /*******Init Code Section********************************************/
  /*******SDRAM Setup************/
  Setup_SDRAM:
  P0.L = lo(EBIU_SDRRC);
  P0.H = hi(EBIU_SDRRC); // SDRAM Refresh Rate Control Register
  R0 = 0x03A9(Z);
  W[P0] = R0;
  SSYNC;
  P0.L = lo(EBIU_SDBCTL);
  P0.H = hi(EBIU_SDBCTL); // SDRAM Memory Bank Control Register
  R0 = 0x0015(Z);
  W[P0] = R0;
  SSYNC;
  P0.L = lo(EBIU_SDGCTL);
  P0.H = hi(EBIU_SDGCTL); // SDRAM Memory Global Control Register
  R0.H = 0x0091;
  R0.L = 0x998F;
  [P0] = R0;
  SSYNC;
  /********************************************************************/
  (P5:0) = [SP++]; // Restore registers from Stack
  (R7:0) = [SP++];
  RETS = [SP++];
  ASTAT = [SP++];
  /********************************************************************/
  RTS;
?
                          
                       
                          
                               
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|文字版|手机版|DIY编程器网 ( 桂ICP备14005565号-1 )

GMT+8, 2024-9-28 00:21 , 耗时 0.099023 秒, 18 个查询请求 , Gzip 开启.

各位嘉宾言论仅代表个人观点,非属DIY编程器网立场。

桂公网安备 45031202000115号

DIY编程器群(超员):41210778 DIY编程器

DIY编程器群1(满员):3044634 DIY编程器1

diy编程器群2:551025008 diy编程器群2

QQ:28000622;Email:libyoufer@sina.com

本站由桂林市临桂区技兴电子商务经营部独家赞助。旨在技术交流,请自觉遵守国家法律法规,一旦发现将做封号删号处理。

快速回复 返回顶部 返回列表