xref: /aosp_15_r20/external/llvm/lib/Target/Hexagon/HexagonTargetTransformInfo.cpp (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker //===-- HexagonTargetTransformInfo.cpp - Hexagon specific TTI pass --------===//
2*9880d681SAndroid Build Coastguard Worker //
3*9880d681SAndroid Build Coastguard Worker //                     The LLVM Compiler Infrastructure
4*9880d681SAndroid Build Coastguard Worker //
5*9880d681SAndroid Build Coastguard Worker // This file is distributed under the University of Illinois Open Source
6*9880d681SAndroid Build Coastguard Worker // License. See LICENSE.TXT for details.
7*9880d681SAndroid Build Coastguard Worker //
8*9880d681SAndroid Build Coastguard Worker /// \file
9*9880d681SAndroid Build Coastguard Worker /// This file implements a TargetTransformInfo analysis pass specific to the
10*9880d681SAndroid Build Coastguard Worker /// Hexagon target machine. It uses the target's detailed information to provide
11*9880d681SAndroid Build Coastguard Worker /// more precise answers to certain TTI queries, while letting the target
12*9880d681SAndroid Build Coastguard Worker /// independent and default TTI implementations handle the rest.
13*9880d681SAndroid Build Coastguard Worker ///
14*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
15*9880d681SAndroid Build Coastguard Worker 
16*9880d681SAndroid Build Coastguard Worker #include "HexagonTargetTransformInfo.h"
17*9880d681SAndroid Build Coastguard Worker #include "llvm/Support/Debug.h"
18*9880d681SAndroid Build Coastguard Worker 
19*9880d681SAndroid Build Coastguard Worker using namespace llvm;
20*9880d681SAndroid Build Coastguard Worker 
21*9880d681SAndroid Build Coastguard Worker #define DEBUG_TYPE "hexagontti"
22*9880d681SAndroid Build Coastguard Worker 
23*9880d681SAndroid Build Coastguard Worker TargetTransformInfo::PopcntSupportKind
getPopcntSupport(unsigned IntTyWidthInBit) const24*9880d681SAndroid Build Coastguard Worker HexagonTTIImpl::getPopcntSupport(unsigned IntTyWidthInBit) const {
25*9880d681SAndroid Build Coastguard Worker   // Return Fast Hardware support as every input  < 64 bits will be promoted
26*9880d681SAndroid Build Coastguard Worker   // to 64 bits.
27*9880d681SAndroid Build Coastguard Worker   return TargetTransformInfo::PSK_FastHardware;
28*9880d681SAndroid Build Coastguard Worker }
29*9880d681SAndroid Build Coastguard Worker 
30*9880d681SAndroid Build Coastguard Worker // The Hexagon target can unroll loops with run-time trip counts.
getUnrollingPreferences(Loop * L,TTI::UnrollingPreferences & UP)31*9880d681SAndroid Build Coastguard Worker void HexagonTTIImpl::getUnrollingPreferences(Loop *L,
32*9880d681SAndroid Build Coastguard Worker                                              TTI::UnrollingPreferences &UP) {
33*9880d681SAndroid Build Coastguard Worker   UP.Runtime = UP.Partial = true;
34*9880d681SAndroid Build Coastguard Worker }
35*9880d681SAndroid Build Coastguard Worker 
getNumberOfRegisters(bool vector) const36*9880d681SAndroid Build Coastguard Worker unsigned HexagonTTIImpl::getNumberOfRegisters(bool vector) const {
37*9880d681SAndroid Build Coastguard Worker   return vector ? 0 : 32;
38*9880d681SAndroid Build Coastguard Worker }
39