原创

GNU C内嵌汇编学习笔记

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://latelee.blog.csdn.net/article/details/50676744

前文所述,只是针对汇编格式的整理,本文将使用coreboot项目代码对其进行实例化。以方便、清晰了解到如何在C语言里使用内嵌汇编的方法。同样地,网络上也有众多文章涉及到这方面,所以本文更多是归纳总结。形成自己的学习笔记。

内嵌汇编一般格式如下:
asm volatile("Instruction List"
                : Output
                : Input
                : Clobber/Modify);
注意,Output、Input、Clobber/Modify都是可选的,因为有的指令没有输入输出,有的指令只有输入或只有输出。

下面是来自coreboot代码读、写msr的函数:

// msr,Model Specific Register,使用rdmsr、wrmsr分别读写MSR
// rdmsr读取64比特MSR数据放到edx和eax (分别为高低32比特) wrms同理
// 寄存器索引在ecx中
static inline __attribute__((always_inline)) msr_t rdmsr(unsigned index)
{
msr_t result;
__asm__ __volatile__ (
"rdmsr"
: "=a" (result.lo), "=d" (result.hi)
: "c" (index)
);
return result;
}


static inline __attribute__((always_inline)) void wrmsr(unsigned index, msr_t msr)
{
__asm__ __volatile__ (
"wrmsr"
: /* No outputs */
: "c" (index), "a" (msr.lo), "d" (msr.hi)
);
}


/*
 * Generic CPUID function
 */
static inline struct cpuid_result cpuid(int op)
{
struct cpuid_result result;
asm volatile(
"mov %%ebx, %%edi;"
"cpuid;"
"mov %%ebx, %%esi;"
"mov %%edi, %%ebx;"
: "=a" (result.eax),
 "=S" (result.ebx),
 "=c" (result.ecx),
 "=d" (result.edx)
: "0" (op)
: "edi");
return result;
}



coreboot项目主页:http://www.coreboot.org/

http://blog.csdn.net/surfacedust/article/details/17138675


文章最后发布于: 2016-02-17 19:00:43
展开阅读全文
0 个人打赏
私信求帮助

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 技术工厂 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览