URN Logo
UNIX Resources » Linux » China Linux Forum » C/C++编程版 » 4 » 如何看懂objdump得到的汇编,请指点一下初学者,谢谢
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防火墙和代理服务器应用
  文件及打印服务器
  技术培训与认证
  TI专版
  Linux内核技术
  Linux 嵌入技术
  Linux设备驱动程序
  Linux 集群技术
  LINUX平台数据库
  系统和网络安全
  CPU 与 编译器
  系统计算研究所专栏
  Linux下的GUI软件开发
  C/C++编程版
  PHP 技 术
  Java&jsp技术
  Shell编程技术
  Perl 编 程
  Python 编 程
  XML/Web Service 技术
  永远的Unix
  FreeBSD世界
   
如何看懂objdump得到的汇编,请指点一下初学者,谢谢
 
 
 
 
 
 
 
 
 
 
很好 我很欣慰 - teawater [2007-11-29 10:01 | 0 byte(s)]
 
 
 
 
Subject: 如何看懂objdump得到的汇编,请指点一下初学者,谢谢
Author: rocky1972    Posted: 2007-11-23 17:13    Length: 5,183 byte(s)
[Original] [Print] [Top]
大家好,在学习位段的时候看到这段代码objdump的结果,其中很是不解。

代码如下:

struct {
short a:4;
short b:5;
short c:7;
} t;

int main()
{
t.a = 1;
t.b = 2;
t.c = 3;

printf(“size: %d ”, sizeof(t));
printf(%d ”, t.a);
printf(%d ”, t.b);
printf(%d ”, t.c);

}


下面是别人objdump的结果和一些注释:
t.a = 1;  是这样的                 

<<<<<<<<<<如何知道下面这段汇编是t.a=1产生的

80483a0: 0f b7 05 d4 96 04 08 movzwl 0x80496d4,%eax
80483a7: 66 89 45 e8 mov %ax,0xffffffe8(%ebp)
80483ab: 8b 45 e8 mov 0xffffffe8(%ebp),%eax
80483ae: 83 e0 f0 and $0xfffffff0,%eax
80483b1: 83 c8 01 or $0x1,%eax
80483b4: 66 89 45 e8 mov %ax,0xffffffe8(%ebp)
80483b8: 8b 45 e8 mov 0xffffffe8(%ebp),%eax
80483bb: 66 a3 d4 96 04 08 mov %ax,0x80496d4


1、        movzwl 0x80496d4, %eax  

取得 t 值放在 eax 中,在这里可以看出,sizeof(t)为2, 也就是 word size

2、        and $0xfffffff0, %eax

or $0x1, %eax
保留低4位, 然后置为1

3、        mov %ax, 0x80496d4 

回写 t 值,t.a 定义为4个位,经过这3步,从而使 t 的低4位置为1。

下面是我自己尝试objdump的结果:

[root@localhost c_work]# objdump -d bit.o

bit.o: file format elf32-i386

Disassembly of section .text:

00000000 <main>:
0: 8d 4c 24 04 lea 0x4(%esp),%ecx
4: 83 e4 f0 and $0xfffffff0,%esp
7: ff 71 fc pushl 0xfffffffc(%ecx)
a: 55 push %ebp
b: 89 e5 mov %esp,%ebp
d: 51 push %ecx
e: 83 ec 14 sub $0x14,%esp
11: 0f b6 05 00 00 00 00 movzbl 0x0,%eax
18: 83 e0 f0 and $0xfffffff0,%eax
1b: 83 c8 01 or $0x1,%eax
1e: a2 00 00 00 00 mov %al,0x0
23: 0f b7 05 00 00 00 00 movzwl 0x0,%eax
2a: 66 25 0f fe and $0xfe0f,%ax
2e: 83 c8 20 or $0x20,%eax
31: 66 a3 00 00 00 00 mov %ax,0x0
37: 0f b6 05 01 00 00 00 movzbl 0x1,%eax
3e: 83 e0 01 and $0x1,%eax
41: 83 c8 06 or $0x6,%eax
44: a2 01 00 00 00 mov %al,0x1
49: c7 44 24 04 04 00 00 movl $0x4,0x4(%esp)
50: 00
51: c7 04 24 00 00 00 00 movl $0x0,(%esp)
58: e8 fc ff ff ff call 59 <main+0x59>
5d: 0f b6 05 00 00 00 00 movzbl 0x0,%eax
64: c1 e0 04 shl $0x4,%eax
67: c0 f8 04 sar $0x4,%al
6a: 0f be c0 movsbl %al,%eax
6d: 89 44 24 04 mov %eax,0x4(%esp)
71: c7 04 24 0e 00 00 00 movl $0xe,(%esp)
78: e8 fc ff ff ff call 79 <main+0x79>
7d: 0f b7 05 00 00 00 00 movzwl 0x0,%eax
84: c1 e0 07 shl $0x7,%eax
87: 66 c1 f8 0b sar $0xb,%ax
8b: 0f be c0 movsbl %al,%eax
8e: 89 44 24 04 mov %eax,0x4(%esp)
92: c7 04 24 16 00 00 00 movl $0x16,(%esp)
99: e8 fc ff ff ff call 9a <main+0x9a>
9e: 0f b6 05 01 00 00 00 movzbl 0x1,%eax
a5: d0 f8 sar %al
a7: 0f be c0 movsbl %al,%eax
aa: 89 44 24 04 mov %eax,0x4(%esp)
ae: c7 04 24 1e 00 00 00 movl $0x1e,(%esp)
b5: e8 fc ff ff ff call b6 <main+0xb6>
ba: 83 c4 14 add $0x14,%esp
bd: 59 pop %ecx
be: 5d pop %ebp
bf: 8d 61 fc lea 0xfffffffc(%ecx),%esp
c2: c3 ret


