blob: c0b0141c3da17bd67ffd2fc15ef0935b141d5933 [file] [log] [blame]
Andrew Scull0372a572018-11-16 15:47:06 +00001/*===-- AggressiveInstCombine.h ---------------------------------*- C++ -*-===*\
2|* *|
Andrew Walbran16937d02019-10-22 13:54:20 +01003|* Part of the LLVM Project, under the Apache License v2.0 with LLVM *|
4|* Exceptions. *|
5|* See https://llvm.org/LICENSE.txt for license information. *|
6|* SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception *|
Andrew Scull0372a572018-11-16 15:47:06 +00007|* *|
8|*===----------------------------------------------------------------------===*|
9|* *|
10|* This header declares the C interface to libLLVMAggressiveInstCombine.a, *|
11|* which combines instructions to form fewer, simple IR instructions. *|
12|* *|
13\*===----------------------------------------------------------------------===*/
14
15#ifndef LLVM_C_TRANSFORMS_AGGRESSIVEINSTCOMBINE_H
16#define LLVM_C_TRANSFORMS_AGGRESSIVEINSTCOMBINE_H
17
18#include "llvm-c/Types.h"
19
20#ifdef __cplusplus
21extern "C" {
22#endif
23
24/**
25 * @defgroup LLVMCTransformsAggressiveInstCombine Aggressive Instruction Combining transformations
26 * @ingroup LLVMCTransforms
27 *
28 * @{
29 */
30
31/** See llvm::createAggressiveInstCombinerPass function. */
32void LLVMAddAggressiveInstCombinerPass(LLVMPassManagerRef PM);
33
34/**
35 * @}
36 */
37
38#ifdef __cplusplus
39}
40#endif /* defined(__cplusplus) */
41
42#endif
43