[LLVMdev] Inline Assembly: Memory constraints with offsets
Krzysztof Parzyszek
kparzysz at codeaurora.org
Wed Mar 11 06:46:50 PDT 2015
On 3/9/2015 5:22 AM, Daniel Sanders wrote:
>
> I've had some luck with this. It turns out that the ISD::INLINE_ASM node has a flag operand corresponding to each operand in the source code. It's used for storing things like the matched operand number for the [0-9]+ constraints, the register class id for register constraints, etc. At first glance, the encoding looks full but it appears that when the lowest 3 bits are Kind_Mem (meaning it's a memory constraint), the upper 16-bits are never used. I've therefore used this gap to store a constraint ID which can then be inspected during instruction selection.
Fantastic! Yes, this is one of the places that I looked at, but to my
great disappointment the connection with the original constraint was not
preserved.
Thanks for doing this!
-Krzysztof
--
Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum,
hosted by The Linux Foundation
More information about the llvm-dev
mailing list