新聞中心

EEPW首頁 > 嵌入式系統 > 設計應用 > ARM匯編學習

ARM匯編學習

作者: 時間:2016-11-09 來源:網絡 收藏
最近用ARM匯編寫了3個小程序,今天發(fā)上來供大家參考一下。

程序1:C語言中嵌套ARM匯編實現找出三個數中的最大值,程序如下:

本文引用地址:http://m.butianyuan.cn/article/201611/317579.htm

test.c文件:

#include #define N 3int MAX(int *p,int b){int rmax = 0;  //用來返回最大值int temp = 0;  //作為變量交換的中間變量int count = 0; //計數器,用來做循環(huán)控制變量__asm{MOV count,#0loop:LDR temp,[p,count * 4]CMP rmax,temp			MOVLT rmax,tempADD count,count,#1CMP count,bBNE	loop }return rmax;	}int main(){int src[N]={3,6,5};//定義一個數組int max = MAX(src,N);return 0;}
程序2:C語言調用匯編程序實現冒泡排序,程序如下:

main.c如下:

#include #define N  10int array[N] = {10,9,8,11,13,7,3,3,5,4};extern void my_sort(int *p,int B);int main(){my_sort(array,N);return 0;}

asmain.c如下:

AREA ASMAIN,CODE,READONLYCODE32ENTRYEXPORT my_sortmy_sortMOV R2,#4		;R2<-4MOV R3,#0		;R3<-0MOV R4,R1		;將數組的寬度賦值給R4MOV R5,R0		;將數組的基地址賦值給R5MUL R6,R4,R2	;將數組的字節(jié)長度賦值給R6ADD R7,R0,R6	;將數組最后的元素的地址賦值給R7outerMOV R5,R0		;重新將數組的基地址賦值給R5innerLDR R8,[R5]		 ;將數組的前一個元素賦值給R8LDR R9,[R5,#4]	 ;將數組的后一個元素賦值給R9CMP R8,R9		 ;比較前一個元素和后一個元素的大小STRGT R8,[R5,#4] ;前一個元素大于后一個元素,則將R8的值賦給數組的后一個元素STRGT R9,[R5]	 ;前一個元素大于后一個元素,則將R9的值賦給數組的前一個元素ADD R5,R5,#4	 ;將指向數組元素的指針下移一個單位CMP R5,R7		 ;比較數組的指針是否移到數組的最后一個元素BLT inner		 ;若沒有,則跳轉到下一次內層循環(huán)SUB R7,R7,#4	 ;R7數組指針前移一個單位ADD R3,R3,#4	 ;R3計數器加4CMP	R3,R6		 ;比較R3和數組字節(jié)長度的大小BLT outer		 ;R3小于數組的字節(jié)長度,跳轉到下一次外層循環(huán)MOV PC,LR		 ;從匯編程序返回到C文件程序END

程序3:匯編語言調用C語言實現選擇排序,程序如下:

asmain.s如下:

AREA ASMAIN,CODE,READONLYCODE32ENTRYIMPORT my_sortstartLDR R0,=DATA1	;將數組的地址傳給my_sort函數的第一個參數MOV R1,#7		;將數組的地址傳給my_sort函數的第二個參數BL my_sort		;執(zhí)行my_sort函數并返回AREA datablock,DATA,READWRITEDATA1	DCD 2,5,10,11,9,7,1END

main.c如下:

#include void my_sort(int *p, int B){int max = 0;int tmp = 0;int i = 0;int j = 0;int z = 0;for(i = 0; i < B - 1; i++){for(j = 0; j < B - i; j++){if(max < p[j]){max = p[j];z = i;}}j--;max = 0;tmp = p[z];p[z] = p[j];p[j] = tmp;}}

注:上面的程序我是在MDK環(huán)境下編譯的,如果在ADS1.2環(huán)境下進行編譯,還要進行一些修改。


關鍵詞: ARM匯編學

評論


技術專區(qū)

關閉