ARM系列文章,請點擊以下匯總鏈接:
《從0學(xué)arm合集》
一、gcc 內(nèi)聯(lián)匯編
內(nèi)聯(lián)匯編即在C中直接使用匯編語句進行編程,使程序可以在C程序中實現(xiàn)C語言不能完成的一些工作,例如,在下面幾種情況中必須使用內(nèi)聯(lián)匯編或嵌入型匯編。
程序中使用飽和算術(shù)運算(Saturating Arithmetic)程序需要對協(xié)處理器進行操作在C程序中完成對程序狀態(tài)寄存器的操作格式:__asm__ __volatile__("asm code"
:output
:input
:changed registers);
asm或__asm__開頭,小括號+分號,括號內(nèi)容寫匯編指令。指令+ 用雙引號引上。
「asm code」主要填寫匯編代碼:
"mov r0, r0 "
"mov r1,r1 "
"mov r2,r2"
「output(asm->C)」用于定義輸出的參數(shù),通常只能是變量:
:"constraint" (variable)
"constraint"用于定義variable的存放位置:
r 表示使用任何可用的寄存器
m 表示使用變量的內(nèi)存地址
+ 可讀可寫
= 只寫
& 表示該輸出操作數(shù)不能使用輸入部分使用過的寄存器,只能用"+&"或"=&"的方式使用
「input(C->asm)」用于定義輸入的參數(shù),可以是變量也可以是立即數(shù):
:"constraint" (variable/immediate)
"constraint"用于定義variable的存放位置:
r 表示使用任何可用的寄存器(立即數(shù)和變量都可以)
m 表示使用變量的內(nèi)存地址
i 表示使用立即數(shù)
Note:
使用__asm__和__volatile__表示編譯器將不檢查后面的內(nèi)容,而是直接交給匯編器。如果希望編譯器為你優(yōu)化,__volatile__可以不加沒有asm code也不能省略""沒有前面的和中間的部分,不可以相應(yīng)的省略:沒有changed 部分,必須相應(yīng)的省略:最后的;不能省略,對于C語言來說這是一條語句匯編代碼必須放在一個字符串內(nèi),且字符串中間不能直接按回車換行,可以寫成多個字符串,注意中間不能有任何符號,這樣就會將兩個字符串合并為一個指令之間必須要換行,還可以使用 使指令在匯編中保持整齊舉例
例1:無參數(shù),無返回值這種情況,output和input可以省略:
asm
( //匯編指令
"mrs r0,cpsr "
"bic r0,r0,#0x80 "
"msr cpsr,r0 "
);
例2:有參數(shù) ,有返回值讓內(nèi)聯(lián)匯編做加法運算,求a+b,結(jié)果存在c中
int a =100, b =200, c =0;
asm
(
"add %0,%1,%2 "
: "=r"(c)
: "r"(a),"r"(b)
: "memory"
);
%0 對應(yīng)變量c%1 對應(yīng)變量a%2 對應(yīng)變量b
例3:有參數(shù) 2 ,有返回值
讓內(nèi)聯(lián)匯編做加法運算,求a+b,結(jié)果存在sum中,把a-b的存在d中
asm volatile
(
"add %[op1],%[op2],%[op3] "
"sub %[op4],%[op2],%[op3] "
:[op1]"=r"(sum),[op4]"=r"(d)
:[op2]"r"(a),[op3]"r"(b)
:"memory"
);
%0 對應(yīng)變量c%1 對應(yīng)變量a%2 對應(yīng)變量b
-
嵌入式設(shè)計
+關(guān)注
關(guān)注
0文章
390瀏覽量
21284 -
C程序
+關(guān)注
關(guān)注
4文章
254瀏覽量
36027
發(fā)布評論請先 登錄
相關(guān)推薦
評論