URN Logo
UNIX Resources » Linux » China Linux Forum » C/C++编程版 » 21 » 一个GCC内联汇编的问题
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防火墙和代理服务器应用
  文件及打印服务器
  技术培训与认证
  Linux内核技术
  Linux 嵌入技术
  Linux设备驱动程序
  Linux 集群技术
  LINUX平台数据库
  系统和网络安全
  CPU 与 编译器
  系统计算研究所专栏
  Linux下的GUI软件开发
  C/C++编程版
  PHP 技 术
  Java&jsp技术
  Shell编程技术
  Perl 编 程
  Python 编 程
  XML/Web Service 技术
  永远的Unix
  FreeBSD世界
   
一个GCC内联汇编的问题
一个GCC内联汇编的问题 - dz130 [2005-12-01 11:21 | 4,265 byte(s)]
 
Re: 一个GCC内联汇编的问题 - jianliang79 [2005-12-01 12:37 | 193 byte(s)]
 
Re: 一个GCC内联汇编的问题 - dz130 [2005-12-01 14:25 | 19 byte(s)]
 
Subject: 一个GCC内联汇编的问题
Author: dz130    Posted: 2005-12-01 11:21    Length: 4,265 byte(s)
[Original] [Print] [Top]
请看下面一段代码:
static int func_MMX(float * _f, int16_t * s16){
int32_t * f = (int32_t *) _f;
asm volatile(
"movl $-1024, %%esi "
"movq "MANGLE(magicF2W)", %%mm7 "
"1: "
"movq (%1, %%esi), %%mm0 "
"movq 8(%1, %%esi), %%mm1 "
"movq 1024(%1, %%esi), %%mm2 "
"movq 1032(%1, %%esi), %%mm3 "
"psubd %%mm7, %%mm0 "
"psubd %%mm7, %%mm1 "
"psubd %%mm7, %%mm2 "
"psubd %%mm7, %%mm3 "
"packssdw %%mm1, %%mm0 "
"packssdw %%mm3, %%mm2 "
"movq %%mm0, %%mm1 "
"punpcklwd %%mm2, %%mm0 "
"punpckhwd %%mm2, %%mm1 "
"movq %%mm0, (%0, %%esi) "
"movq %%mm1, 8(%0, %%esi) "
"addl $16, %%esi "
" jnz 1b "
"emms "
:: "r" (s16+512), "r" (f+256)
:"%esi", "memory"
);
return 2*256;
}

编译出来的代码是:
push %ebp
mov %esp, %ebp
push %esi
mov 0xc(%ebp),%edx
mov 0x8(%ebp),%eax
add $0x400,%edx
add $0x400,%eax
mov $0xfffffc00,%esi
movq 0x9f5758,%mm7
1:
movq (%eax,%esi,1),%mm0
movq 0x8(%eax,%esi,1),%mm1
movq 0x400(%eax,%esi,1), %mm2
movq 0x408(%eax,%esi,1),%mm3
psubd %mm7,%mm0
psubd %mm7,%mm1
psubd %mm7,%mm2
psubd %mm7,%mm3
packssdw %mm1,%mm0
packssdw $mm3,%mm2
movq %mm0,%mm1
punpcklwd %mm2,%mm0
punpckhwd %mm2,%mm1
movq %mm0,(%edx,%esi,1)
movq %mm1,0x8(%edx,%esi,1)
add $0x10,%esi
jne 1b
emms
pop %esi
mov %$0x200,%eax
pop %ebp
ret

很明显, 编译器将s16放到edx中,将 f 放到eax中,但是编译器根据什么将edx和eax都加上0x400呢?是不是和:: "r" (s16+512), "r" (f+256)这行有关?在这行中,s16+512 和 f+256 是什么意思呢?
[Original] [Print] [Top]
Subject: Re: 一个GCC内联汇编的问题
Author: jianliang79    Posted: 2005-12-01 12:37    Length: 193 byte(s)
[Original] [Print] [Top]
s16 + 512和f+256就是把指针加一个偏移阿,因为s16是指向int16_t的指针,因此s16 + 512要偏移512 * sizeof(int16_t)= 1024(0x400),而f是指向float的指针,因此f+256要偏移256 * sizeof(float)=1024(0x400)。
[Original] [Print] [Top]
Subject: Re: 一个GCC内联汇编的问题
Author: dz130    Posted: 2005-12-01 14:25    Length: 19 byte(s)
[Original] [Print] [Top]
原来如此,多谢指点。
[Original] [Print] [Top]
« Previous thread
请教linux下开发C++程序的代码分析以及性能分析的工具
C/C++编程版
21
Next thread »
紧急求救,大家帮帮看看SCSI的配置,给点建议
     

Copyright © 2007 UNIX Resources Network, All Rights Reserved.      About URN | Privacy & Legal | Help | Contact us
备案序号: 京ICP备05006143    webmaster: webmaster@unixresources.net
This page created on 2008-07-17 03:52:24, cost 0.10392308235168 ms.