- Added documentation for the CC and Flags Locations created by statepoints.
- Added some suggested comments
Details
Diff Detail
Event Timeline
Minor comments below. Looks close to ready.
I'm mildly disturbed you didn't need to change anything else in the backend. Did you audit things like X86MCInstLowering and X86ISelLowering to make sure they weren't using raw indices into the operand list?
include/llvm/CodeGen/StackMaps.h | ||
---|---|---|
102 | Why two enums? I suspect there's a semantic difference, possibly a name or comment is appropriate? | |
test/CodeGen/X86/statepoint-allocas.ll | ||
75–80 | With this change, you're changing the public format. Thus, we need to update: http://llvm.org/docs/Statepoints.html#stack-map-format Having said that, it looks like the documentation never included the flags at all. Oops. Can you add entries for both calling convention and flags? |
I did, yes.Nearly all of the code that would be sensitive to operand indices is in StackMap.{c,h}, and it is very good about using accessors and/or symbolic offsets.
include/llvm/CodeGen/StackMaps.h | ||
---|---|---|
102 | There is a semantic difference:
I'll add a comment to that effect. | |
test/CodeGen/X86/statepoint-allocas.ll | ||
75–80 | Will do. |
LGTM. One optional comment, no further review needed.
Thanks.
docs/Statepoints.rst | ||
---|---|---|
486 | Can you add something to the effect of: This constant is a valid calling convention identifier (http://llvm.org/docs/LangRef.html#calling-conventions) for the version of LLVM used to generate the stackmap. There are no additional compatibility guarantees made for this field over what LLVM provides elsewhere w.r.t. these indentifiers. |
Can you add something to the effect of: This constant is a valid calling convention identifier (http://llvm.org/docs/LangRef.html#calling-conventions) for the version of LLVM used to generate the stackmap. There are no additional compatibility guarantees made for this field over what LLVM provides elsewhere w.r.t. these indentifiers.