MMX汇编指令优化

举报
风吹稻花香 发表于 2021/06/04 23:29:33 2021/06/04
【摘要】 MMX和SSE都是INTEL开发的基于SIMD(单指令多数据流)的技术。所谓单指令多数据流是指可以用一条指令可以完成多个数据的操作。虽然64位系统已经推出,但是我们大部分都是使用32位系统,所以如果要完成两个128位的相加运算,用普通32位指令很明显要执行4条相加指令,而基于64位的MMX指令只需要执行两次即可完成,更强大的SSE能一次处理128位,故一次就可以完成操作,所以...

下面举一个例子:
在VC 6 SP6中可以直接在内联汇编中使用mmx指令,而且调试时也能查看MMX寄存器
__int16 a[]={1,2,3,4}
__int16 b[]={5,6,7,8}
_asm{
movq mm0,a                                         //将数组a中的4个数一次存入mm0
movq mm1,b                                        //将数组b中的4个数一次存入mm0
paddsw mm0,mm1                               //16位带符号的饱和相加,结果存在mm0中
movq a,mm0                                        //再把mm0中的结果存放在数组a中  
emms                                                   //千万别忘了,擦干净
}

也可以不用内联汇编直接用函数,MS的最新的SDK和INTEL的编译器都支持这种方式
#include                             //使用所必须包含的头文件
__m64 a=_mm_set_pi16(1, 2, 3, 4);       //向a中写入4个16位的整数
__m64 b=_mm_set_pi16(5, 6, 7, 8);      //最后一位写入最低位,即8写入最低位
a=_m_paddsw(a,b);                               //完成16位加法运算
_m_empty;                                             //一样不要忘记擦PP,嘿嘿

以上只是最基本最简单的介绍,MMX一共有57条指令,包括基本算术运算指令,比较指令,转换指令,逻辑指令,位移和传输指令,此处就不一一列举,详细的指令介绍请参看INTEL的官方网站。但请记住MMX是针对整数运算的,千万不要用于浮点运算,浮点运算要用更为强大的SSE指令完成

文章来源: blog.csdn.net,作者:网奇,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/jacke121/article/details/54668477

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。