Search code examples
gccx86inline-assemblyxv6

What does the declaration“extern struct cpu *cpu asm("%gs:0");” mean?


When I'm reading the xv6 source code, I'm confused about the syntax of the declaration below. Can anyone explain it to me?

extern struct cpu *cpu asm("%gs:0");

Solution

  • I assume you understand what extern struct cpu *cpu means. The question you have is: What does the asm("%gs:0") part mean?

    This code is using a gcc extension called asm labels to say that the variable cpu is defined by the assembler string %gs:0.

    This is NOT how this extension is intended to be used and is considered a hack.

    There's an excellent discussion of gs (and fs) here, but in short gs points to the current thread's local storage. The format of the data at gs depends on your OS (Windows is very different than Linux). This particular code is saying that at offset 0 from gs, there is a pointer to a struct cpu.