C指針原理(7)-C內嵌匯編
阿新 • • 發佈:2018-11-30
ansi 部分 add 理解 $2 %d turn print 完成 如何在內聯匯編中訪問C程序的局部變量呢,請看下面這段代碼。
#include <stdio.h> int main(void){ //不使用全局變量,必須使用擴展GNU的asm //格式為:asm("匯編代碼":輸出位置:輸入位置:改動的寄存器列表) //a為eax,ax,al;b為ebx等;c為ecx等;d為edx等;S為esi或si;D為edi或di //+讀和寫;=寫;%如果必要,操作數可以和下一個操作數切換;&在內聯函數完成之前,可以刪除或重新使用操作數 int xa=6; int xb=2; int result; //ansi c標準的asm有其它用,所以用__asm__,__volatile__表示內聯匯編部分不用優化(可以用volatile,但是ansi c不行),以防優化破壞內聯代碼組織結構 asm volatile( "add %%ebx,%%eax\n\t" "movl $2,%%ecx\n\t" "mul %%ecx\n\t" "movl %%eax,%%edx" :"=d"(result):"a"(xa),"b"(xb):"%ecx");//註意擴展方式使用2個%表示 printf("%d\n",result); return 0; }
這個例子完成這個計算:(xa+xb)2=(6+2)2=16
???? 不使用全局變量與匯編代碼交互,我們必須使用擴展GNU的asm?,格式為:
??? ? asm("匯編代碼":輸出位置:輸入位置:改動的寄存器列表)???
???????匯編代碼中涉及寄存器部分的使用2個“%”,如:使用%%eax表示eax寄存器
????? ?輸出位置、輸入位置的特殊命名規則為:
????? a為eax,ax,al;b為ebx等;c為ecx等;d為edx等;S為esi或si;D為edi或di???
??????+讀和寫
????? =寫
????? %如果必要,操作數可以和下一個操作數切換
????? &在內聯函數完成之前,可以刪除或重新使用操作數
??? 上述代碼中,匯編代碼部分為
??? 輸出位置、輸入位置、改動的寄存器列表部分為:
???? :"=d"(result):"a"(xa),"b"(xb):"%ecx"
???? 先來看匯編代碼部分,使用雙%號表示寄存器,比如:
?????"add %%ebx,%%eax\n\t"
???? ?關於輸出位置、輸入位置部分,可以這麽理解:將變量與寄存器綁定,綁定後,對寄存器的操作就是對變量的操作。
?????? :"=d"(result):"a"(xa),"b"(xb)
?????? 將result與寄存器edx綁定,xa與寄存器eax綁定,xb與寄存器ebx綁定。
?????? %ecx屬於需要改動的寄存器
C指針原理(7)-C內嵌匯編