青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

天衣有縫

冠蓋滿京華,斯人獨(dú)憔悴~
posts - 35, comments - 115, trackbacks - 0, articles - 0
   :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

fpu, mmx及sse的一些 介紹(原創(chuàng))

Posted on 2007-04-18 15:57 天衣有縫 閱讀(4697) 評論(2)  編輯 收藏 引用 所屬分類: program
為什么要需要FPU和MMX/SSE?
提供了SIMD環(huán)境(single instruction multi data),即單指令多數(shù)據(jù)。
內(nèi)嵌浮點(diǎn)運(yùn)算單元,64及128位寄存器等。甚至sin/cos等數(shù)學(xué)函數(shù)也囊括其中,
著名的xvid項(xiàng)目就是使用gcc編譯后使用MMX/SSE優(yōu)化匯編的典型案例。

轉(zhuǎn)載請注明原創(chuàng):http://m.shnenglu.com/jinglexy
msn and mail: jinglexy at yahoo dot com dot cn 上海體育館2007.4.18

FPU: 8個80位浮點(diǎn)寄存器(數(shù)據(jù)),16位狀態(tài)寄存器,16位控制寄存器,16為標(biāo)識寄存器。
     使用FPU指令對這些寄存器進(jìn)行操作,這些寄存器構(gòu)成一個循環(huán)棧,st7棧底,st0棧頂,
     當(dāng)一個值被壓入時,被存入st0,原來st0中的值被存入st7
MMX: 將8個FPU寄存器重命名為8個64位MMX寄存器,即mm0到mm7。
     57條MMX指令,加快了整形浮點(diǎn)運(yùn)算,但是對于復(fù)雜浮點(diǎn)運(yùn)算無幫助

SSE: 8個128位寄存器(從xmm0到xmm7),MXSCR寄存器,EFLAGS寄存器,專有指令(復(fù)雜浮點(diǎn)運(yùn)算)
SSE2: 寄存器和SSE相同,增加了5種數(shù)據(jù)類型(都是128位),專有指令
SSE3: 僅增加了幾個新的指令

由于MMX使用的寄存器影射到FPU寄存器上,所以MMX指令執(zhí)行前,需要保存FPU堆棧。

示例1,F(xiàn)PU寄存器及指令使用(下面所有程序都使用at&t風(fēng)格匯編):
data1:
        .byte 0x34, 0x12, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
data2:
        .byte 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
.section .text
.globl _start
_start:
        nop
        fbld  data1     壓入st0
        fimul data2     st0中的值和data2相乘,保存在st0中
        fbstp data1     st0彈出到內(nèi)存44


示例2, SSE寄存器及指令使用
.lcomm data 16
value1:
        .float 12.34, 2345.543, -3493.2, 0.44901
value2:
        .float -54439.234, 23231.4, 1.0098, 0.000003
.section .text
.globl _start
_start:
        movups value1, %xmm0
        movups value2, %xmm1
        movups %xmm0, %xmm2
        movups %xmm0, data


Feedback

# re: fpu, mmx及sse的一些 介紹(原創(chuàng))  回復(fù)  更多評論   

2008-02-19 14:47 by 海楓
你好,我最近也在看FPU的資料(Intel CPU的官方文檔)

想向你請教一下:
FPU,SEE和MMX是不是有重疊的部分呢?

在Intel CPU下的GCC對于浮點(diǎn)計算部分代碼是不是轉(zhuǎn)換上只用FPU的指令呢?
下面是我在Linux下跑的一個例子,前一部分代碼是C源代碼,后一部分代碼是GCC處理后的相應(yīng)匯編代碼,我發(fā)現(xiàn)里面只有涉及FPU的東西,而沒有MMX和SEE。

ylin@ylin:~/program/c$ cat double.c

double sum(double s1, double s2)
{
int i = 1;
double c = 3.0;
c += s1;
c += s2;
c += i;

return c;
}


void test()
{
sum(1.0, 2.0);
}
ylin@ylin:~/program/c$ cat double.s
.file "double.c"
.section .rodata
.align 8
.LC0:
.long 0
.long 1074266112
.text
.globl sum
.type sum, @function
sum:
pushl %ebp
movl %esp, %ebp
subl $32, %esp
movl 8(%ebp), %eax
movl %eax, -24(%ebp)
movl 12(%ebp), %eax
movl %eax, -20(%ebp)
movl 16(%ebp), %eax
movl %eax, -32(%ebp)
movl 20(%ebp), %eax
movl %eax, -28(%ebp)
movl $1, -4(%ebp)
fldl .LC0
fstpl -16(%ebp)
fldl -16(%ebp)
faddl -24(%ebp)
fstpl -16(%ebp)
fldl -16(%ebp)
faddl -32(%ebp)
fstpl -16(%ebp)
fildl -4(%ebp)
fldl -16(%ebp)
faddp %st, %st(1)
fstpl -16(%ebp)
fldl -16(%ebp)
leave
ret
.size sum, .-sum
.section .rodata
.align 8
.LC2:
.long 0
.long 1073741824
.text
.globl test
.type test, @function
test:
pushl %ebp
movl %esp, %ebp
subl $16, %esp
fldl .LC2
fstpl 8(%esp)
fld1
fstpl (%esp)
call sum
fstp %st(0)
leave
ret
.size test, .-test
.ident "GCC: (GNU) 4.1.2 (Ubuntu 4.1.2-0ubuntu4)"
.section .note.GNU-stack,"",@progbits

