程序设计语言与编译ppt课件_10.3 寄存器分配.pptxVIP

程序设计语言与编译ppt课件_10.3 寄存器分配.pptx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

第十章目标代码生成;在目标代码生成的过程中,须要合理分配寄存器。

1. 功能上的需要

指令系统的限制

寄存器数量的限制

2. 性能上的需要

访问内存的速度

访问寄存器的速度

;寄存器的分配

将某寄存器分配给某变量后,对该变量的访问就可以用该寄存器来代替,而不用每次都访问内存。

寄存器的释放

在释放寄存器前,如果变量的值已被修改,则须要先将变量的值回写到内存中。

;三地址码

x=y+z

;提前将Ra分配给y

LOD Rx,x的地址

LOD Rz,z的地址

LOD Rb,(Rz)

LOD Rc,Ra

ADD Rc,Rb

STO (Rx),Rc;为一个新的变量分配寄存器时,可按以下优先级选择寄存器:

1. 未分配给其它变量的寄存器,任选一个。

2. 已分配给其它变量,但其值未被修改的寄存器;

如有多个,选择活跃度较低的变量对应的那个;

先释放寄存器,再将该寄存器分配给新的变量。

3. 已分配给其它变量,其值已被修改的寄存器;

如有多个,选择活跃度较低的变量对应的那个;

先回写变量,再释放寄存器,再将寄存器分配给新的变量。

;gpl.y

load_reg()

get_rreg()

get_areg()

spill_one()

insert_desc()

clear_desc()

……

您可能关注的文档

文档评论(0)

Kaiser + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档