韦东山书MMU部分中的C代码嵌入了汇编指令,最后面有两行代码是这样的:
: /* 无输出 */
: "r" (ttb)
这是gcc嵌入汇编的写法,首先,GCC内联汇编的一般格式是这样的:
asm(
代码列表
:输出运算符列表
:输入运算符列表
:被更改资源列表
);
代码列表、输出运算符列表、输入运算符列表和被更改的资源列表被3个 ":"分隔。书中的代码只有两个":",且第一个":"后为空,说明这段代码无输出也无资源被更改。若代码后面根本没有":",说明这段代码内联汇编既无输出也无输入,也没有资源被更改,只留下了汇编代码部分。
void mmu_init(void)
{
unsigned long ttb = 0x30000000;
__asm__(
... ...
"mov r4, %0
"
... ...
: /* 无输出 */
: "r" (ttb) );}
代码中有一条mov指令,该指令将%0赋值给r4。这里,符号%0代表出现在输入运算符列表和输出运算符列表的第一个值。如果%1存在的话,那么它就代表出现在列表中的第二个值,依次类推。所以,该段代码中,%0代表的就是"r" (ttb)这个表达式的值,即0x30000000。
在"r"(ttb)这个表达式中,ttb代表的正是C语言向内联汇编输入的变量,操作符"r"则代表ttb的值会通过某一个寄存器来传递。在gcc中与之类似的操作符还包括"m","I"等等。