[llvm-dev] Updating RegMask inline
vivek pandya via llvm-dev
llvm-dev at lists.llvm.org
Fri May 27 19:20:31 PDT 2016
On Sat, May 28, 2016 at 7:46 AM, Mehdi Amini <mehdi.amini at apple.com> wrote:
>
>
> Sent from my iPhone
>
> On May 27, 2016, at 7:02 PM, vivek pandya <vivekvpandya at gmail.com> wrote:
>
>
>
> On Sat, May 28, 2016 at 7:29 AM, Matthias Braun <matze at braunis.de> wrote:
>
>>
>> On May 27, 2016, at 6:55 PM, vivek pandya via llvm-dev <
>> llvm-dev at lists.llvm.org> wrote:
>>
>>
>>
>> On Sat, May 28, 2016 at 12:23 AM, vivek pandya <vivekvpandya at gmail.com>
>> wrote:
>>
>>>
>>>
>>> On Sat, May 28, 2016 at 12:21 AM, Mehdi Amini <mehdi.amini at apple.com>
>>> wrote:
>>>
>>>>
>>>> > On May 27, 2016, at 11:49 AM, vivek pandya <vivekvpandya at gmail.com>
>>>> wrote:
>>>> >
>>>> > Hello Mentors,
>>>> >
>>>> > I have completed writing simple register mask calculator pass, an
>>>> immutable pass that stores RegMasks and provides API to query them, and a
>>>> target specific pass for X86 target which currently iterates through all MI
>>>> in given MF and if a call instruction is found then it quires for RegMask
>>>> to Immutable pass and prints which registers are clobbered and preserved as
>>>> per actual register allocation for callee function.
>>>> >
>>>> > So now I need to update RegMask for call instruction, so as per our
>>>> previous discussion on IRC if we add a method to update RegMask, Do we have
>>>> to do it in target specific way? Is it possible to have RegMask at fixed
>>>> position in Operands array in MI? Also provide some more details on
>>>> updating cached RegMask in various other class.
>>>>
>>>> Add a method "setOperandMask()" in class MachineOperand, and then when
>>>> you find a call you just walk all the operands till you find one which
>>>> "isRegMask()" at which point you can update it.
>>>>
>>>> Ok.
>>>
>>
>> Is it ok to add "setRegMaskOperand()" in class MI and looping through
>> operands to find RegMask is also included in method ?
>> -Vivek
>>
>>
>> I expect your code to be the only user of such a function so I would not
>> add it to MachineInstr but keep the code local in your pass for now (you
>> can add a static helper function in the .cpp file of your pass).
>>
>> But Operands are private to MI so It should go into MI or some other
> tricks like Friend Function ?
>
>
> Not sure what you mean by private here, can't you iterate the operands?
> I'd expect you to iterate the operands till op->isRegMask() is true, then
> you just have to update the regmask inside the operand. I think I already
> pointed you this, what's not working? Why are you trying to find a
> different solution?
>
> I got the previous idea, I just did not see iterators and I just thought
to move iteration to find RegMask from user code to MI but now it is
clear. Sorry for that : (
Vivek
>
>
>
> Vivek
>
>> - Matthias
>>
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20160528/9c58c049/attachment.html>
More information about the llvm-dev
mailing list