#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;
//使用占位符,由r表示,编译器自主选择使用哪些寄存器,%0,%1。。。表示第1、2。。。个变量
asm volatile(
"add %1,%2\n\t"
"movl %2,%0"
:"=r"(result):"r"(xa),"r"(xb));
printf("%d\n",result);
return 0;
}
deepfuture@deepfuture-laptop:~/private/mytest$ gcc -o testasmc testasmc.c
deepfuture@deepfuture-laptop:~/private/mytest$ ./testasmc
8
deepfuture@deepfuture-laptop:~/private/mytest$
二、引用占位符
#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;
//替换占位符,声明替换名称占位符。由r表示,编译器自主选择使用哪些寄存器,%0,%1。。。表示第1、2。。。个变量,
//"0"(xb)为引用占位符,表示使用第一个命令的寄存器存放xb输出值
asm volatile(
"add %1,%0\n\t"
:"=r"(xb):"r"(xa),"0"(xb));
printf("%d\n",xb);
return 0;
}
三、替换占位符
#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;
//替换占位符,声明替换名称占位符。由r表示,编译器自主选择使用哪些寄存器,%0,%1。。。表示第1、2。。。个变量,
//"0"(xb)为引用占位符,表示使用第一个命令的寄存器存放xb输出值
asm volatile(
"add %[mya],%[myb]\n\t"
:[myb]"=r"(xb):[mya]"r"(xa),"0"(xb));
printf("%d\n",xb);
return 0;
}
使用内存位置。使用m标记
int x=2;
int y=6;
int result;
asm("movl %1 %%eax\n\t"
"addl %2 %%eax \n\t"
"movl %%eax,%0\n\t"
:"=m"(result)
:"a"(x),"m"(y)
)
本文详细介绍了如何在GCC中使用内联汇编进行低级控制。通过具体示例展示了不同类型的占位符如普通占位符、引用占位符和替换占位符的用法,并解释了如何指定寄存器以及如何利用内存位置。
2210

被折叠的 条评论
为什么被折叠?



