• <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>

            歲月流轉,往昔空明

            C++博客 首頁 新隨筆 聯系 聚合 管理
              118 Posts :: 3 Stories :: 413 Comments :: 0 Trackbacks

            沒啥好說的,有圖有真相。上個逐像素光照的圖。

             

            基本上編譯器的架構已經確定了,好多功能亟待實現。

            尋合作者。

             

            XY][6}U9SVQ_5RTWG8(6}18

             

            編譯器生成的LLVM未優化代碼。

            define void @"Mvs_main@@QSVSIn@@"(%.s.stri* %.arg.stri, %.s.bufi* %.arg.bufi, %.s.stro* %.arg.stro, %.s.bufo* %.arg.bufo) {
            .init.vargs:
              %in = alloca %VSIn, align 16
              %0 = load %.s.stri* %.arg.stri, align 4
              %1 = extractvalue %.s.stri %0, 0
              %2 = load <4 x float>* %1, align 4
              %3 = getelementptr %VSIn* %in, i32 0, i32 0
              store <4 x float> %2, <4 x float>* %3, align 4
              %4 = load %.s.stri* %.arg.stri, align 4
              %5 = extractvalue %.s.stri %4, 1
              %6 = load <4 x float>* %5, align 4
              %7 = getelementptr %VSIn* %in, i32 0, i32 1
              store <4 x float> %6, <4 x float>* %7, align 4
              br label %.entry
            
            .entry:                                           ; preds = %.init.vargs
              br label %.body
            
            .body:                                            ; preds = %.entry
              %out = alloca %.s.bufo, align 16
              %in1 = load %VSIn* %in, align 4
              %8 = extractvalue %VSIn %in1, 1
              %9 = getelementptr %.s.bufo* %out, i32 0, i32 1
              store <4 x float> %8, <4 x float>* %9, align 4
              %in2 = load %VSIn* %in, align 4
              %10 = extractvalue %VSIn %in2, 0
              %11 = load %.s.bufi* %.arg.bufi, align 4
              %12 = extractvalue %.s.bufi %11, 0
              %13 = call <4 x float> @"Mmul@@QV4F@@QM44F@@"(<4 x float> %10, [4 x <4 x float>] %12)
              %14 = getelementptr %.s.bufo* %out, i32 0, i32 0
              store <4 x float> %13, <4 x float>* %14, align 4
              %15 = load %.s.bufi* %.arg.bufi, align 4
              %16 = extractvalue %.s.bufi %15, 1
              %in3 = load %VSIn* %in, align 4
              %17 = extractvalue %VSIn %in3, 0
              %18 = fsub <4 x float> %16, %17
              %19 = getelementptr %.s.bufo* %out, i32 0, i32 2
              store <4 x float> %18, <4 x float>* %19, align 4
              %20 = load %.s.bufi* %.arg.bufi, align 4
              %21 = extractvalue %.s.bufi %20, 2
              %in4 = load %VSIn* %in, align 4
              %22 = extractvalue %VSIn %in4, 0
              %23 = fsub <4 x float> %21, %22
              %24 = getelementptr %.s.bufo* %out, i32 0, i32 3
              store <4 x float> %23, <4 x float>* %24, align 4
              %25 = load %.s.bufi* %.arg.bufi, align 4
              %26 = extractvalue %.s.bufi %25, 3
              %in5 = load %VSIn* %in, align 4
              %27 = extractvalue %VSIn %in5, 0
              %28 = fsub <4 x float> %26, %27
              %29 = getelementptr %.s.bufo* %out, i32 0, i32 4
              store <4 x float> %28, <4 x float>* %29, align 4
              %out6 = load %.s.bufo* %out, align 4
              %30 = extractvalue %.s.bufo %out6, 0
              %31 = getelementptr %.s.bufo* %.arg.bufo, i32 0, i32 0
              store <4 x float> %30, <4 x float>* %31, align 4
              %out7 = load %.s.bufo* %out, align 4
              %32 = extractvalue %.s.bufo %out7, 1
              %33 = getelementptr %.s.bufo* %.arg.bufo, i32 0, i32 1
              store <4 x float> %32, <4 x float>* %33, align 4
              %out8 = load %.s.bufo* %out, align 4
              %34 = extractvalue %.s.bufo %out8, 2
              %35 = getelementptr %.s.bufo* %.arg.bufo, i32 0, i32 2
              store <4 x float> %34, <4 x float>* %35, align 4
              %out9 = load %.s.bufo* %out, align 4
              %36 = extractvalue %.s.bufo %out9, 3
              %37 = getelementptr %.s.bufo* %.arg.bufo, i32 0, i32 3
              store <4 x float> %36, <4 x float>* %37, align 4
              %out10 = load %.s.bufo* %out, align 4
              %38 = extractvalue %.s.bufo %out10, 4
              %39 = getelementptr %.s.bufo* %.arg.bufo, i32 0, i32 4
              store <4 x float> %38, <4 x float>* %39, align 4
              ret void
                                                              ; No predecessors!
              ret void
            }
            
            JITed Code(x64):
            0000000000250010  push        rbp  
            0000000000250011  mov         rbp,rsp  
            0000000000250014  push        rsi  
            0000000000250015  push        rdi  
            0000000000250016  push        rbx  
            0000000000250017  sub         rsp,78h  
            000000000025001B  mov         rax,qword ptr [rcx]  
            000000000025001E  movups      xmm0,xmmword ptr [rax]  
            0000000000250021  movaps      xmmword ptr [rbp-40h],xmm0  
            0000000000250025  mov         rax,qword ptr [rcx+8]  
            0000000000250029  movups      xmm0,xmmword ptr [rax]  
            000000000025002C  mov         rsi,r9  
            000000000025002F  mov         rdi,rdx  
            0000000000250032  movaps      xmmword ptr [rbp-30h],xmm0  
            0000000000250036  mov         rbx,rsp  
            0000000000250039  lea         rax,[rbx-50h]  
            000000000025003D  mov         rsp,rax  
            0000000000250040  movaps      xmm0,xmmword ptr [rbp-30h]  
            0000000000250044  movups      xmmword ptr [rbx-40h],xmm0  
            0000000000250048  lea         rcx,[rbp-50h]  
            000000000025004C  lea         rdx,[rbp-60h]  
            0000000000250050  lea         r8,[rbp-70h]  
            0000000000250054  lea         r9,[rbp-80h]  
            0000000000250058  mov         rax,130010h  
            0000000000250062  lea         r10,[rbp-90h]  
            0000000000250069  movups      xmm0,xmmword ptr [rdi]  
            000000000025006C  movups      xmm1,xmmword ptr [rdi+10h]  
            0000000000250070  movups      xmm2,xmmword ptr [rdi+20h]  
            0000000000250074  movups      xmm3,xmmword ptr [rdi+30h]  
            0000000000250078  movaps      xmm4,xmmword ptr [rbp-40h]  
            000000000025007C  sub         rsp,30h  
            0000000000250080  movaps      xmmword ptr [rbp-50h],xmm4  
            0000000000250084  movaps      xmmword ptr [rbp-60h],xmm0  
            0000000000250088  movaps      xmmword ptr [rbp-70h],xmm1  
            000000000025008C  movaps      xmmword ptr [rbp-80h],xmm2  
            0000000000250090  movaps      xmmword ptr [rbp-90h],xmm3  
            0000000000250097  mov         qword ptr [rsp+20h],r10  
            000000000025009C  call        rax  
            000000000025009E  add         rsp,30h  
            00000000002500A2  movups      xmmword ptr [rbx-50h],xmm0  
            00000000002500A6  movups      xmm0,xmmword ptr [rdi+40h]  
            00000000002500AA  subps       xmm0,xmmword ptr [rbp-40h]  
            00000000002500AE  movups      xmmword ptr [rbx-30h],xmm0  
            00000000002500B2  movups      xmm0,xmmword ptr [rdi+50h]  
            00000000002500B6  subps       xmm0,xmmword ptr [rbp-40h]  
            00000000002500BA  movups      xmmword ptr [rbx-20h],xmm0  
            00000000002500BE  movups      xmm0,xmmword ptr [rdi+60h]  
            00000000002500C2  subps       xmm0,xmmword ptr [rbp-40h]  
            00000000002500C6  movups      xmmword ptr [rbx-10h],xmm0  
            00000000002500CA  movups      xmm0,xmmword ptr [rbx-50h]  
            00000000002500CE  movups      xmmword ptr [rsi],xmm0  
            00000000002500D1  movups      xmm0,xmmword ptr [rbx-40h]  
            00000000002500D5  movups      xmmword ptr [rsi+10h],xmm0  
            00000000002500D9  movups      xmm0,xmmword ptr [rbx-30h]  
            00000000002500DD  movups      xmmword ptr [rsi+20h],xmm0  
            00000000002500E1  movups      xmm0,xmmword ptr [rbx-20h]  
            00000000002500E5  movups      xmmword ptr [rsi+30h],xmm0  
            00000000002500E9  movups      xmm0,xmmword ptr [rbx-10h]  
            00000000002500ED  movups      xmmword ptr [rsi+40h],xmm0  
            00000000002500F1  lea         rsp,[rbp-18h]  
            00000000002500F5  pop         rbx  
            00000000002500F6  pop         rdi  
            00000000002500F7  pop         rsi  
            00000000002500F8  pop         rbp  
            00000000002500F9  ret  
            
            posted on 2011-06-25 16:10 空明流轉 閱讀(2233) 評論(5)  編輯 收藏 引用

            評論

            # re: SALVIA的Vertex Shader已經可以work了 2011-06-25 19:00 ooseven
            樓主都用上llvm了?太贊!
            能不能專門發一些介紹llvm主題的文章?
            早就聽過llvm的大名卻無緣識得真面目  回復  更多評論
              

            # re: SALVIA的Vertex Shader已經可以work了 2011-06-25 19:05 空明流轉
            @ooseven
            LLVM的手冊要好好看,一個是Tutorial,一個是Reference。
            要理解LLVM IR和C++ Interface之間的關系就OK了。

            LLVM的源代碼質量很高,調試起來什么的都很方便,小bug甚至自己都可以修的。  回復  更多評論
              

            # re: SALVIA的Vertex Shader已經可以work了 2011-06-25 19:19 千暮(zblc)
            mark!  回復  更多評論
              

            # re: SALVIA的Vertex Shader已經可以work了 2011-06-27 01:19 陳梓瀚(vczh)
            坐等可以work變成可以leverage  回復  更多評論
              

            # re: SALVIA的Vertex Shader已經可以work了 2011-12-21 19:35 Chansey
            用llvm模擬的shader compiler?  回復  更多評論
              

            久久综合给合综合久久| 国产成人无码精品久久久性色| 欧美噜噜久久久XXX| 国产精品美女久久久久久2018| 日韩精品久久久久久| 三级片免费观看久久| 欧美午夜精品久久久久免费视| 国产精品免费久久| 久久久久99精品成人片欧美| 精品久久久久久久久久中文字幕| 久久精品综合网| 国产精品一区二区久久精品无码| 久久久精品国产| 欧美国产精品久久高清| 久久99国产精品二区不卡| 精品久久久久久国产| 久久男人AV资源网站| 久久国产乱子精品免费女| 中文精品久久久久人妻不卡| 少妇久久久久久被弄到高潮| 国产福利电影一区二区三区久久老子无码午夜伦不 | 国产精品美女久久久网AV| 日韩久久久久久中文人妻| 欧美一级久久久久久久大| 国产精品久久久久jk制服| 亚洲精品无码专区久久久| 久久精品aⅴ无码中文字字幕不卡| 久久精品国产亚洲一区二区三区 | 97久久精品人妻人人搡人人玩| 伊人久久精品影院| 亚洲国产成人久久综合野外| 久久久久综合中文字幕| 久久精品亚洲男人的天堂| 久久天天日天天操综合伊人av| 精品无码久久久久久久动漫| 久久av高潮av无码av喷吹| 一本色道久久88综合日韩精品| 欧美亚洲国产精品久久| 狠狠色综合网站久久久久久久高清 | 免费观看久久精彩视频| 99精品久久精品|