社区导航

 
快捷导航
  • 首页
  • 论坛
  • 查看新帖
  • 最新回复
  • 精华区
  • 社区活动
  • 联系管理员
  • 消灭零回复
  • E金币兑换
搜索
查看: 1217|回复: 2

[求助] 关于SysCtlDelay

[复制链接]

11

TA的帖子

0

TA的资源

一粒金砂(中级)

Rank: 2

发表于 2012-12-5 15:44:12 | 显示全部楼层 |阅读模式
我用的是LM4F230,Stellaris WARE 9453
使用ROM_SysCtlDelay循环是3个周期
使用SysCtlDelay循环是6个周期
不知道为什么会这样?求解

__asm void
SysCtlDelay(unsigned long ulCount)
{
    subs    r0, #1;
    bne     SysCtlDelay;
    bx      lr;
}
循环到底是几个周期呢
此帖出自最爱TI M4论坛

回复

使用道具 举报

11

TA的帖子

0

TA的资源

一粒金砂(中级)

Rank: 2

 楼主| 发表于 2012-12-6 12:38:32 | 显示全部楼层

自己顶

自己顶

回复

使用道具 举报

11

TA的帖子

0

TA的资源

一粒金砂(中级)

Rank: 2

 楼主| 发表于 2012-12-6 12:53:29 | 显示全部楼层

我的理解

ARM Cortex-M3内核的预取部件具有分支预测功能,可以预取分支目标地址的指令,使分支延迟减少到一个时钟周期。
循环是两条指令,再加一个分支预测的开销,所以循环是3个周期。
但是为什么实际仿真出来是6个呢?!!

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

  • 论坛活动 E手掌握

    扫码关注
    EEWORLD 官方微信

  • EE福利  唾手可得

    扫码关注
    EE福利 唾手可得

小黑屋|手机版|Archiver|电子工程世界 ( 京ICP证 060456

GMT+8, 2017-9-20 22:50 , Processed in 0.249941 second(s), 16 queries , Redis On.

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