<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/74530>74530</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
[AArch64][Windows] Don't omit frame pointers in -Od
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
AndrewDeanMS
</td>
</tr>
</table>
<pre>
Given this source code:
```
#include <windows.h>
#include <stdio.h>
void* frames[5]{};
void innermost() {
CaptureStackBackTrace(0, 5, frames, nullptr);
}
void inner() {
innermost();
}
void outer() {
inner();
}
void outermost() {
outer();
}
int main() {
outermost();
printf("innermost: 0x%p\tframe[0]: 0x%p\n", &innermost, frames[0]);
printf(" inner: 0x%p\tframe[1]: 0x%p\n", &inner, frames[1]);
printf(" outer: 0x%p\tframe[2]: 0x%p\n", &outer, frames[2]);
printf("outermost: 0x%p\tframe[3]: 0x%p\n", &outermost, frames[3]);
printf(" main: 0x%p\tframe[4]: 0x%p\n", &main, frames[4]);
return 0;
}
```
Compile and run like so:
```
clang-cl /nologo /Zi /c /Od test.cpp
link /nologo /debug /incremental:no test.obj
test.exe
```
EXPECT: that the addresses in the backtrace are within the functions main, outermost, outer, inner, and innermost
ACTUAL: frame[0] is within innermost, but frame[1] is mainCRTStartup and frame[2] and frame[3] are in kernel32 and ntdll respectively.
```
innermost: 0x00007FF60BF51000 frame[0]: 0x00007FF60BF51024
inner: 0x00007FF60BF5102C frame[1]: 0x00007FF60BF51A8C
outer: 0x00007FF60BF5103C frame[2]: 0x00007FFACF782310
outermost: 0x00007FF60BF5104C frame[3]: 0x00007FFAD0E5577C
main: 0x00007FF60BF5105C frame[4]: 0x0000000000000000
```
Compare to cl:
```
cl /nologo /Zi /c /Od test.cpp
link /nologo /debug /incremental:no test.obj
test.exe
innermost: 0x00007FF7DA951588 frame[0]: 0x00007FF7DA9515B0
inner: 0x00007FF7DA9515B8 frame[1]: 0x00007FF7DA9515C4
outer: 0x00007FF7DA9515D0 frame[2]: 0x00007FF7DA9515DC
outermost: 0x00007FF7DA9515E8 frame[3]: 0x00007FF7DA9515F4
main: 0x00007FF7DA951600 frame[4]: 0x00007FF7DA95160C
```
I believe the issue here is that clang-cl is omitting the frame pointers for small functions, even with -Od.
Compare the assembly for `outermost` for clang-cl:
```
?outermost@@YAXXZ:
000000014000104C: str lr,[sp,#-0x10]!
0000000140001050: bl ?outer@@YAXXZ
0000000140001054: ldr lr,[sp],#0x10
0000000140001058: ret
```
with the assembly when using cl:
```
?outermost@@YAXXZ:
0000000140001640: stp fp,lr,[sp,#-0x10]!
0000000140001644: mov fp,sp
0000000140001648: bl ?outer@@YAXXZ
000000014000164C: ldp fp,lr,[sp],#0x10
0000000140001650: ret
```
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJy8V1GPozYX_TXOizWRMTaQhzwQMvn0Sa226k7V7b45cCfxjmMj28zs_vvKwCSQMGQrVY0iSPC959jH9x5AOCcPGmCN-Abx7UI0_mjsOteVhbctCP3r58XeVD_W_5OvoLE_SoedaWwJuDQVoDhHZItIjhLSf7u_NJa6VE0FGMXFm9SVeXPLI4ofp8adr6QZjOLu9GpkhWiOn604gUN8wxHfonSD0i2KNzehWGoN9mScRzRDdIVDaBeEMS5E7RsLn70oXzaifHmyogREM4JogXk49DS0wLpRqvYW0dWZJ3BOE06RXc1kHsU0fgJlgP0T6R-teoD9IYrUHp-E1B_mTywkjNVWav_cDtDLguMck--I8hrxwreSIr4hYeOGIxpRGpRGNBloVVy2us2YITyrPE0Y3SMckUU_QdYpOUlGZ8j6DRiQ0TtkF8knyeJ7ZDdSxvdW127-JBmbIetKZsDDJngs-MZqTG6L78ow-loszKmWCrDQFbaNxkq-AHbmI5spldCHh1JhRHfaKHMw4ddXGY5lOHyqsAfnl2VddxlK6pdxdAX75hB-SF1aOIH2QqE416bLNPtvXWb7D77D3PQfv_z2WDwFxfxReOyPgEVVWXAOHJa6vbAX5YsP5oOFBfwm_bEfeG506aXRDr9LO9rPcyWd6zeIdOmedgJ58fRH_kuYwLD1sHTvRKNu2zceDzsmxAXu4venz15Y39Qtx7DORxfi9oKFsLQXsBpUTNsA7SulsAVXQ-nlK6gfy5FOV-pduQchhKS7XUI2Ox4RQjDGt0YyDqLsynwng4oBUjSNlGfFtXtOIMVDJHqNlBe7NKNx1K_uqqHHSGyIFN8gbckj52k6mNOgW8dIfIjERkjDz73uC9vpDS7Vxz3333cbnquTdJuveMSzbK5O-qANGd1epyKyuSLpgwo2VyR90JbMFcl7UDFXJH3QYzZXJH3Qjs0VSReUjJqJTSMlpJgrkv_jPSgJr9CalnSuAXyEYAKuc72zKUuHzUl6L_WhM7jAi2sjtQfr8LOx2J2EUhfnC6YE4TkzuBV--FQtp-sz-KpzcNqrHy0MSshFwIS0196nca7jae9B8e6Syghi5K_8y5evlyzcN07EwoGwIkjmvMUqmDDiG1eHM40fyPeoe2yJplM5Cal7hc-fd_IhcZd6lclCpqrsOXNAHhgDf0s_TZyFdAt-bl9byUfKvh1B48aF7fu3ZUwY6WSs8XOQ759qmbBWkZN5PSvS4rh6Sr-EZT-v_HVq0Ul_O9G7uifdht_qvqjWcbWKV2IB6yglURaxmEWL4zoSEaQrzukzoWVaZYmISVllLKERWTGRLeSaEhpHlHBKI0qjpYh4HPHVqoqYSMUeECNwElItlXo9LY09LNoOXaeMx2ShxB6Ua9_1KNXw1rVveKbj24Vdh5yHfXNwiBElnXcXFC-9al8S89yWx6S1Dr75s3uxC48BW6MRTX3b8dedLnXo5UVj1frofe1CVdAdoruD9MdmvyzNCdFd4OpPD7U136D04T4RZugQ3bUr-DsAAP__Q-H5ew">