omjavaid added a comment.

@labath

I have considered alternatives which can be used to avoid this patch altogether.

We are creating dynamic register infos vector for SVE in D77047 
<https://reviews.llvm.org/D77047>. This is needed because we have update 
register size and offset of SVE registers.

The reason this problem of register indexes not matching with native register 
number happens because we place SVE register set after debug registers in 
register infos list. Linux does not use debug register and thus we have to jump 
over those register indexes which creates a mismatch in value reg list of SVE Z 
registers. see here 
https://github.com/llvm-mirror/lldb/blob/master/source/Plugins/Process/Utility/RegisterInfos_arm64.h#L719

To solve this problem:

1. First option we have is that also update/correct the value_regs and LLDB 
register no while sharing these register infos to correct register indexes. 
This is more like a hack but should work as long as we correctly keep track of 
LLDB register nos that we assign to SVE register. Register nos are mostly 
considered constant and expected to remain fixed so it will be ugly to change 
them specially when they might also be used by other parts of code.

2. Second option is to avoid the use of debug registers altogether in SVE 
register infos list which will mean that sve register nos may overlap with 
debug registers and in future if some other target wants to implement sve 
register access then will have to correct this and push debug register after 
SVE registers in the list.

3. and final option is what I have already implemented in this patch.

What do you think?


CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D77043/new/

https://reviews.llvm.org/D77043



_______________________________________________
lldb-commits mailing list
lldb-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits

Reply via email to