小弟敢问一下:
1 学好C,需要看懂objdump产生的代码吗?
2 如何看懂这些汇编代码?


谢谢:)
[Original] [Print] [Top]
Subject: Re: 如何看懂objdump得到的汇编,请指点一下初学者,谢谢
Author: teawater    Posted: 2007-11-26 12:52    Length: 32 byte(s)
[Original] [Print] [Top]
1.不需要
2.学习i386汇编
----
科学家会武术 流氓都挡不住
[Original] [Print] [Top]
Subject: Re: 如何看懂objdump得到的汇编,请指点一下初学者,谢谢
Author: KernelNewbie    Posted: 2007-11-26 15:59    Length: 101 byte(s)
[Original] [Print] [Top]
我刚看书时发现这种格式的输出,正不明白是什么工具输出的呢,发现LZ的帖子,原来是objdump嘿嘿,谢谢LZ啦!
----
用一生来做程序
[Original] [Print] [Top]
Subject: Re: 如何看懂objdump得到的汇编,请指点一下初学者,谢谢
Author: IN_FLAMES    Posted: 2007-11-26 22:12    Length: 70 byte(s)
[Original] [Print] [Top]
objdump都不知道啊....
看来你应该去多学习而不是到IT人生灌水...
----
CLF最大的马甲
[Original] [Print] [Top]
Subject: Re: 如何看懂objdump得到的汇编,请指点一下初学者,谢谢
Author: rocky1972    Posted: 2007-11-27 11:30    Length: 104 byte(s)
[Original] [Print] [Top]
针对一楼的问题,熟悉objdump的朋友能否讲讲,给出一个简单的,入门级的HOWTO也可以!
小弟先谢过了:)
[Original] [Print] [Top]
Subject: Re: 如何看懂objdump得到的汇编,请指点一下初学者,谢谢
Author: IN_FLAMES    Posted: 2007-11-27 11:58    Length: 33 byte(s)
[Original] [Print] [Top]
man objdump
info objdump
----
CLF最大的马甲
[Original] [Print] [Top]
Subject: Re: 如何看懂objdump得到的汇编,请指点一下初学者,谢谢
Author: KernelNewbie    Posted: 2007-11-27 16:55    Length: 21 byte(s)
[Original] [Print] [Top]
多谢政委教诲! 会的。
----
用一生来做程序
[Original] [Print] [Top]
Subject: Re: 如何看懂objdump得到的汇编,请指点一下初学者,谢谢
Author: IN_FLAMES    Posted: 2007-11-28 16:36    Length: 19 byte(s)
[Original] [Print] [Top]
panjet才是政委.....
----
CLF最大的马甲
[Original] [Print] [Top]
Subject: Re: 如何看懂objdump得到的汇编,请指点一下初学者,谢谢
Author: KernelNewbie    Posted: 2007-11-28 20:14    Length: 45 byte(s)
[Original] [Print] [Top]
谨尊前辈教诲!

PS:特此更正
----
用一生来做程序
[Original] [Print] [Top]
Subject: Re: 如何看懂objdump得到的汇编,请指点一下初学者,谢谢
Author: wheelz    Posted: 2007-11-29 00:05    Length: 22 byte(s)
[Original] [Print] [Top]
你这是煽动小冷篡权啊。
----
[Original] [Print] [Top]
Subject: Re: 如何看懂objdump得到的汇编,请指点一下初学者,谢谢
Author: KernelNewbie    Posted: 2007-11-29 09:07    Length: 79 byte(s)
[Original] [Print] [Top]
嘿嘿,不敢:)

PS:这个线索不能再跟我,否则该移到别的版了:)
----
用一生来做程序
[Original] [Print] [Top]
Subject: 很好 我很欣慰
Author: teawater    Posted: 2007-11-29 10:01    Length: 0 byte(s)
[Original] [Print] [Top]
----
科学家会武术 流氓都挡不住
[Original] [Print] [Top]
Subject: Re: 如何看懂objdump得到的汇编,请指点一下初学者,谢谢
Author: freelilo    Posted: 2007-11-30 13:55    Length: 22 byte(s)
[Original] [Print] [Top]
我的楼上又放水了!!!
----
吃自助餐的最高境界,扶墙进,扶墙出。
[Original] [Print] [Top]
Subject: Re: 如何看懂objdump得到的汇编,请指点一下初学者,谢谢
Author: skyjump    Posted: 2007-12-03 13:47    Length: 51 byte(s)
[Original] [Print] [Top]
可以先看看<深入理解计算机系统>这本书.
[Original] [Print] [Top]
« Previous thread
What Every Programmer Should Know About Memory
C/C++编程版
4
Next thread »
一个最简单的线程程序,居然出现段错误,请大家帮忙看看啊!
     

Copyright © 2007~2009 UNIX Resources Network, All Rights Reserved.      About URN | Privacy & Legal | Help | Contact us
webmaster: webmaster@unixresources.net
This page created on 2009-09-07 16:43:27, cost 0.0225169658661 ms.