llvm-project/llvm/docs/GlobalISel
Matt Arsenault 1ee6ce9bad GlobalISel: Allow forming atomic/volatile G_ZEXTLOAD
SelectionDAG has a target hook, getExtendForAtomicOps, which it uses
in the computeKnownBits implementation for ATOMIC_LOAD. This is pretty
ugly (as is having a separate load opcode for atomics), so instead
allow making use of atomic zextload. Enable this for AArch64 since the
DAG path defaults in to the zext behavior.

The tablegen changes are pretty ugly, but partially helps migrate
SelectionDAG from using ISD::ATOMIC_LOAD to regular ISD::LOAD with
atomic memory operands. For now the DAG emitter will emit matchers for
patterns which the DAG will not produce.

I'm still a bit confused by the intent of the isLoad/isStore/isAtomic
bits. The DAG implementation rejects trying to use any of these in
combination. For now I've opted to make the isLoad checks also check
isAtomic, although I think having isLoad and isAtomic set on these
makes most sense.
2022-07-08 11:55:08 -04:00
..
GMIR.rst
GenericOpcode.rst GlobalISel: Allow forming atomic/volatile G_ZEXTLOAD 2022-07-08 11:55:08 -04:00
IRTranslator.rst GlobalISel: Update documentation 2021-05-05 17:35:02 -04:00
InstructionSelect.rst
KnownBits.rst
Legalizer.rst [NFC] Trim trailing whitespace in *.rst 2021-11-15 09:17:08 +08:00
Pipeline.rst
Porting.rst
RegBankSelect.rst
Resources.rst
block-extract.png
index.rst
pipeline-overview-customized.png
pipeline-overview-with-combiners.png
pipeline-overview.png
testing-pass-level.png
testing-unit-level.png