Legacy AIX assembly might not support all extended mnes,
add one feature bit to control the generation in MC,
and avoid generating them by default on AIX.
Details
- Reviewers
steven.zhang sfertile - Group Reviewers
Restricted Project - Commits
- rG0f588ac03e15: [PowerPC] Only use some extend mne if assembler is modern enough
Diff Detail
- Repository
- rG LLVM Github Monorepo
Event Timeline
clang -target powerpc64le-unknown-linux-gnu -c -o a.o modern-as.s error: instruction use requires an option to be enabled mfudscr 2
IIUC this patch is breaking compatibility with gas due to the AIX assembler not supporting the mnemonic. Similarly for my xxspltd patch, we wouldn't be able to encode the mnemonic without passing extra options on Linux. Thats why I took the approach I did in D94419. I am happy to change direction, but in my opinion we should only be disabling the mnemonics on AIX.
Yes, this patch should only disable it for AIX.
See the changes in Taget Machine.
I don't know why you get that failure, I will check.
@sfertile I have fixed the MC layer feature as well, please have another look. Thanks.
Thanks Jinsong, left a couple really minor comments. Will rebase the xxspltd fix on this patch now.
llvm/lib/Target/PowerPC/PPC.td | ||
---|---|---|
60 | Minor nit: I think name, option, description string, etc should explicitly reflect its the AIX assembler. | |
llvm/lib/Target/PowerPC/PPCInstrInfo.td | ||
1122 | ditto in adding AIX to the name. | |
llvm/test/MC/PowerPC/modern-as.s | ||
2 | We should have a run step that checks for the error when '-mattr=-modern-as`. | |
llvm/test/MC/PowerPC/ppc64-encoding-ext.s | ||
3422 | We can leave this test alone now that the mnemonic is accepted by default. |
llvm/lib/Target/PowerPC/PPC.td | ||
---|---|---|
60 | I updated the description and comments to mention AIX, but not the naming of feature. |
llvm/lib/Target/PowerPC/PPC.td | ||
---|---|---|
60 | If we find a bug in gas that necessitate disabling an alias and we attempt to use this same feature it would mean also disabling xxspltd and mtudscr on Linux breaking compatibility with gas. Likewise we would be disabling said alias on AIX breaking compatibility with the AIX system as for a gas bug. |
llvm/lib/Target/PowerPC/PPC.td | ||
---|---|---|
60 | Yes, unless we want to give one feature for each assembler limitation , there will be situation like, compiler will try to be conservative. |
llvm/lib/Target/PowerPC/PPC.td | ||
---|---|---|
60 | If we were only talking about what the compiler emits then I would agree with you 100%. But the Feature also affects what the integrated assembler accepts, in which case breaking compatability due to bugs on another platform isn't acceptable. There might be another approach though: we don't need to disable accepting the bugged/missing mnemonics in the integrated assembler (ie we always add +modern-as to the MCSubtargetInfo). Then we can have the conservative behaviour in what the compiler emits, still accept anything the reference assembler does, and not have to have multiple Features to control the behaviour. The down side is there is assembly integrated-as will accept that the reference assembler won't. |
llvm/lib/Target/PowerPC/PPC.td | ||
---|---|---|
60 | Anyway, I updated the name to be AIX specific now. We can introduce new feature bits for Linux later if really needed. |
Minor nit: I think name, option, description string, etc should explicitly reflect its the AIX assembler.