Back to home page

EIC code displayed by LXR

 
 

    


File indexing completed on 2026-05-10 08:44:43

0001 //===- llvm/Transforms/Utils/LowerVectorIntrinsics.h ------------*- C++ -*-===//
0002 //
0003 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
0004 // See https://llvm.org/LICENSE.txt for license information.
0005 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
0006 //
0007 //===----------------------------------------------------------------------===//
0008 //
0009 // Lower intrinsics with a scalable vector arg to loops.
0010 //
0011 //===----------------------------------------------------------------------===//
0012 
0013 #ifndef LLVM_TRANSFORMS_UTILS_LOWERVECTORINTRINSICS_H
0014 #define LLVM_TRANSFORMS_UTILS_LOWERVECTORINTRINSICS_H
0015 
0016 #include <cstdint>
0017 #include <optional>
0018 
0019 namespace llvm {
0020 
0021 class CallInst;
0022 class Module;
0023 
0024 /// Lower \p CI as a loop. \p CI is a unary intrinsic with a vector argument and
0025 /// is deleted and replaced with a loop.
0026 bool lowerUnaryVectorIntrinsicAsLoop(Module &M, CallInst *CI);
0027 
0028 } // namespace llvm
0029 
0030 #endif