8051、ARM和DSP指令周期的測(cè)試與分析
1 AT89S51工作機(jī)制及指令周期的測(cè)試
AT89S51單片機(jī)的時(shí)鐘采用內(nèi)部方式,時(shí)鐘發(fā)生器對(duì)振蕩脈沖進(jìn)行2分頻。由于時(shí)鐘周期為振蕩周期的兩倍(時(shí)鐘周期=振蕩周期P1+振蕩周期P2),而1個(gè)機(jī)器周期含有6個(gè)時(shí)鐘,因此1個(gè)機(jī)器周期包括12個(gè)晶振的振蕩周期。取石英晶振的振蕩頻率為11.059 2 MHz,則單片機(jī)的機(jī)器周期為12/11.059 2=1.085 1 μs。51系列單片機(jī)的指令周期一般含1~4個(gè)機(jī)器周期,多數(shù)指令為單周期指令,有2周期和
為了觀察指令周期,對(duì)單片機(jī)的P1口的最低位進(jìn)行循環(huán)置位操作和清除操作。源程序如下:
#include
main() {
while(1) {
P1=0x01;
P1=0x00;
}
}
采用KEIL uVISION2進(jìn)行編譯、鏈接,生成可執(zhí)行文件。當(dāng)調(diào)用該集成環(huán)境中的Debug時(shí),可以得到上述源程序混合模式的反匯編代碼:
2:main()
3: {
4:while(1)
5:{
6:P1=0x01;
0x000F759001MOVP1(0x90),#0x01
7:P1=0x00;
0x0012 E4CLRA
0x0013 F590MOVP1(0x90),A
8:}
0x001580EDSJMPmain (C:0003)
其中斜體的代碼為C源程序,正體的代碼為斜體C源程序?qū)?yīng)的匯編語言代碼。每行匯編代碼的第1列為該代碼在存儲(chǔ)器中的位置,第2列為機(jī)器碼,后面是編譯、鏈接后的匯編語言代碼。所有指令共占用6個(gè)機(jī)器周期(其中“MOV P1(0x90),#0x01”占用2個(gè)機(jī)器周期,“CLR A”和“MOV P1(0x90),A”各占用1個(gè)機(jī)器周期,最后一個(gè)跳轉(zhuǎn)指令占用2個(gè)機(jī)器周期),則總的循環(huán)周期為6
評(píng)論