03_12-03-_Code_Generation_II_18m08s

03_12-03-_Code_Generation_II_18m08s

ID:39713724

大小:846.76 KB

页数:15页

时间:2019-07-09

03_12-03-_Code_Generation_II_18m08s_第1页
03_12-03-_Code_Generation_II_18m08s_第2页
03_12-03-_Code_Generation_II_18m08s_第3页
03_12-03-_Code_Generation_II_18m08s_第4页
03_12-03-_Code_Generation_II_18m08s_第5页
资源描述:

《03_12-03-_Code_Generation_II_18m08s》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、CompilersCodeGenerationIIAlexAikenCodeGenerationIIAlanguagewithintegersandintegeroperationsPD;P

2、DDdefid(ARGS)=E;ARGSid,ARGS

3、idEint

4、id

5、ifE=EthenEelseE1234

6、E+E

7、E–E

8、id(E,…,E)12121nAlexAikenCodeGenerationII•Codeforfunctioncallsandfunctiondefinitionsdep

9、endsonthelayoutoftheAR•AverysimpleARsufficesforthislanguage:–Theresultisalwaysintheaccumulator•NoneedtostoretheresultintheAR–Theactivationrecordholdsactualparameters•Forf(x,…,x)pushx,…,xonthestack1nn1•ThesearetheonlyvariablesinthislanguageAlexAikenCodeG

10、enerationII•Thestackdisciplineguaranteesthatonfunctionexit$spisthesameasitwasonfunctionentry–Noneedforacontrollink•Weneedthereturnaddress•Apointertothecurrentactivationisuseful–Thispointerlivesinregister$fp(framepointer)AlexAikenCodeGenerationII•Summary

11、:Forthislanguage,anARwiththecaller’sframepointer,theactualparameters,andthereturnaddresssuffices•Picture:Consideracalltof(x,y),theARis:FPoldfpyARoffxSPAlexAikenCodeGenerationII•Thecallingsequenceistheinstructions(ofbothcallerandcallee)tosetupafunctionin

12、vocation•Newinstruction:jallabel–Jumptolabel,saveaddressofnextinstructionin$ra–Onotherarchitecturesthereturnaddressisstoredonthestackbythe“call”instructionAlexAikenCodeGenerationIIcgen(f(e,…,e))=1n•Thecallersavesitsvalueoftheframesw$fp0($sp)pointeraddiu

13、$sp$sp-4•Thenitsavestheactualparametersincgen(e)nreverseordersw$a00($sp)addiu$sp$sp-4•Finallythecallersavesthereturn…addressinregister$racgen(e1)•TheARsofaris4*n+4byteslongsw$a00($sp)addiu$sp$sp-4jalf_entryAlexAikenCodeGenerationII•Newinstruction:jrreg–

14、Jumptoaddressinregisterregcgen(deff(x1,…,xn)=e)=•Note:Theframepointerpointstothemove$fp$sptop,notbottomoftheframesw$ra0($sp)•Thecalleepopsthereturnaddress,theaddiu$sp$sp-4actualargumentsandthesavedvalueoftheframepointercgen(e)•z=4*n+8lw$ra4($sp)addiu$sp

15、$spzlw$fp0($sp)jr$raAlexAikenCodeGenerationIIBeforecallOnentryBeforeexitAftercallFPFPFPSPoldfpoldfpSPyyxxSPFPreturnSPAlexAikenCodeGenerationII•Variablereferencesarethelastconstruct•The“variables”ofafunctionarejustitsparameters–Th

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。
相关文章
更多
相关标签