《计算机体系结构》第二次实验-指令集实验_第1页
《计算机体系结构》第二次实验-指令集实验_第2页
《计算机体系结构》第二次实验-指令集实验_第3页
《计算机体系结构》第二次实验-指令集实验_第4页
《计算机体系结构》第二次实验-指令集实验_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

指令集实验王宇航指令集实验实验内容通过观察求素数程序在windlx以及Intel中的运行方式和内存中的存储方式,进行比较和分析。实验步骤1、 安装windlx模拟器,分析、运行其自带的求素数代码。详细分析其用到的各类机器指令格式。在windlx中将prim.s文件导入到其中并进行;-; Program begins at symbol main; generates a table with the first Count prime numbers from Table;-.data;* size of table.globalCountCount:.word10.globalTableTable:.spaceCount*4.text.globalmainmain:;* Initializationaddir1,r0,0;Index in Tableaddir2,r0,2 ;Current value/r1=r0+0 ; r2=r0+2 ;建立索引并初始化;* Determine, if R2 can be divided by a value in tableNextValue:addir3,r0,0 ;Helpindex in Table/r3=r0+0 ;建立帮助索引Loop:seqr4,r1,r3;End of Table?bnezr4,IsPrim;R2 is a prime numberlwr5,Table(R3)divur6,r2,r5multur7,r6,r5subur8,r2,r7beqzr8,IsNoPrimaddir3,r3,4jLoop/循环判断是否为素数IsPrim: ;* Write value into Table and increment indexswTable(r1),r2addir1,r1,4;* Count reached?lwr9,Countsrlir10,r1,2sger11,r10,r9bnezr11,Finish/循环中的子函数,对是素数的进行存储和处理IsNoPrim:;* Check next valueaddir2,r2,1 ;increment R2jNextValue/循环中的子函数,对不是是素数的进行存储和处理Finish: ;* endtrap0/程序结束2、 编写c语言求素数程序,并分析其在Intel机器上执行的汇编代码。#include stdafx.h#include stdio.hint isprime(int n)int m=2;for(;m*m=n;+m)if(n%m=0)return 0;return 1;/循环中的子函数,对是素数的进行存储和处理,是素数则返回1,不是素数则返回0int main(int argc, char* argv)int b;for(b=2;b=100;b+)if(isprime(b)printf(%dn,b);return 0;/主函数,利用循环对100以内的数进行判断并输出。以下为上面的程序翻译过来后的汇编程序。TITLEF:学习程序求素数求素数.cpp.386Pinclude listing.incif Version gt 510.model FLATelse_TEXTSEGMENT PARA USE32 PUBLIC CODE_TEXTENDS_DATASEGMENT DWORD USE32 PUBLIC DATA_DATAENDSCONSTSEGMENT DWORD USE32 PUBLIC CONSTCONSTENDS_BSSSEGMENT DWORD USE32 PUBLIC BSS_BSSENDS$SYMBOLSSEGMENT BYTE USE32 DEBSYM$SYMBOLSENDS$TYPESSEGMENT BYTE USE32 DEBTYP$TYPESENDS_TLSSEGMENT DWORD USE32 PUBLIC TLS_TLSENDS;COMDAT ?_C_03HMFC?$CFd?6?$AACONSTSEGMENT DWORD USE32 PUBLIC CONSTCONSTENDS;COMDAT ?isprimeYAHHZ_TEXTSEGMENT PARA USE32 PUBLIC CODE_TEXTENDS;COMDAT _main_TEXTSEGMENT PARA USE32 PUBLIC CODE_TEXTENDSFLATGROUP _DATA, CONST, _BSSASSUMECS: FLAT, DS: FLAT, SS: FLATendifPUBLIC?isprimeYAHHZ; isprime;COMDAT ?isprimeYAHHZ_TEXTSEGMENT_n$ = 8_m$ = -4?isprimeYAHHZ PROC NEAR; isprime, COMDAT; 7 : pushebpmovebp, espsubesp, 68; Hpushebxpushesipushedileaedi, DWORD PTR ebp-68movecx, 17; Hmoveax, -; ccccccccHrep stosd; 8 : int m=2;movDWORD PTR _m$ebp, 2; 9 : for(;m*m=n;+m)jmpSHORT $L530$L531:moveax, DWORD PTR _m$ebpaddeax, 1movDWORD PTR _m$ebp, eax$L530:movecx, DWORD PTR _m$ebpimulecx, DWORD PTR _m$ebpcmpecx, DWORD PTR _n$ebpjgSHORT $L532; 10 : if(n%m=0)moveax, DWORD PTR _n$ebpcdqidivDWORD PTR _m$ebptestedx, edxjneSHORT $L533; 11 : return 0;xoreax, eaxjmpSHORT $L528$L533:; 12 : return 1;jmpSHORT $L531$L532:moveax, 1$L528:; 13 : popedipopesipopebxmovesp, ebppopebpret0?isprimeYAHHZ ENDP; isprime_TEXTENDSPUBLIC_mainPUBLIC?_C_03HMFC?$CFd?6?$AA; stringEXTRN_printf:NEAREXTRN_chkesp:NEAR;COMDAT ?_C_03HMFC?$CFd?6?$AA; File F:学习程序求素数求素数.cppCONSTSEGMENT?_C_03HMFC?$CFd?6?$AA DB %d, 0aH, 00H; stringCONSTENDS;COMDAT _main_TEXTSEGMENT_b$ = -4_mainPROC NEAR; COMDAT; 16 : pushebpmovebp, espsubesp, 68; Hpushebxpushesipushedileaedi, DWORD PTR ebp-68movecx, 17; Hmoveax, -; ccccccccHrep stosd; 17 : int b; 18 : for(b=2;b=100;b+)movDWORD PTR _b$ebp, 2jmpSHORT $L539$L540:moveax, DWORD PTR _b$ebpaddeax, 1movDWORD PTR _b$ebp, eax$L539:cmpDWORD PTR _b$ebp, 100; HjgSHORT $L541; 20 : if(isprime(b)movecx, DWORD PTR _b$ebppushecxcall?isprimeYAHHZ; isprimeaddesp, 4testeax, eaxjeSHORT $L542; 21 : printf(%dn,b);movedx, DWORD PTR _b$ebppushedxpushOFFSET FLAT:?_C_03HMFC?$CFd?6?$AA; stringcall_printfaddesp, 8$L542:; 22 : jmpSHORT $L540$L541:; 23 : return 0;xoreax, eax; 24 : popedipopesipopebxaddesp, 68; Hcmpebp, espcall_chkespmovesp, ebppopebpret0_m

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论