Oto prosty plik C z definicją enum i mainfunkcją:
enum days {MON, TUE, WED, THU};
int main() {
enum days d;
d = WED;
return 0;
}
Przenosi się na następujący LLVM IR:
define dso_local i32 @main() #0 {
%1 = alloca i32, align 4
%2 = alloca i32, align 4
store i32 0, i32* %1, align 4
store i32 2, i32* %2, align 4
ret i32 0
}
%2jest ewidentnie dzmienną, która otrzymuje 2 przypisane do niej. Co %1odpowiada, jeśli zero jest zwracane bezpośrednio?
clang-9 -S -emit-llvm simple.c
main( godbolt.org/z/kEtS-s ). Link pokazuje, w jaki sposób zespół jest mapowany na źródło
main, tajemnicza dodatkowa zmienna zniknie. Co ciekawe, znika również, jeśli returncałkowicie pominiesz instrukcję (co jest legalne mainw C i równoważne z return 0;).
mainjak int main(int argc, char **argv)widzisz argci argvkopiujesz na stos, ale tajemnicza zmienna zerowa nadal tam jest.