[AIX][XCOFF] Use bit order of has_vec and longtbtable bits as defined in AIX header...
authorzhijian <zhijian@ca.ibm.com>
Fri, 9 Jul 2021 15:06:46 +0000 (11:06 -0400)
committerzhijian <zhijian@ca.ibm.com>
Fri, 9 Jul 2021 15:06:46 +0000 (11:06 -0400)
commit841077a7e9806f6b288c93dca86dc141cbf5a01d
tree7e18152f992b39c31f7c9dbb7fc92c81bb69c686
parentf551fb96c7fbe38628f049bfe0e48a6943ee341f
[AIX][XCOFF] Use bit order of has_vec and longtbtable bits as defined in AIX header debug.h

Summary:

  The bit order of the has_vec and longtbtable bits in the traceback table generated by the XL compiler flipped at some point after v12.1. This is different from the definition is the AIX header debug.h. The change in the XL compiler that caused the deviation from the OS header definition was unintentional. Since both orderings are extant and the XL compiler runtime also expects the ordering defined by the OS, we will correct the output from LLVM to match the defined ordering given by the OS (which is also consistent with the Assembler Language Reference). Mitigation for traceback tables encoded with the wrong ordering is required for either ordering.

Reviewers: XingXue, HubertTong
Differential Revision: https://reviews.llvm.org/D105487
llvm/include/llvm/BinaryFormat/XCOFF.h
llvm/lib/Target/PowerPC/PPCAsmPrinter.cpp
llvm/test/CodeGen/PowerPC/aix-emit-tracebacktable-clobber-register.ll
llvm/test/CodeGen/PowerPC/aix-emit-tracebacktable-vectorinfo.ll
llvm/test/CodeGen/PowerPC/aix-emit-tracebacktable-vectorinfo_hasvarg.ll
llvm/test/CodeGen/PowerPC/aix-emit-tracebacktable.ll
llvm/test/CodeGen/PowerPC/aix-exception.ll
llvm/test/CodeGen/PowerPC/aix-tracetable-csr.ll
llvm/test/DebugInfo/XCOFF/empty.ll
llvm/test/DebugInfo/XCOFF/explicit-section.ll
llvm/test/DebugInfo/XCOFF/function-sections.ll