# re: fpu, mmx及sse的一些 介紹(原創(chuàng))[未登錄]  回復(fù)  更多評論   

2008-03-19 10:44 by 補(bǔ)考少年
[b]原始短消息:[/b] [url=http://bbs.chinaunix.net/pm.php?action=view&folder=inbox&pmid=757158]你好![/url]
[quote]我在你的博客中有留言??!
想問你個問題!
期待你的回復(fù)??![/quote]


很抱歉,才看到你的短信
FPU,SEE和MMX是不是有重疊的部分呢?
你是說寄存器重疊嗎?fpu和mmx使用相同的寄存器,名字不同,使用任意一個之前最好保存相關(guān)上下文寄存器。
sse和sse2只有比較新的cpu(pII以上)才支持,為了保證兼容性,默認(rèn)編譯器不會使用它。
gcc幫助中有:
i386 and x86-64 Options -mtune=cpu-type -march=cpu-type -mfp-
math=unit -masm=dialect -mno-fancy-math-387 -mno-fp-ret-in-387
-msoft-float -msvr3-shlib -mno-wide-multiply -mrtd -malign-dou-
ble -mpreferred-stack-boundary=num -mmmx -msse -msse2 -msse3
-m3dnow -mthreads -mno-align-stringops -minline-all-stringops
-mpush-args -maccumulate-outgoing-args -m128bit-long-double
-m96bit-long-double -mregparm=num -momit-leaf-frame-pointer
-mno-red-zone -mno-tls-direct-seg-refs -mcmodel=code-model -m32
-m64
就像沒有fpu的時候使用libc中軟浮點(diǎn)一樣,默認(rèn)gcc對一些復(fù)雜算法使用fpu指令和軟件算法來解決
可以比較一下:
gcc -c double.c -o double -msse2
objdump -d double
gcc -c double.c -o double -m3dnow
objdump -d double
對優(yōu)化的一些猜測:針對各個平臺編譯一套dll或.so(不同的編譯優(yōu)化選項(xiàng)),然后啟動時判斷平臺,加載不同的dll

具體的我也沒深入研究過,都是一知半解,希望對你有幫助
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            9色porny自拍视频一区二区| 亚洲视频导航| 老司机久久99久久精品播放免费| 亚洲精品三级| 欧美深夜福利| 久久综合网络一区二区| 99伊人成综合| 一本大道久久a久久综合婷婷| 欧美日韩精品欧美日韩精品| 亚洲图片激情小说| 一区二区三区 在线观看视| 欧美日韩在线看| 香港成人在线视频| 欧美一区二区三区在线播放| 国产一区二区中文| 美女爽到呻吟久久久久| 欧美1区2区3区| 亚洲永久在线观看| 亚洲欧美日韩一区二区| 在线观看视频免费一区二区三区| 欧美mv日韩mv国产网站| 欧美精品午夜| 欧美怡红院视频一区二区三区| 久久国内精品视频| 日韩视频一区二区三区在线播放| 日韩视频第一页| 国产一区二区欧美日韩| 91久久精品视频| 欧美激情免费观看| 久久aⅴ国产紧身牛仔裤| 久久久伊人欧美| 亚洲综合国产| 女人色偷偷aa久久天堂| 一区二区三区欧美亚洲| 欧美影院在线| 中国成人黄色视屏| 久久久久久久久久久成人| 国产精品99久久久久久久vr| 国产精品永久免费在线| 激情自拍一区| 亚洲综合第一页| 亚洲精选在线观看| 久久激情视频免费观看| 亚洲天堂久久| 裸体歌舞表演一区二区| 亚洲欧美日韩综合国产aⅴ| 美女视频一区免费观看| 久久精品91久久香蕉加勒比 | 最新精品在线| 午夜在线观看免费一区| 亚洲人成在线观看网站高清| 亚洲欧美资源在线| 亚洲网站在线播放| 欧美激情第五页| 麻豆成人在线播放| 国产精品美女www爽爽爽视频| 欧美国产专区| 在线看日韩欧美| 久久精品免费看| 欧美有码在线观看视频| 国产精品v日韩精品v欧美精品网站| 欧美成人一区在线| 狠狠色丁香婷婷综合| 亚洲一区在线视频| 亚洲欧美日韩国产一区二区三区| 欧美国产视频日韩| 亚洲福利视频二区| 亚洲国产精品综合| 另类天堂视频在线观看| 麻豆久久婷婷| 亚洲成人中文| 久久亚洲视频| 亚洲国产经典视频| 欧美国产日韩一区| 久久精品一区二区三区不卡牛牛 | 亚洲性xxxx| 欧美成人精品| 欧美风情在线| 最新中文字幕一区二区三区| 久久亚洲一区二区| 欧美国产在线观看| 最新国产成人av网站网址麻豆| 久久九九免费| 久久国产一区二区| 影音先锋久久久| 鲁大师影院一区二区三区| 欧美电影免费观看高清| 亚洲电影下载| 欧美精品色网| 亚洲午夜三级在线| 久久久亚洲综合| 亚洲第一页自拍| 欧美激情日韩| 日韩亚洲欧美在线观看| 亚洲欧美日韩精品一区二区 | 久久精品五月| 亚洲国产欧美日韩精品| 一区二区三区**美女毛片| 欧美日韩久久久久久| 一本久久a久久精品亚洲| 欧美一区二区三区视频免费播放| 国产日韩欧美在线看| 麻豆精品精品国产自在97香蕉| 亚洲人成77777在线观看网| 午夜精品福利视频| 一色屋精品亚洲香蕉网站| 久久久久久久久久看片| 亚洲国产91精品在线观看| 一区二区三区高清不卡| 国产一二三精品| 亚洲一区免费网站| 在线视频欧美日韩精品| 久久亚洲精品伦理| 中文久久精品| 在线观看精品视频| 欧美亚洲成人免费| 久久这里有精品15一区二区三区 | 激情六月婷婷综合| 欧美日韩国产二区| 久久精品亚洲| 亚洲欧美一区二区三区在线 | 一区二区三区免费网站| 国产一区在线观看视频| 欧美日韩高清区| 亚久久调教视频| 一区二区三区色| 亚洲黄色在线视频| 久久亚洲精选| 午夜亚洲福利| 亚洲一区免费网站| 亚洲丝袜av一区| 亚洲激情一区| 亚洲大片av| 国产精品一香蕉国产线看观看| 欧美jjzz| 久久艳片www.17c.com| 欧美亚洲日本网站| 午夜国产欧美理论在线播放| 99这里只有久久精品视频| 亚洲国产精品视频| 麻豆视频一区二区| 欧美中文字幕在线| 欧美一区二区三区视频免费| 午夜国产不卡在线观看视频| 亚洲影院免费| 亚洲免费视频成人| 亚洲手机视频| 亚洲男同1069视频| 亚洲欧美视频| 久久aⅴ国产紧身牛仔裤| 亚洲欧美文学| 欧美中文字幕视频在线观看| 亚洲一区综合| 一区二区三区日韩精品视频| 亚洲人成久久| 午夜精彩视频在线观看不卡| 亚洲精品孕妇| 伊人婷婷欧美激情| 在线免费观看日本欧美| 在线观看91精品国产入口| …久久精品99久久香蕉国产| 亚洲高清视频中文字幕| 最新国产成人av网站网址麻豆| 亚洲国产一区二区精品专区| 亚洲电影免费观看高清完整版在线观看 | 一区二区高清| 亚洲理伦在线| 亚洲视频免费观看| 西西人体一区二区| 久久精品理论片| 美女网站在线免费欧美精品| 欧美精品自拍| 国产精品久久久久久模特| 国产精品免费小视频| 国产精品香蕉在线观看| 国产日韩一区二区| 在线免费观看欧美| 亚洲午夜精品国产| 欧美在线视频一区二区| 欧美国产在线电影| 亚洲一区二区精品| 久久精品人人做人人爽| 欧美精品三区| 国产在线精品成人一区二区三区 | 欧美精品免费观看二区| 国产精品成人免费视频| 黄色一区三区| 在线免费高清一区二区三区| 亚洲久久一区二区| 亚洲午夜未删减在线观看| 欧美在线视屏| 99re66热这里只有精品4| 亚洲一区二区三区乱码aⅴ蜜桃女| 欧美中文字幕在线视频| 欧美日韩国产在线播放| 国产一区欧美| 午夜精品久久99蜜桃的功能介绍| 欧美激情欧美狂野欧美精品| 亚洲欧美日韩视频二区| 欧美福利视频在线|