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");
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");
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
.
It is a special case of an asm label. It instructs the compiler to emit %gs:0
instead of the usual symbol name if you reference the cpu
variable. Presumably %gs
has been previously set up as a per-cpu storage area, with a struct cpu
pointer at offset zero. The purpose is to allow each cpu to access its own data.