• <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 空明流轉 閱讀(2226) 評論(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?  回復  更多評論
              

            亚洲精品无码久久久影院相关影片 | 久久久久久久97| 精品久久久久成人码免费动漫 | 久久夜色精品国产www| 亚洲精品乱码久久久久久蜜桃 | 久久久无码精品亚洲日韩蜜臀浪潮| 精品久久一区二区| 国产69精品久久久久APP下载| 99久久国产热无码精品免费| 精品99久久aaa一级毛片| 一本色综合网久久| 国产精品久久久久久久午夜片| 久久亚洲精品无码aⅴ大香| 91久久福利国产成人精品| 久久亚洲AV成人无码软件| 久久久久人妻一区精品 | 久久伊人影视| 91精品无码久久久久久五月天| 性高湖久久久久久久久| 久久久久久久综合日本| 91精品久久久久久无码| 久久亚洲欧美国产精品| 99久久国产综合精品女同图片 | 人妻丰满?V无码久久不卡| 久久综合久久久| 久久精品无码一区二区无码 | 中文精品久久久久人妻不卡| 久久精品一区二区影院| 99久久亚洲综合精品成人| 久久久青草久久久青草| 狠狠狠色丁香婷婷综合久久俺| 精品国产乱码久久久久久郑州公司| 国产免费久久精品99re丫y| 精品伊人久久久| 久久丫忘忧草产品| 欧美黑人又粗又大久久久| 无遮挡粉嫩小泬久久久久久久| 漂亮人妻被黑人久久精品| 久久久久亚洲AV无码专区体验| 99久久精品午夜一区二区| 亚洲国产精品人久久|