linux - 在 i386 的 linux 内核 2.6.11 中,此内联汇编 (:"0"(THREAD_SIZE - 1)) 的含义是什么

标签 linux assembly kernel i386 irq

在do_IRQ中可以找到如下代码!

#ifdef CONFIG_DEBUG_STACKOVERFLOW
   /* Debugging check for stack overflow: is there less than 1KB free? */
    {
       long esp;

        __asm__ __volatile__("andl %%esp,%0" :
                "=r" (esp) : "0" (THREAD_SIZE - 1));
       if (unlikely(esp < (sizeof(struct thread_info) + STACK_WARN))) {
           printk("do_IRQ: stack overflow: %ld\n",
                esp - sizeof(struct thread_info));
            dump_stack();
        }
    }
#endif

我没看懂这个asm汇编的意思
asm _volatile_("andl %%esp,%0": "=r"(esp) : "0"(THREAD_SIZE - 1)); THREAD_SIZE - 1 意味着什么? 我记得括号里的符号应该是输出部分的esp一样的C变量,但输入部分看起来像整数而不是C符号,有没有人帮忙

最佳答案

"0" 约束意味着:使用与第 0 个操作数相同的约束( http://www.ibiblio.org/gferg/ldp/GCC-Inline-Assembly-HOWTO.html#ss6.1 和 6.1.3 匹配(数字)约束)。

基本上,此代码段将 THREAD_SIZE - 1 作为输入寄存器,并在同一寄存器中输出一个与值。该寄存器在源代码中被引用为 esp 变量。

关于linux - 在 i386 的 linux 内核 2.6.11 中,此内联汇编 (:"0"(THREAD_SIZE - 1)) 的含义是什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21904753/

相关文章:

Linux - 如何将 file1.txt 的全部内容插入到 file2.txt 的第 4 行

linux - GNU makefile 中的 Qt 资源

c - AMD64 指令指针中的奇怪行为

c - 向量化模运算

linux - 在 Linux 内核中, header 包含错误

language-agnostic - 单片内核和微内核有什么区别?

c - 无需等待接收整个文件即可发送文件

linux - 使用 bash 脚本获取文件名

c - 汇编中参数的 GDB 字符集

python - 从/proc/stat 计算 user、nice、sys、idle、iowait、irq 和 sirq