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

            eryar

            PipeCAD - Plant Piping Design Software.
            RvmTranslator - Translate AVEVA RVM to OBJ, glTF, etc.
            posts - 603, comments - 590, trackbacks - 0, articles - 0

            CPU Instruction Pointer

            Posted on 2016-04-10 23:56 eryar 閱讀(1672) 評論(1)  編輯 收藏 引用

            CPU Instruction Pointer

            eryar@163.com

            1.Introduction

            CPU對存儲器的讀寫通過總線Bus來完成,總線又分為地址總線(Address Bus)、數(shù)據(jù)總線(Data Bus)、控制總線(Control Bus)。地址總線AB決定了CPU的尋址能力,即可以訪問的存儲空間的大小。數(shù)據(jù)總線DB決定了CPU的一次操作中可以處理的數(shù)據(jù)的大小,16位CPU一次可以加載兩個字節(jié),32位CPU一次可以加載4個字節(jié)。當(dāng)然CPU的主頻越大,那么在相同的時間內(nèi),處理的次數(shù)會更多。

            2.16bit CPU 

            由于8086CPU有20位地址總線,所以尋址能力為1MB。但是8086所有的寄存器都是16位的,如果由寄存器直接處理地址,那么一個16位的寄存器可以訪問的最大地址為64KB。如何通過16位的寄存器來訪問這1MB的空間呢?8086CPU折騰出一個地址加法器,通過加法器來根據(jù)兩個16位地址來合成一個20位的地址,即物理地址=段地址X16+偏移地址。對應(yīng)到CPU中就是CS和IP這兩個寄存器。

            8086CPU中的CS和IP的內(nèi)容提供了CPU要執(zhí)行指令的地址。在CPU中,程序員能夠用指令讀寫的部件只有寄存器,程序員可以通過改變寄存器中的內(nèi)容實現(xiàn)對CPU的控制。CPU從何處執(zhí)行指令是由CS和IP中的內(nèi)容決定的,程序員可以通過改變CS和IP中的內(nèi)容來控制CPU執(zhí)行目標(biāo)指令。

            若想同時修改CS和IP的內(nèi)容,可以用形如jmp 段地址:偏移地址的指令完成。如下圖所示:

            wps_clip_image-10222

            3.32bit CPU

            因為80386的CPU尋址能力是4GB,所以它的尋址模式是平坦模式,不需要用段地址+偏移地址來折騰。所以32位CPU的EIP寄存器對應(yīng)了16位CPU中的CS和IP兩個寄存器。修改了EIP寄存器就可以改變CPU要執(zhí)行的指令。如下面一段簡單代碼:

            #include <stdio.h> 

            int main(int argc, char* argv[]) 

                mark: printf(
            "hi\n"); 

                
            goto mark; 

                
            return 0
            }

            使用了goto,在Debug時可以在Visual Studio中看到CPU中相關(guān)寄存器中的信息如下圖所示:

            wps_clip_image-22411

            由上圖可知,goto對應(yīng)的匯編命令就是一個修改EIP寄存器的jmp指令。

            Feedback

            # re: CPU Instruction Pointer  回復(fù)  更多評論   

            2016-04-12 16:25 by anna
            很基礎(chǔ)的知識

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            一本久道久久综合狠狠爱| 99久久精品免费看国产免费| 怡红院日本一道日本久久 | 国内精品久久久久久久久| 国产91色综合久久免费| 久久久久成人精品无码| 久久久久亚洲AV片无码下载蜜桃| 色婷婷综合久久久久中文一区二区 | 国产精品午夜久久| 久久精品国产久精国产果冻传媒| 性欧美大战久久久久久久久 | 国内精品久久久久久久涩爱| 狠狠色噜噜色狠狠狠综合久久| 九九久久99综合一区二区| 一本久久免费视频| 久久久久免费精品国产| 日韩精品无码久久久久久| 久久久久国产亚洲AV麻豆| 久久国产欧美日韩精品| 三级三级久久三级久久 | 一本久久精品一区二区| 国产一区二区精品久久岳| 999久久久免费精品国产| 亚洲国产小视频精品久久久三级 | 精品熟女少妇aⅴ免费久久| 99久久精品午夜一区二区| 久久久久亚洲av成人网人人软件| 国产99久久久国产精品~~牛| 国产成人精品综合久久久| 一个色综合久久| 99久久综合国产精品免费| 少妇久久久久久被弄到高潮| 日韩亚洲欧美久久久www综合网| 精品久久久久久无码专区不卡 | 婷婷综合久久狠狠色99h| 国产V亚洲V天堂无码久久久| 久久久久人妻精品一区二区三区| 久久人人青草97香蕉| 久久亚洲国产精品成人AV秋霞| 香蕉久久久久久狠狠色| 无码任你躁久久久久久老妇App|