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

            Welcome to ErranLi's Blog!

              C++博客 :: 首頁(yè) :: 聯(lián)系 :: 聚合  :: 管理
              106 Posts :: 1 Stories :: 97 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(12)

            搜索

            •  

            積分與排名

            • 積分 - 175922
            • 排名 - 151

            最新評(píng)論

            閱讀排行榜

            原文:http://www.shnenglu.com/milkyway/archive/2007/04/08/21481.html
            作者:


            淺談wince應(yīng)用程序的可移植性

            ????? 由于windows絕大多數(shù)情況下運(yùn)行于X86平臺(tái)上,也就不存在不同平臺(tái)的可移植性問(wèn)題。然而Windows CE運(yùn)行在四大架構(gòu)(X86,SHx,MIPS,ARM)的CPU上,編寫應(yīng)用程序時(shí)就需要考慮它的移植。
            ?????? 以下通過(guò)在wince系統(tǒng)下訪問(wèn)物理地址,來(lái)看看如何編寫可移植性較好的應(yīng)用程序。
            ?????? 首先必須明確兩個(gè)概念。
            ?????? 1。在X86平臺(tái)下才有I/O地址這一說(shuō),在其他體系的CPU(如ARM/MIPS)下是沒有I/O端口的。因?yàn)閄86下把I/O和存儲(chǔ)器分開編址,導(dǎo)致其有兩種地址;而別的CPU是把兩者統(tǒng)一編址,即把I/O映射到存儲(chǔ)器上。
            ??????? 2。wince的存儲(chǔ)管理是通過(guò)MMU實(shí)現(xiàn)的,在系統(tǒng)啟動(dòng)后,我們只能訪問(wèn)虛擬存儲(chǔ)空間,必須經(jīng)過(guò)MMU。但是在X86下,訪問(wèn)I/O口和存儲(chǔ)器走的地址總線不同,不用經(jīng)過(guò)MMU。
            ?????????比如我們想要訪問(wèn)掛在某總線上物理地址為360h的端口,對(duì)于X86平臺(tái)我們可以直接嵌入?yún)R編操作物理地址, 或者使用地址指針訪問(wèn)物理地址。但對(duì)于其他平臺(tái),我們必須先作一個(gè)物理地址到虛擬地址的映射,然后操作其虛擬地址。這樣顯然程序的可移植性不好,我們需要定義? #ifdef __x86....#elif defined __arm? 使得在不同平臺(tái)下程序能夠順利運(yùn)行。
            ????????? 如果使用下面的代碼我們就可以不用這么費(fèi)勁的定義不同平臺(tái)了:
            ????????先定義
            ???? inIoSpace = 1;
            ??? ioPhysicalBase.QuadPart = 0x360;

            if( HalTranslateBusAddress( Isa,???????????????? //此函數(shù)把ISA總線上物理地址映射為系統(tǒng)物理地址
            ??????????????????????????? 0,
            ??????????????????????????? ioPhysicalBase,
            ??????????????????????????? &inIoSpace,????????????????? //此參數(shù)=1說(shuō)明轉(zhuǎn)化的是I/O空間地址,=0時(shí)存儲(chǔ)器地址
            ??????????????????????????? &ioPhysicalBase ) )
            {
            ??? if( !inIoSpace )?????????????????????????????????????????? ////如果是存儲(chǔ)器地址,針對(duì)非X86 平臺(tái)

            ??? {
            ??????????? ioPortBase = ( PUCHAR ) MmMapIoSpace(??????????? //此函數(shù)把系統(tǒng)物理地址轉(zhuǎn)化為虛擬地址
            ??????????? ioPhysicalBase,
            ??????????? IoLen,
            ??????????? FALSE );
            ??????? if( ioPortBase == NULL )
            ??????? {
            ??????????? //TODO: Error handling
            ??????? }
            ??? }
            ??? else???????????????????????????????????????????????? //如果是I/O,即X86?下,不需要做地址映射
            ??? {
            ??????? ioPortBase = ( PUCHAR ) ioPhysicalBase.LowPart;
            ??? }
            }
            else
            {
            ??? //TODO: Error Handling
            }

            ???????隨后對(duì)于端口的操作( ioPortBase),我們也可以充分挖掘它的可移植性。通過(guò)使用READ_PORT_UCHAR,
            WRITE_PORT_UCHAR這些wince下的宏來(lái)實(shí)現(xiàn)端口讀寫。而不是在X86下用指針操作(不僅移植性差,而且容易產(chǎn)生問(wèn)題)。CE下的宏在內(nèi)部是封裝好的API函數(shù)。例如WRITE_PORT_UCHAR這個(gè)宏在X86 處理器上轉(zhuǎn)化為一條OUT的匯編指令;而在ARM處理器上會(huì)轉(zhuǎn)化成一條對(duì)虛擬地址的寫指令。

            posted on 2007-10-13 17:58 erran 閱讀(735) 評(píng)論(0)  編輯 收藏 引用 所屬分類: WinCE
            99久久精品国产高清一区二区| 四虎久久影院| …久久精品99久久香蕉国产| 久久精品aⅴ无码中文字字幕不卡 久久精品aⅴ无码中文字字幕重口 | 久久综合日本熟妇| 婷婷久久综合九色综合98| 国产成人精品久久| 亚洲精品无码成人片久久| 久久线看观看精品香蕉国产| 青青草原综合久久大伊人导航| 亚洲人成伊人成综合网久久久| A狠狠久久蜜臀婷色中文网| 日日狠狠久久偷偷色综合96蜜桃 | 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 狠狠色噜噜色狠狠狠综合久久 | 日本免费久久久久久久网站| 久久久久久青草大香综合精品| 色欲久久久天天天综合网精品 | 久久精品成人| 久久精品无码一区二区无码 | 亚洲午夜久久久久久久久久| 久久精品无码一区二区三区免费| 欧美日韩久久中文字幕| 久久综合中文字幕| 777米奇久久最新地址| 久久亚洲AV无码精品色午夜| 久久久久综合中文字幕| A级毛片无码久久精品免费| 精品久久久久久亚洲精品| 久久九九兔免费精品6| 一本色道久久88综合日韩精品 | 国产69精品久久久久99尤物| 国产精品久久久久久影院| 久久精品国产日本波多野结衣| 伊人久久无码精品中文字幕| 香蕉99久久国产综合精品宅男自 | 无码任你躁久久久久久老妇| 久久高潮一级毛片免费| 久久久WWW成人免费毛片| 99久久精品免费看国产| 成人精品一区二区久久|