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

            2010年3月8日

                學(xué)計算機(jī)圖形學(xué)用到OpenGL,不過想在Ubuntu下進(jìn)行實現(xiàn),查查了查,OpenGL linux下的C綁定是Mesa,可是安裝這玩意兒可是費了我一番功夫。

                首先,從www.Mesa3D.org下載了三個文件,MesaDemos-X.Y.Z.tar.gz , MesaGLUT-X.Y.Z.tar.gz,MesaLib-X.Y.Z.tar.gz,分別是DemoGLUT庫和最主要的MesaOpenGL)鏈接文件。這里X.Y.ZMesa的版本,我下載的是7.6.1。解壓后的得到一個文件夾Mesa-X.Y.Z

                bash中進(jìn)入這個文件夾中,執(zhí)行./configure進(jìn)行配置,額,少了一些庫。

                首先是libdrm,在軟件包管理器中,找到了libdrm-dev,安裝后,再次執(zhí)行./configure

                還是少庫。

                少了dri2proto

                查了查,找到了x11proto-dri2-dev,安裝后執(zhí)行./configure

                少庫。

                少了xxf86vm

                在軟件包中找到libxxf86vm-dev安裝后,額,不抱希望了,執(zhí)行./configure

                …………少庫。

                這次是xt

                找了找,在軟件包中找到了libxt-dev,安裝后。./configure

                成功了!提示我make

                哈哈,真高興!可是make就出問題了,提示我少了fdepend這個東西。

                可是我怎么都找不到這個東西在哪里。

                很郁悶。

                繼續(xù)上www.Mesa3D.org看看官方的說明,上面說安裝Mesa需要4個東西。

            1. dri2proto version 1.99.3 or later

            2. Linux 2.6.28

            3. libDRM version 2.4.3 or later

            4. Xorg server version 1.5 or later

                前三個,我都有安阿?第四個是什么東西,繼續(xù)在軟件包管理器中搗鼓。找到了xorg-dev這個安裝。再次make,竟然成功了!好吧,make install,也成功了。

                然后接下來,驗證Mesa能不能用。

                轉(zhuǎn)到Mesa-X.Y.Z/progs/demos目錄下,執(zhí)行./gears,提示找不到libglut.so.3(好像是這個,記不大清了),看看Mesa3D上讓執(zhí)行這么幾個命令。

            1. cd lib/ (轉(zhuǎn)到了Mesa-X.Y.Z/lib/目錄下)

            2. export LD_LIBRARY_PATH=${PWD}

            3. export LIBGL_DRIVERS_PATH=${PWD} (if using DRI drivers)

                現(xiàn)在再執(zhí)行Mesa-X.Y.Z/progs/demos/gears可以運行了,看到了齒輪在轉(zhuǎn)動!

                可是在Mesa-X.Y.Z/progs/samples/編譯一個文件

                         gcc `pkg-config opengl --cflags --libs ` point.c -o point

                出現(xiàn)了好多錯誤。

                額,怎么回事?

                才知道,編譯文件是找不到glut庫,仔細(xì)一看才發(fā)現(xiàn),自己編譯文件用的命令錯了,應(yīng)該是

                            gcc `pkg-config glut --cflags --libs ` point.c -o point

                好了,現(xiàn)在一切沒有問題了,安裝成功!


            posted @ 2010-03-08 00:36 楊帆 閱讀(3772) | 評論 (5)編輯 收藏

            2010年2月18日

            今天在solaris下做這個測試

            測試代碼如下:
            #include <stdlib.h>
            #include <unistd.h>
            int main(){
                   void* p=malloc(512*1024*1024);
                   if(p==NULL) return -1;
                      sleep(10000000);
                         return 0;

            }


            然后我用g++ 4.3.2編譯
            g++-4.3.2 -o testm testm.c

            開了5個,開到第6個的時候,malloc就返回-1了。可是,可是,令人驚奇的是
            這個時候,我無論是用vmstat還是用mdb看,我都還有大量的空閑的物理內(nèi)存
            >::memstat
            Page Summary                Pages                MB  %Tot
            ------------     ----------------  ----------------  ----
            Kernel                     144849               565   14%
            ZFS File Data               62043               242    6%
            Anon                       146323               571   14%
            Exec and libs                3640                14    0%
            Page cache                  34357               134    3%
            Free (cachelist)            35896               140    3%
            Free (freelist)            600734              2346   58%

            Total                     1027842              4015
            Physical                  1027841              4015
            這與我開這幾個程序之前,沒有明顯的變化。(相比而下,在windows下,這個時 候系統(tǒng)已經(jīng)卡的快嗝屁了)

            然后我用ps來看
            # ps -eo pid,vsz,rss,args |grep testm
             1298 527292 1356 ./testm
             1309 4224 1256 grep testm
             1300 527292 1356 ./testm
             1302 527292 1356 ./testm
             1296 527292 1356 ./testm
             1304 527292 1356 ./testm

            # pmap 1296
            1296:    ./testm
            08046000       8K rwx--    [ stack ]
            08050000       4K r-x--  /tmp/testm
            08060000       8K rwx--  /tmp/testm
            08062000  524296K rwx--    [ heap ]
            FEB70000     320K r-x--  /lib/libm.so.2
            FEBCF000       8K rwx--  /lib/libm.so.2
            FECD0000      24K rwx--    [ anon ]
            FECE0000    1280K r-x--  /usr/lib/libc/libc_hwcap1.so.1
            FEE20000      28K rwx--  /usr/lib/libc/libc_hwcap1.so.1
            FEE27000       8K rwx--  /usr/lib/libc/libc_hwcap1.so.1
            FEE30000      52K r-x--  /usr/lib/libgcc_s.so.1
            FEE4C000       4K rwx--  /usr/lib/libgcc_s.so.1
            FEE50000       4K rwx--    [ anon ]
            FEE60000     856K r-x--  /usr/lib/libstdc++.so.6.0.10
            FEF45000     160K rwx--  /usr/lib/libstdc++.so.6.0.10
            FEF6D000      24K rwx--  /usr/lib/libstdc++.so.6.0.10
            FEF80000       4K r--s-  /var/ld/ld.config
            FEF90000       4K rwx--    [ anon ]
            FEFA0000       4K rw---    [ anon ]
            FEFB0000       4K rw---    [ anon ]
            FEFBE000     180K r-x--  /lib/ld.so.1
            FEFFB000       8K rwx--  /lib/ld.so.1
            FEFFD000       4K rwx--  /lib/ld.so.1
             total    527292K


            系統(tǒng)的確給這個進(jìn)程分配了地址空間(看它的heap有多大),但是壓根兒就沒有給 它分配物理內(nèi)存。我想不出的是,它依據(jù)什么來拒絕新的申請。
            由于環(huán)境有限,我沒有找到良好的環(huán)境在freebsd下重復(fù)這個實驗。我在 freebsd.unix-center.net上做這個測試,但是把每個進(jìn)程分配的內(nèi)存縮小到64M, 然后開了100個這樣的進(jìn)程,據(jù)估計至少需要6G的內(nèi)存,malloc一直都是成功的, 我的手酸了,懶得弄了。


            最有趣的在于這個:
            #include <stdlib.h>
            #include <unistd.h>
            #include <string.h>

            int main(){
                   void* p=malloc(512*1024*1024);
                   if(p==NULL) return -1;
                memset(p,0,512*1024*1024);
                free(p);
                      sleep(10000000);
                         return 0;

            }

            用ps/pmap去看,事實證明,free函數(shù)根本就沒有釋放物理內(nèi)存。free是把malloc 得到的物理內(nèi)存還給了自己進(jìn)程,而不是還給了操作系統(tǒng)。
            在這一點上,freebsd是有差別的。執(zhí)行完free之后,rss明顯降了下來



            posted @ 2010-02-18 20:01 楊帆 閱讀(442) | 評論 (0)編輯 收藏
            僅列出標(biāo)題  

            導(dǎo)航

            <2011年5月>
            24252627282930
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            統(tǒng)計

            常用鏈接

            留言簿

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            欧美激情精品久久久久| 国产精品久久久久免费a∨| 国产精品久久久久影视不卡| 国产午夜福利精品久久2021| 九九精品99久久久香蕉| 久久se精品一区二区| 久久这里有精品视频| 国产精品久久久久久久久久影院 | 亚洲午夜无码久久久久| 精品国产乱码久久久久久郑州公司| 国产成人久久久精品二区三区| 久久99热这里只频精品6| 久久99精品久久久久久久不卡| 精品无码久久久久久国产| 欧美熟妇另类久久久久久不卡| 国产精品激情综合久久| 亚洲精品午夜国产VA久久成人| 久久精品国产精品亚洲| 久久福利青草精品资源站免费 | 亚洲精品tv久久久久久久久 | 久久久久久久久久免免费精品| 亚洲综合伊人久久大杳蕉| 久久久无码精品午夜| 久久久久一区二区三区| 熟妇人妻久久中文字幕| 欧美日韩精品久久久久| 伊人久久大香线蕉AV一区二区| 国产99久久久国产精品~~牛| 99re这里只有精品热久久| 少妇久久久久久久久久| 亚洲精品国产自在久久| 久久天天躁狠狠躁夜夜av浪潮 | 国产午夜久久影院| 久久99亚洲网美利坚合众国| 少妇高潮惨叫久久久久久| 伊人久久大香线蕉av不变影院| 久久精品极品盛宴观看| 97香蕉久久夜色精品国产 | 国产免费久久精品99久久| 色综合久久久久网| 国产日韩久久免费影院|