資源描述:
《armgcc內(nèi)嵌匯編手冊(cè)》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在應(yīng)用文檔-天天文庫(kù)。
1、轉(zhuǎn)自:http://blogold.chinaunix.net/u2/69404/showart_1922655.htmlARMGCC內(nèi)嵌(inline)匯編手冊(cè)關(guān)于這篇文檔這篇文章是本人為方便各位業(yè)界同仁而翻譯,方便大家開發(fā)底層代碼使用,轉(zhuǎn)載請(qǐng)注明出處,謝謝。要是你E文功底好,本人還是建議閱讀E文版的。http://www.ethernut.de/en/documents/arm-inline-asm.html對(duì)于基于ARM的RISC處理器,GNUC編譯器提供了在C代碼中內(nèi)嵌匯編的功能。這種非??岬奶匦蕴峁┝薈代碼沒有的功
2、能,比如手動(dòng)優(yōu)化軟件關(guān)鍵部分的代碼、使用相關(guān)的處理器指令。這里設(shè)想了讀者是熟練編寫ARM匯編程序讀者,因?yàn)樵撈臋n不是ARM匯編手冊(cè)。同樣也不是C語(yǔ)言手冊(cè)。這篇文檔假設(shè)使用的是GCC4的版本,但是對(duì)于早期的版本也有效。GCCasm聲明讓我們以一個(gè)簡(jiǎn)單的例子開始。就像C中的聲明一樣,下面的聲明代碼可能出現(xiàn)在你的代碼中。/*NOP例子*/asm("movr0,r0");該語(yǔ)句的作用是將r0移動(dòng)到r0中。換句話講他并不干任何事。典型的就是NOP指令,作用就是短時(shí)的延時(shí)。請(qǐng)接著閱讀和學(xué)習(xí)這篇文檔,因?yàn)樵撀暶鞑⒉幌衲阆胂蟮暮推渌腃語(yǔ)
3、句一樣。內(nèi)嵌匯編使用匯編指令就像在純匯編程序中使用的方法一樣??梢栽谝粋€(gè)asm聲明中寫多個(gè)匯編指令。但是為了增加程序的可讀性,最好將每一個(gè)匯編指令單獨(dú)放一行。asm("movr0,r0t""movr0,r0t""movr0,r0t""movr0,r0");換行符和制表符的使用可以使得指令列表看起來變得美觀。你第一次看起來可能有點(diǎn)怪異,但是當(dāng)C編譯器編譯C語(yǔ)句的是候,它就是按照上面(換行和制表)生成匯編的。到目前為止,匯編指令和你寫的純匯編程序中的代碼沒什么區(qū)別。但是對(duì)比其它的C聲明,asm的常量和寄存器的處
4、理是不一樣的。通用的內(nèi)嵌匯編模版是這樣的。asm(code:outputoperandlist:inputoperandlist:clobberlist);匯編和C語(yǔ)句這間的聯(lián)系是通過上面asm聲明中可選的outputoperandlist和inputoperandlist。Clobberlist后面再講。下面是將C語(yǔ)言的一個(gè)整型變量傳遞給匯編,邏輯左移一位后在傳遞給C語(yǔ)言的另外一個(gè)整型變量。/*Rotatingbitsexample*/asm("mov%[result],%[value],ror#1":[result]"=
5、r"(y):[value]"r"(x));每一個(gè)asm語(yǔ)句被冒號(hào)(:)分成了四個(gè)部分。l匯編指令放在第一部分中的“”中間。"mov%[result],%[value],ror#1"l接下來是冒號(hào)后的可選擇的outputoperandlist,每一個(gè)條目是由一對(duì)[](方括號(hào))和被他包括的符號(hào)名組成,它后面跟著限制性字符串,再后面是圓括號(hào)和它括著的C變量。這個(gè)例子中只有一個(gè)條目。[result]"=r"(y)l接著冒號(hào)后面是輸入操作符列表,它的語(yǔ)法和輸入操作列表一樣[value]"r"(x)l破壞符列表,在本例中沒有使用就像上面
6、的NOP例子,asm聲明的4個(gè)部分中,只要最尾部沒有使用的部分都可以省略。但是有有一點(diǎn)要注意的是,上面的4個(gè)部分中只要后面的還要使用,前面的部分沒有使用也不能省略,必須空但是保留冒號(hào)。下面的一個(gè)例子就是設(shè)置ARMSoc的CPSR寄存器,它有input但是沒有outputoperand。asm("msrcpsr,%[ps]"::[ps]"r"(status))即使匯編代碼沒有使用,代碼部分也要保留空字符串。下面的例子使用了一個(gè)特別的破壞符,目的就是告訴編譯器內(nèi)存被修改過了。這里的破壞符在下面的優(yōu)化部分在講解。asm("":::
7、"memory");為了增加代碼的可讀性,你可以使用換行,空格,還有C風(fēng)格的注釋。asm("mov%[result],%[value],ror#1":[result]"=r"(y)/*Rotationresult.*/:[value]"r"(x)/*Rotatedvalue.*/:/*Noclobbers*/);在代碼部分%后面跟著的是后面兩個(gè)部分方括號(hào)中的符號(hào),它指的是相同符號(hào)操作列表中的一個(gè)條目。%[result]表示第二部分的C變量y,%[value]表示三部分的C變量x;符號(hào)操作符的名字使用了獨(dú)立的命名空間。這就意味
8、著它使用的是其他的符號(hào)表。簡(jiǎn)單一點(diǎn)就是說你不必關(guān)心使用的符號(hào)名在C代碼中已經(jīng)使用了。在早期的C代碼中,循環(huán)移位的例子必須要這么寫:asm("mov%0,%1,ror#1":"=r"(result):"r"(value))在匯編代碼中操作數(shù)的引用使用的是%后面跟一個(gè)數(shù)字,%1代表第一個(gè)操作數(shù)