Keil C51中對雙數據指針的直接利用
作為一個(gè)常用的C51編譯器,Keil C51是支持雙數據指針的,但并不是直接支持。如果要在C51程序中使用雙數據指針,有一些特別的要求。
首先來(lái)看Keil C51是如何支持雙數據指針的。
在Keil C51的編譯器手冊中指出:#pragma modp2可以打開(kāi)Philips或Atmel WM系列器件中有雙DPTR的型號,并且可以提
Keil公司也提供了一個(gè)對照表,對比性能的提升。對比的型號是8051和Dallas 320,函數是memcpy塊拷貝。對照表如下:
看起來(lái)似乎使用庫函數就可以大幅度提高程序性能,但實(shí)際上這樣做并不能保證一定可以提高程序性能。首先Dallas 320是4T的CPU,本身就比12T的8051快。其次,以memcpy為例,它的原型是void*memcpy(void*s1,const void*s2,int len),其傳人參數有3個(gè),合計8字節,要使用數據段來(lái)傳送。在數據量少的情況下,參數傳遞的開(kāi)銷(xiāo)就有可能大過(guò)數據傳遞的開(kāi)銷(xiāo)。如果想要在數據塊拷貝或移動(dòng)的同時(shí)對數據加以處理,比如在一個(gè)目的數據塊后面加上一個(gè)校驗和,那么使用庫函數是辦不到的,只有通過(guò)循環(huán)來(lái)進(jìn)行。當數據塊的源和目都是16位地址時(shí),每一次循環(huán)都會(huì )有兩次對數據指針的賦值,在源地址和目地址之間來(lái)回切換,這時(shí)采用雙數據指針會(huì )有效地提高程序性能。如果要在程序中直接生成使用雙數據指針的代碼,目前沒(méi)有直接的編譯指令。Keil公司在它的網(wǎng)站上曾說(shuō)過(guò)多數據指針支持庫函數,并且目前也未打算在編澤器中直接支持多數據指針。
2 Keil C中直接生成雙數據指針的代碼
實(shí)際上,Keil C51編譯器還是可以直接生成使用雙數據指針的代碼的,只要沒(méi)定好適當的優(yōu)化級別,安排好適當的C51語(yǔ)句,編譯器就會(huì )生成使用雙數據指針的代碼。下面給出一個(gè)例子,使用雙數據指針將CODE區的一個(gè)16字節的數組拷貝到XDATA區。 編譯后其中for循環(huán)的匯編代碼主體如下:
可以看到,匯編代碼基本上是最簡(jiǎn)化的使用雙數據指針的匯編程序。
由上面的代碼可知,在優(yōu)化級別7(Extended Index Ac-cess Optimizing)的作用下,DPTR被調用了。通過(guò)類(lèi)型轉換和SFR指令的配合,雙數據指針指令被生成。這足一個(gè)經(jīng)驗方法,基本上這是一個(gè)框架,可以在看到雙DPTR調用被生成后加入其他語(yǔ)句,在塊操作的同時(shí)處理數據。
3 調試環(huán)境的設定
在Keil uVision2環(huán)境下,軟件仿真Philips或AtmelWM系列器件中有雙DPTR的型號時(shí),仿真器中會(huì )有AUXR1、DPTR0、DPTR1這3個(gè)寄存器。如果不使能雙DPTR特性,仿真時(shí)DPTR的值是混亂的。對于宏晶科技STC89系列器件的雙DPTR特性,打開(kāi)軟件仿真設定的具體步驟是:在File/Device Database菜單中選擇STC的某一具體型號,在Options框中"CPU="一項后加上MODP2,然后單擊Update更新器件庫。打開(kāi)雙數據指針調試后,再啟動(dòng)Debug,就會(huì )有AUXR1、DPTR[0]、DPTR[1]這3個(gè)寄存器。當加載上述程序時(shí),會(huì )清楚地看到雙數據指針的操作和AUXR1的變化。
linux操作系統文章專(zhuān)題:linux操作系統詳解(linux不再難懂)
評論