您好,欢迎来到聚文网。
登录
免费注册
网站首页
|
搜索
热搜:
磁力片
|
漫画
|
购物车
0
我的订单
商品分类
首页
幼儿
文学
社科
教辅
生活
销量榜
深入分析GCC
国内不可多得的全面系统介绍GCC设计与实现的书籍,对GCC的总体设计、主要代码架构及实现细节进行了深入的分析和总结。
装帧: 平装
出版社: 机械工业出版社
作者: 王亚刚 编著
出版日期: 2017-02-01
商品条码: 9787111556329
版次: 1
开本: 16开
页数: 537
出版年份: 2017
定价:
¥99
销售价:
登录后查看价格
¥{{selectedSku?.salePrice}}
库存:
{{selectedSku?.stock}}
库存充足
{{item.title}}:
{{its.name}}
加入购物车
立即购买
加入书单
收藏
精选
¥5.83
世界图书名著昆虫记绿野仙踪木偶奇遇记儿童书籍彩图注音版
¥5.39
正版世界名著文学小说名家名译中学生课外阅读书籍图书批发 70册
¥8.58
简笔画10000例加厚版2-6岁幼儿童涂色本涂鸦本绘画本填色书正版
¥5.83
世界文学名著全49册中小学生青少年课外书籍文学小说批发正版
¥4.95
全优冲刺100分测试卷一二三四五六年级上下册语文数学英语模拟卷
¥8.69
父与子彩图注音完整版小学生图书批发儿童课外阅读书籍正版1册
¥24.2
好玩的洞洞拉拉书0-3岁宝宝早教益智游戏书机关立体翻翻书4册
¥7.15
幼儿认字识字大王3000字幼儿园中班大班学前班宝宝早教启蒙书
¥11.55
用思维导图读懂儿童心理学培养情绪管理与性格培养故事指导书
¥19.8
少年读漫画鬼谷子全6册在漫画中学国学小学生课外阅读书籍正版
¥64
科学真好玩
¥12.7
一年级下4册·读读童谣和儿歌
¥38.4
原生态新生代(传统木版年画的当代传承国际研讨会论文集)
¥11.14
法国经典中篇小说
¥11.32
上海的狐步舞--穆时英(中国现代文学馆馆藏初版本经典)
¥21.56
猫的摇篮(精)
¥30.72
幼儿园特色课程实施方案/幼儿园生命成长启蒙教育课程丛书
¥24.94
旧时风物(精)
¥12.04
三希堂三帖/墨林珍赏
¥6.88
寒山子庞居士诗帖/墨林珍赏
¥6.88
苕溪帖/墨林珍赏
¥6.88
楷书王维诗卷/墨林珍赏
¥9.46
兰亭序/墨林珍赏
¥7.74
祭侄文稿/墨林珍赏
¥7.74
蜀素帖/墨林珍赏
¥12.04
真草千字文/墨林珍赏
¥114.4
进宴仪轨(精)/中国古代舞乐域外图书
¥24.94
舞蹈音乐的基础理论与应用
内容简介
本书结合GCC4.4.0源代码,围绕GCC编译过程,详细介绍了GCC的设计框架和实现过程,包括从源代码到AST、从AST到GIMPLE、从GIMPLE到RTL,以及从RTL到终的目标机器代码的详细过程,涉及各个阶段中间表示的详细分析、生成过程,使读者在了解编译原理的基础上进一步掌握其实现的总体流程和实现细节,让更多的读者对编译技术不再只是停留在理论层面,而是学会如何实现一个编译系统实例。
目录
前言
第1章GCC概述1
1.1GCC的产生与发展1
1.2GCC的特点2
1.3GCC代码分析3
第2章GCC源代码分析工具4
2.1vim+ctags代码阅读工具4
2.2GNUgdb调试工具6
2.3GNUbinutils工具8
2.4shell工具及graphviz绘图工具11
2.5GCC调试选项13
第3章GCC总体结构16
3.1GCC的目录结构16
3.2GCC的逻辑结构18
3.3GCC源代码编译20
3.3.1配置21
3.3.2编译23
3.3.3安装25
第4章从源代码到AST/GENERIC26
4.1抽象语法树26
4.2树节点的声明28
4.3树节点结构33
4.3.1structtree_base35
4.3.2structtree_common36
4.3.3常量节点38
4.3.4标识符节点42
4.3.5声明节点44
4.3.6structtree_decl_minimal46
4.3.7structtree_decl_common46
4.3.8structtree_field_decl49
4.3.9structtree_decl_with_rtl55
4.3.10structtree_label_decl55
4.3.11structtree_result_decl56
4.3.12structtree_const_decl57
4.3.13structtree_parm_decl57
4.3.14structtree_decl_with_vis59
4.3.15structtree_var_decl59
4.3.16structtree_decl_non_common62
4.3.17structtree_function_decl62
4.3.18structtree_type_decl64
4.3.19类型节点67
4.3.20tree_list节点68
4.3.21表达式节点71
4.3.22语句节点73
4.3.23其他树节点75
4.4AST输出及图示76
4.5AST的生成83
4.5.1词法分析84
4.5.2词法分析过程90
4.5.3语法分析98
4.5.4语法分析过程99
4.5.5c_parse_file103
4.5.6c_parser_translation_unit105
4.5.7c_parser_external_declaration105
4.5.8c_parser_declaration_or_fndef107
4.5.9c_parser_declspecs112
4.6小结114
第5章从AST/GENERIC到GIMPLE115
5.1GIMPLE115
5.2GIMPLE语句119
5.3GIMPLE的表示与存储122
5.4GIMPLE语句的操作数128
5.5GIMPLE语句序列的基本操作132
5.6GIMPLE的生成135
5.6.1gimplify_function_tree136
5.6.2gimplify_body138
5.6.3gimlify_parameters139
5.6.4gimplify_stmt144
5.6.5gimplify_expr144
5.7GIMPLE转换实例157
5.7.1BIND_EXPR节点的GIMPLE生成158
5.7.2STATEMENT_LIST_EXPR节点的GIMPLE生成159
5.7.3MODIFY_EXPR节点的GIMPLE生成160
5.7.4POSTINCREMENT_EXPR节点的GIMPLE生成162
5.8实例分析172
5.9小结176
第6章GIMPLE处理及其优化177
6.1GCCPass177
6.1.1核心数据结构177
6.1.2Pass的类型179
6.1.3Pass链的初始化182
6.1.4Pass的执行184
6.2Pass列表187
6.3GIMPLEPass实例193
6.3.1pass_remove_useless_stmts193
6.3.2pass_lower_cf195
6.3.3pass_build_cfg197
6.3.4pass_build_cgraph_edges203
6.3.5pass_build_ssa205
6.3.6pass_all_optimizations206
6.3.7pass_expand207
6.4小结207
第7章RTL208
7.1RTL中的对象类型209
7.2RTX_CODE210
7.3RTX类型210
7.4RTX输出格式212
7.5RTX操作数213
7.6RTX的机器模式216
7.7RTX的存储219
7.8RTX表达式222
7.8.1常量225
7.8.2寄存器和内存227
7.8.3算术运算228
7.8.4比较运算230
7.8.5副作用230
7.9IR—RTL232
7.9.1INSN233
7.9.2JUMP_INSN234
7.9.3CALL_INSN235
7.9.4BARRIER235
7.9.5CODE_LABEL236
7.9.6NOTE237
7.10小结238
第8章机器描述文件${target}.md239
8.1机器描述文件240
8.2指令模板241
8.2.1模板名称242
8.2.2RTL模板246
8.2.3条件256
8.2.4输出模板256
8.2.5属性256
8.3定义RTL序列257
8.4指令拆分263
8.5枚举器266
8.5.1mode枚举器266
8.5.2code枚举器268
8.6窥孔优化269
8.6.1define_peephole269
8.6.2define_peephole2270
8.7小结271
第9章机器描述文件${target}.(ch)272
9.1targetm272
9.1.1structgcc_target的定义273
9.1.2targetm的初始化277
9.2编译驱动及选项279
9.2.1编译选项280
9.2.2SPEC语言及SPEC文件281
9.2.3机器相关的编译选项285
9.3存储布局286
9.3.1位顺序和字节顺序286
9.3.2类型宽度287
9.3.3机器模式提升287
9.3.4存储对齐288
9.3.5编程语言中数据类型的存储布局289
9.4寄存器使用290
9.4.1寄存器的基本描述290
9.4.2寄存器分配顺序297
9.4.3机器模式298
9.4.4寄存器类型300
9.5堆栈及函数调用规范描述307
9.5.1堆栈的基本特性309
9.5.2寄存器消除313
9.5.3函数栈帧的管理315
9.5.4参数传递316
9.5.5函数返回值318
9.5.6i386机器栈帧318
9.6寻址方式325
9.7汇编代码分区326
9.8定义输出的汇编语言333
9.8.1汇编代码文件的框架333
9.8.2数据输出336
9.8.3未初始化数据输出336
9.8.4标签输出338
9.8.5指令输出342
9.9机器描述信息的提取343
9.9.1gencode.c347
9.9.2genattr.c348
9.9.3genattrtab.c348
9.9.4genrecog.c349
9.9.5genflag.c352
9.9.6genemit.c353
9.9.7genextract.c354
9.9.8genopinit.c356
9.9.9genoutput.c360
9.9.10genpreds.c362
9.9.11其他363
9.10小结364
第10章从GIMPLE到RTL365
10.1GIMPLE序列365
10.2典型数据结构366
10.3RTL生成的基本过程367
10.3.1变量展开370
10.3.2参数及返回值处理380
10.3.3初始块的处理395
10.3.4基本块的RTL生成398
10.3.5退出块的处理410
10.3.6其他处理411
10.4GIMPLE语句转换成RTL411
10.4.1GIMPLE语句转换的一般过程412
10.4.2GIMPLE_GOTO语句的RTL生成415
10.4.3GIMPLE_ASSIGN语句的RTL生成417
10.5小结432
第11章RTL处理及优化433
11.1RTL处理过程433
11.2特殊虚拟寄存器的实例化435
11.3指令调度437
11.3.1指令调度算法439
11.3.2GCC指令调度的实现440
11.3.3指令调度实例1442
11.3.4指令调度实例2459
11.4统一寄存器分配460
11.4.1基本术语461
11.4.2寄存器分配的主要流程463
11.4.3代码分析466
11.4.4寄存器分配实例1468
11.4.5寄存器分配实例2483
11.5汇编代码生成494
11.5.1汇编代码文件的结构495
11.5.2从RTL到汇编代码499
11.6小结502
第12章支持新的目标处理器503
12.1GCC移植503
12.2PAAG处理器504
12.2.1PAAG处理器指令集505
12.2.2应用二进制接口505
12.3GCC移植的基本步骤506
12.4PAAG机器描述文件(paag.md)507
12.5paag.(ch)文件512
12.5.1存储布局512
12.5.2寄存器使用规范513
12.5.3堆栈布局及堆栈指针514
12.5.4函数调用规范515
12.5.5寻址方式519
12.5.6汇编代码输出521
12.5.7杂项523
12.6PAAG后端注册523
12.7GCC移植测试524
12.8小结526
参考文献527
索引529
摘要
前 言GCC(GNU Compiler Collection,GNU编译器套件)是一套由GNU开发的程序设计语言编译工具,是GNU工程中最重要的组成部分。经过近30年的发展,GCC不仅支持众多的前端编程语言,还支持各种主流的处理器平台和操作系统平台,成为公认的跨平台编译器的事实标准,也成为编译器设计的成功典范。 作为一名GCC编译器的使用者和源码阅读的爱好者,我一直想写一本关于GCC的技术书。 2002年,我开始在Linux系统上进行一些软件开发,GCC就是我使用的编译工具。我一直对从源代码到目标代码的转换过程充满好奇,想知道在这个过程中GCC到底都做了些什么?GCC是如何设计的,那些成千上万个GCC的源代码文件都表示了什么意义?那时我常常幻想,要是能透彻地分析和理解GCC源代码,多好!从那时起,在教学科研之余,我偶尔会翻阅一下GCC的相关源代码,可是看着繁多的GCC源代码,也常常感觉手足无措,真有一种“老虎吃天,无法下爪”的尴尬。于是分析GCC源代码的事情被搁置了,然而那种一探究竟的心情总是挥之不去。 2012年开始,我有了较多的闲暇时间,在经过一段彷徨之后,分析GCC源代码的冲动又一次浮现在脑海。我知道,这次是要来真的了,我要做点自己喜欢的事。 Why?我有空余时间了,我要干些自己感兴趣的事情。在我创建的GCC爱好者交流群中经常有朋友问,有没有介绍GCC的资料呀?大多人都会说,有——请看官方文档!我也去看了看,没错,GCC有比较详细的官方文档,包括gccinternal及用户手册等。然而,这些文档的内容庞杂,缺乏系统分析GCC设计框架和工作流程的内容,并且大多的内容对读者来讲都是零散的,让初学者无所适从。于是我想,为什么不分析一下GCC系统,把GCC的设计实现用一种更清晰明了、更系统的方法介绍给GCC的爱好者呢?What?本书将围绕GCC编译过程,详细介绍从源代码到AST、从AST到GIMPLE、从GIMPLE到RTL,以及从RTL到最终的目标机器汇编代码的详细过程,涉及各个阶段中间表示的详细分析、生成过程。本书提供了大量的图表和实例,展示了GCC编译系统的总体工作流程和工作细节。本书的另外一个特点是结合GCC 4.4.0的源代码进行分析,使读者在了解编译原理的基础上进一步掌握其实现的总体流程和细节,让更多读者对编译技术的认识不再只停留在理论层面,而是向其展示一个编译系统实例的实现过程。 How?GCC源代码涉及的内容非常庞杂,很难在一本书中全面描述,因此本书以GCC中间表示为主线,详细分析GCC从源代码开始,直到生成目标机器汇编代码的整个过程中所使用的三种中间表示(AST、GIMPLE及RTL),并对这三种中间表示的基本概念、生成过程进行详细的描述,对基于GIMPLE和RTL的优化处理进行介绍,从而描述一条从源代码到目标机器汇编代码的清晰路线图。 Who?本书以热爱编译系统理论及其实现的在校大学生、研究生为主要读者对象,也可以作为企业中研发编译系统以及进行编译系统移植的研发工程师的有益参考。 在编写这本书的时候,有一种精神支撑着我,我相信“兴趣”加上“坚持”就是胜利!分析GCC不是一年半载的事情,需要3年、5年,甚至更长时间,不过我可以坚持,我要用我的坚持换来对GCC的深入分析,让更多的GCC爱好者熟悉它、接触它、了解它,更多地参与GCC的开发与维护。 感谢我的爱人和孩子,给了我家的温暖和亲情。感谢病榻上的父亲,虽然他不能和我说话,但他那一双大手,依然经常抚摸在我的头上。感谢年老体弱的母亲,感谢她一直照顾我的父亲,让我知道什么是坚持,什么是不离不弃!感谢西安邮电大学GPU项目组的各位同事在本书的写作中提出的宝贵建议。 本书的写作得到国家自然科学基金重点项目(项目编号:61136002)以及陕西省教育厅科研计划项目(项目编号:14JK1674)资助。 鉴于作者水平有限,在分析和写作本书的过程中也引入了一些个人观点,因此难免有一些理解的偏差和错误,敬请读者批评指正并不吝赐教,如有意见和建议,请联系作者lazy_linux@126.com,在此一并感谢! 王亚刚2016年10月于西安邮电大学
×
Close
添加到书单
加载中...
点此新建书单
×
Close
新建书单
标题:
简介:
蜀ICP备2024047804号
Copyright 版权所有 © jvwen.com 聚文网