12345678910111213141516171819202122232425262728293031323334353637383940 |
- //==- AArch64PBQPRegAlloc.h - AArch64 specific PBQP constraints --*- C++ -*-==//
- //
- // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
- // See https://llvm.org/LICENSE.txt for license information.
- // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
- //
- //===----------------------------------------------------------------------===//
- #ifndef LLVM_LIB_TARGET_AARCH64_AARCH64PBQPREGALOC_H
- #define LLVM_LIB_TARGET_AARCH64_AARCH64PBQPREGALOC_H
- #include "llvm/ADT/SetVector.h"
- #include "llvm/CodeGen/PBQPRAConstraint.h"
- namespace llvm {
- class TargetRegisterInfo;
- /// Add the accumulator chaining constraint to a PBQP graph
- class A57ChainingConstraint : public PBQPRAConstraint {
- public:
- // Add A57 specific constraints to the PBQP graph.
- void apply(PBQPRAGraph &G) override;
- private:
- SmallSetVector<unsigned, 32> Chains;
- const TargetRegisterInfo *TRI;
- // Add the accumulator chaining constraint, inside the chain, i.e. so that
- // parity(Rd) == parity(Ra).
- // \return true if a constraint was added
- bool addIntraChainConstraint(PBQPRAGraph &G, unsigned Rd, unsigned Ra);
- // Add constraints between existing chains
- void addInterChainConstraint(PBQPRAGraph &G, unsigned Rd, unsigned Ra);
- };
- } // end namespace llvm
- #endif // LLVM_LIB_TARGET_AARCH64_AARCH64PBQPREGALOC_H
|