URN Logo
UNIX Resources » Linux » China Linux Forum » CPU 与 编译器 » 6 » MIPS跳转指令嵌套的延迟槽问题
announcement 声明: 本页内容为中国Linux论坛的内容镜像,文章的版权以及其他所有的相关权利属于中国Linux论坛和相应文章的作者,如果转载,请注明文章来源及相关版权信息。
Resources
China Linux Forum(finished)
Linux Forum(finished)
FreeBSD China(finished)
linuxforum.net
  业界新闻与评论
  自由软件杂谈
  IT 人生
  Linux软件快递
  翻译作坊
  Linux图书与评论
  GNU Emacs/XEmacs
  Linux 中文环境和中文化
  Linux桌面与办公软件
  Linux 多媒体与娱乐版
  自由之窗Mozilla
  笔记本电脑上的Linux
  Gentoo
  Debian 一族
  网络管理技术
  Linux 安装与入门
  WEB服务器和FTP服务器
  域名服务器和邮件服务器
  Linux防火墙和代理服务器应用
  文件及打印服务器
  技术培训与认证
  Linux内核技术
  Linux 嵌入技术
  Linux设备驱动程序
  Linux 集群技术
  LINUX平台数据库
  系统和网络安全
  CPU 与 编译器
  系统计算研究所专栏
  Linux下的GUI软件开发
  C/C++编程版
  PHP 技 术
  Java&jsp技术
  Shell编程技术
  Perl 编 程
  Python 编 程
  XML/Web Service 技术
  永远的Unix
  FreeBSD世界
   
MIPS跳转指令嵌套的延迟槽问题
MIPS跳转指令嵌套的延迟槽问题 - zyj001et [2005-10-14 22:34 | 953 byte(s)]
 
Re: MIPS跳转指令嵌套的延迟槽问题 - zmingliu [2005-10-16 11:09 | 314 byte(s)]
 
Subject: MIPS跳转指令嵌套的延迟槽问题
Author: zyj001et    Posted: 2005-10-14 22:34    Length: 953 byte(s)
[Original] [Print] [Top]
在看 see mips run的 分支延迟的时候,突然想到 一个问题,如果brach指令是嵌套的呢,即branch的延迟槽中由有一个 branch 指令

比如

jal 1
jal 2
nop


1:
move $4,$3
move $3,$4

2:
XXXXXXX

在 jal 1 指令计算 转移地址的时候,jal 2指令已经进入IF阶段。 在jal 1计算好 转移地址后,程序将跳转到1处, move $4,$3 开始进入IF阶段。 当move $3,$4 开始进入 IF阶段时候,jal 2的转移地址已经计算处,那么就应该调到 2处执行。 也就是说jal 2 后的nop指令是永远没有机会执行的。
流水线如下:




因为我目前也没有 测试环境,所以也无法 写程序来测试。 哪位兄弟知道的, 来讨论一下啊。

----
--
Attached file: 582200-1.JPG
[Original] [Print] [Top]
Subject: Re: MIPS跳转指令嵌套的延迟槽问题
Author: zmingliu    Posted: 2005-10-16 11:09    Length: 314 byte(s)
[Original] [Print] [Top]
这类体系结构的问题,如果怀疑说明自己没有看仔细。一个用的很广的系统是不会出现意想不到的后果的,而且这类问题也没有讨论的意义。我虽然没有实际做过MIPS的系统。但是无论DSP程序还是微码程序这类需要汇编编程,并且需要精确计算cycle的软件,都存在这种问题。关键在于不是所有的指令都可以放在延迟槽中。这类指令通常就包括跳转指令。
----
Only interested in OS RT CPU ACE DOC MM etc. ;-)
[Original] [Print] [Top]
« Previous thread
没有有读gdb源码的兄弟啊?交流下撒
CPU 与 编译器
6
Next thread »
MIPS R3000的 异常入口
     

Copyright © 2007 UNIX Resources Network, All Rights Reserved.      About URN | Privacy & Legal | Help | Contact us
备案序号: 京ICP备05006143    webmaster: webmaster@unixresources.net
This page created on 2008-07-17 03:47:22, cost 0.064974069595337 ms.