一条cltq指令引发的血案

这篇文章是我于2011年左右先在百度博客写了,后来又搞到自己做的博客上,现在又把它放在简书上。

转载请标注来处:http://www.jianshu.com/p/d2e22da3a71b

两个 a.c b.c, a.c里实现了一个函数 void **malloc2d()返回一个void型的二级指针,然后b.c里会调用这个malloc2d的函数,但是在调试的时候始终得不到正确的值,遂用gdb进行调试一番,发现在调用malloc2d过后,rax寄存器的值发生了变化,高32位被截取为0了,我靠,这还了得,猜想会不会是哪把我这个内存给采掉了,我X,百思不得其解。于是乎慢慢的试,先将malloc2d的实现放在了b.c里了,结果是没问题的,这就很纳闷了,难道是跨文件惹的祸,将改变后的二进制文件进行objdump反汇编与原来的二进制的反汇编进行比较,发现原来的在调用malloc2d后多了一条指令cltq

1159   400f75:       e8 8f 03 00 00          callq  401309 <malloc2d>
1160   400f7a:       48 98                  cltq
1161   400f7c:       48 89 05 05 0d 20 00    mov    %rax,0x200d05(%rip)        # 601c88 <case_with_funcid>

这是一条神马指令啊,为什么不是直接将返回值RAX赋给变量呢,为什么要先cltq啊,到底是什么情况啊。
然后再用GDB调试了下原二进制文件,

(gdb) 
0x0000000000400f7a in create_tmp_suite_table ([MySQL](http://lib.csdn.net/base/mysql)=0x7fffffffdde0, suite=0x601c50 "Oglconform_31", 
    cases=0x601c64 "(1.5)") at mysql_operation.c:165
165case_with_funcid = malloc2d(846, 626, sizeof(int), &tmp);
1: x/i $pc
=> 0x400f7a <create_tmp_suite_table+100>:cltq    //下一条要执行的指令
(gdb) p /x $rax    //先 check下 $rax
$3 = 0x7ffff6ebc010
(gdb) si          //执行一条指令cltq
0x0000000000400f7c165case_with_funcid = malloc2d(846, 626, sizeof(int), &tmp);
1: x/i $pc
=> 0x400f7c <create_tmp_suite_table+102>:mov    %rax,0x200d05(%rip)        # 0x601c88 <case_with_funcid>
(gdb) p /x $rax     //再check 下rax
$4 = 0xfffffffff6ebc010

看出来了吧,rax高32位被截了全补1了,什么情况,为什么GCC 出来会多一条没用的CLTQ 指令啊,GOOGLE一下,
http://www.cs.cmu.edu/~fp/courses/15213-s07/misc/asm64-handout.pdf
cltq R[%rax ] <- SignExtend(R[%eax]) Convert %eax to quad word,将$eax转化为4字,不就是RAX了嘛,切,
cltq是有符号数的扩展,如果$eax的最高的32位为1的话,刚RAX的高32扩展后全为1,相反如果$EAX的高位为0的话,则扩展出来后全为0
所以刚刚的$eax扩展后$rax 为0xfffffffff6ebc010多了,

BUT,BUT,BUT, 问题是找到了,但是是什么原因触发了这个cltq指令呢,大牛给出了解释,
http://forum.osdev.org/viewtopic.php?f=1&t=23133

二楼的兄弟给了这样的解释:

My guess is that "heap_sbrk"is not properly declared in the latter case, and thecompiler assumes it is returning an int (32 bits) instead of an uintptr_t (64 bits). Check the inclusion of the header file.

原来在写makefile的时候a.c 直接写的是gcc -c a.c 产生a.o,gcc a.o b.c -o b这样在编译b.c的时候,malloc2d函数会在a.o里找到malloc2d的sysbol,但是它并没有在b.c时申明,所以编译器会默认它返回32位,而我们在用malloc2d的时候会(int **)malloc2d强制转一次为64位(BTW,MY OS IS 64 BIT)的了,所以它要扩展下eax,就这样了,

所以在编译的时候最好加上 -Werror 参数 It will make you a much better developer.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容

  • 【1】7,9,-1,5,( ) A、4;B、2;C、-1;D、-3 分析:选D,7+9=16;9+(-1)=8;(...
    Alex_bingo阅读 18,882评论 1 19
  • NSMutableAttributedString* promiseLabelText= [[NSMutableA...
    没错就是豪哥灬阅读 1,562评论 0 3
  • 下午的风很热 吹到脸上像是汽车尾气 傻明说他最长的恋爱谈了五年 姑娘很漂亮,娇小可爱 更难得的是 每次送姑娘回家 ...
    安歌浩倡阅读 396评论 0 0
  • 我想,我一辈子都不会忘记那一天,父亲躺在血泊里,身上散发着冰冷的气息,母亲已经哭倒在了别人的怀里,我没有哭,我也不...
    空小娱阅读 4,528评论 0 3
  • 我的两位朋友,一位目前是自由职业者,每个月的收入也不菲,另一个朋友,是某金融领域业绩前三的业务员(牛逼的业务员,很...
    老抓阅读 425评论 2 2