2020-11-05 02:08:34 +08:00
|
|
|
//===-- mlir-c/AffineMap.h - C API for MLIR Affine maps -----------*- 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
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
2020-08-18 16:26:30 +08:00
|
|
|
|
|
|
|
#ifndef MLIR_C_AFFINEMAP_H
|
|
|
|
#define MLIR_C_AFFINEMAP_H
|
|
|
|
|
2021-01-08 20:36:27 +08:00
|
|
|
#include "mlir-c/AffineExpr.h"
|
2020-08-18 16:26:30 +08:00
|
|
|
#include "mlir-c/IR.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2020-11-05 02:08:34 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2021-01-25 22:22:16 +08:00
|
|
|
// Opaque type declarations.
|
|
|
|
//
|
|
|
|
// Types are exposed to C bindings as structs containing opaque pointers. They
|
|
|
|
// are not supposed to be inspected from C. This allows the underlying
|
|
|
|
// representation to change without affecting the API users. The use of structs
|
|
|
|
// instead of typedefs enables some type safety as structs are not implicitly
|
|
|
|
// convertible to each other.
|
|
|
|
//
|
|
|
|
// Instances of these types may or may not own the underlying object. The
|
|
|
|
// ownership semantics is defined by how an instance of the type was obtained.
|
2020-11-05 02:08:34 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2020-11-03 02:56:25 +08:00
|
|
|
|
|
|
|
#define DEFINE_C_API_STRUCT(name, storage) \
|
|
|
|
struct name { \
|
|
|
|
storage *ptr; \
|
|
|
|
}; \
|
|
|
|
typedef struct name name
|
|
|
|
|
2020-08-18 16:26:30 +08:00
|
|
|
DEFINE_C_API_STRUCT(MlirAffineMap, const void);
|
|
|
|
|
2020-11-03 02:56:25 +08:00
|
|
|
#undef DEFINE_C_API_STRUCT
|
|
|
|
|
2020-11-05 02:08:34 +08:00
|
|
|
/// Gets the context that the given affine map was created with
|
2020-11-09 08:49:36 +08:00
|
|
|
MLIR_CAPI_EXPORTED MlirContext mlirAffineMapGetContext(MlirAffineMap affineMap);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2020-11-05 02:08:34 +08:00
|
|
|
/// Checks whether an affine map is null.
|
2020-11-30 10:31:11 +08:00
|
|
|
static inline bool mlirAffineMapIsNull(MlirAffineMap affineMap) {
|
2020-09-14 22:52:22 +08:00
|
|
|
return !affineMap.ptr;
|
|
|
|
}
|
|
|
|
|
2020-11-05 02:08:34 +08:00
|
|
|
/// Checks if two affine maps are equal.
|
2020-11-30 10:31:11 +08:00
|
|
|
MLIR_CAPI_EXPORTED bool mlirAffineMapEqual(MlirAffineMap a1, MlirAffineMap a2);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2021-01-25 22:22:16 +08:00
|
|
|
/// Prints an affine map by sending chunks of the string representation and
|
|
|
|
/// forwarding `userData to `callback`. Note that the callback may be called
|
|
|
|
/// several times with consecutive chunks of the string.
|
2020-11-09 08:49:36 +08:00
|
|
|
MLIR_CAPI_EXPORTED void mlirAffineMapPrint(MlirAffineMap affineMap,
|
|
|
|
MlirStringCallback callback,
|
|
|
|
void *userData);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2020-11-05 02:08:34 +08:00
|
|
|
/// Prints the affine map to the standard error stream.
|
2020-11-09 08:49:36 +08:00
|
|
|
MLIR_CAPI_EXPORTED void mlirAffineMapDump(MlirAffineMap affineMap);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2021-01-25 22:22:16 +08:00
|
|
|
/// Creates a zero result affine map with no dimensions or symbols in the
|
|
|
|
/// context. The affine map is owned by the context.
|
2020-11-09 08:49:36 +08:00
|
|
|
MLIR_CAPI_EXPORTED MlirAffineMap mlirAffineMapEmptyGet(MlirContext ctx);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2021-01-25 22:22:16 +08:00
|
|
|
/// Creates a zero result affine map of the given dimensions and symbols in the
|
|
|
|
/// context. The affine map is owned by the context.
|
2021-01-08 20:36:27 +08:00
|
|
|
MLIR_CAPI_EXPORTED MlirAffineMap mlirAffineMapZeroResultGet(
|
|
|
|
MlirContext ctx, intptr_t dimCount, intptr_t symbolCount);
|
|
|
|
|
2021-01-25 22:22:16 +08:00
|
|
|
/// Creates an affine map with results defined by the given list of affine
|
|
|
|
/// expressions. The map resulting map also has the requested number of input
|
|
|
|
/// dimensions and symbols, regardless of them being used in the results.
|
|
|
|
|
2020-11-09 08:49:36 +08:00
|
|
|
MLIR_CAPI_EXPORTED MlirAffineMap mlirAffineMapGet(MlirContext ctx,
|
|
|
|
intptr_t dimCount,
|
2021-01-08 20:36:27 +08:00
|
|
|
intptr_t symbolCount,
|
|
|
|
intptr_t nAffineExprs,
|
|
|
|
MlirAffineExpr *affineExprs);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2021-01-25 22:22:16 +08:00
|
|
|
/// Creates a single constant result affine map in the context. The affine map
|
|
|
|
/// is owned by the context.
|
2020-11-09 08:49:36 +08:00
|
|
|
MLIR_CAPI_EXPORTED MlirAffineMap mlirAffineMapConstantGet(MlirContext ctx,
|
|
|
|
int64_t val);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2021-01-25 22:22:16 +08:00
|
|
|
/// Creates an affine map with 'numDims' identity in the context. The affine map
|
|
|
|
/// is owned by the context.
|
2020-11-09 08:49:36 +08:00
|
|
|
MLIR_CAPI_EXPORTED MlirAffineMap
|
|
|
|
mlirAffineMapMultiDimIdentityGet(MlirContext ctx, intptr_t numDims);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2021-01-25 22:22:16 +08:00
|
|
|
/// Creates an identity affine map on the most minor dimensions in the context.
|
|
|
|
/// The affine map is owned by the context. The function asserts that the number
|
|
|
|
/// of dimensions is greater or equal to the number of results.
|
2020-11-09 08:49:36 +08:00
|
|
|
MLIR_CAPI_EXPORTED MlirAffineMap
|
|
|
|
mlirAffineMapMinorIdentityGet(MlirContext ctx, intptr_t dims, intptr_t results);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2021-01-25 22:22:16 +08:00
|
|
|
/// Creates an affine map with a permutation expression and its size in the
|
|
|
|
/// context. The permutation expression is a non-empty vector of integers.
|
|
|
|
/// The elements of the permutation vector must be continuous from 0 and cannot
|
|
|
|
/// be repeated (i.e. `[1,2,0]` is a valid permutation. `[2,0]` or `[1,1,2]` is
|
|
|
|
/// an invalid invalid permutation.) The affine map is owned by the context.
|
2020-11-09 08:49:36 +08:00
|
|
|
MLIR_CAPI_EXPORTED MlirAffineMap mlirAffineMapPermutationGet(
|
|
|
|
MlirContext ctx, intptr_t size, unsigned *permutation);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2021-01-25 22:22:16 +08:00
|
|
|
/// Checks whether the given affine map is an identity affine map. The function
|
|
|
|
/// asserts that the number of dimensions is greater or equal to the number of
|
|
|
|
/// results.
|
2020-11-30 10:31:11 +08:00
|
|
|
MLIR_CAPI_EXPORTED bool mlirAffineMapIsIdentity(MlirAffineMap affineMap);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2020-11-05 02:08:34 +08:00
|
|
|
/// Checks whether the given affine map is a minor identity affine map.
|
2020-11-30 10:31:11 +08:00
|
|
|
MLIR_CAPI_EXPORTED bool mlirAffineMapIsMinorIdentity(MlirAffineMap affineMap);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2020-11-05 02:08:34 +08:00
|
|
|
/// Checks whether the given affine map is an empty affine map.
|
2020-11-30 10:31:11 +08:00
|
|
|
MLIR_CAPI_EXPORTED bool mlirAffineMapIsEmpty(MlirAffineMap affineMap);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2021-01-25 22:22:16 +08:00
|
|
|
/// Checks whether the given affine map is a single result constant affine
|
|
|
|
/// map.
|
2020-11-30 10:31:11 +08:00
|
|
|
MLIR_CAPI_EXPORTED bool mlirAffineMapIsSingleConstant(MlirAffineMap affineMap);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2021-01-25 22:22:16 +08:00
|
|
|
/// Returns the constant result of the given affine map. The function asserts
|
|
|
|
/// that the map has a single constant result.
|
2020-11-09 08:49:36 +08:00
|
|
|
MLIR_CAPI_EXPORTED int64_t
|
|
|
|
mlirAffineMapGetSingleConstantResult(MlirAffineMap affineMap);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2020-11-05 02:08:34 +08:00
|
|
|
/// Returns the number of dimensions of the given affine map.
|
2020-11-09 08:49:36 +08:00
|
|
|
MLIR_CAPI_EXPORTED intptr_t mlirAffineMapGetNumDims(MlirAffineMap affineMap);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2020-11-05 02:08:34 +08:00
|
|
|
/// Returns the number of symbols of the given affine map.
|
2020-11-09 08:49:36 +08:00
|
|
|
MLIR_CAPI_EXPORTED intptr_t mlirAffineMapGetNumSymbols(MlirAffineMap affineMap);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2020-11-05 02:08:34 +08:00
|
|
|
/// Returns the number of results of the given affine map.
|
2020-11-09 08:49:36 +08:00
|
|
|
MLIR_CAPI_EXPORTED intptr_t mlirAffineMapGetNumResults(MlirAffineMap affineMap);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2021-01-08 20:36:27 +08:00
|
|
|
/// Returns the result at the given position.
|
|
|
|
MLIR_CAPI_EXPORTED MlirAffineExpr
|
|
|
|
mlirAffineMapGetResult(MlirAffineMap affineMap, intptr_t pos);
|
|
|
|
|
2021-01-25 22:22:16 +08:00
|
|
|
/// Returns the number of inputs (dimensions + symbols) of the given affine
|
|
|
|
/// map.
|
2020-11-09 08:49:36 +08:00
|
|
|
MLIR_CAPI_EXPORTED intptr_t mlirAffineMapGetNumInputs(MlirAffineMap affineMap);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2021-01-25 22:22:16 +08:00
|
|
|
/// Checks whether the given affine map represents a subset of a symbol-less
|
|
|
|
/// permutation map.
|
2020-11-30 10:31:11 +08:00
|
|
|
MLIR_CAPI_EXPORTED bool
|
2020-11-09 08:49:36 +08:00
|
|
|
mlirAffineMapIsProjectedPermutation(MlirAffineMap affineMap);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2021-01-25 22:22:16 +08:00
|
|
|
/// Checks whether the given affine map represents a symbol-less permutation
|
|
|
|
/// map.
|
2020-11-30 10:31:11 +08:00
|
|
|
MLIR_CAPI_EXPORTED bool mlirAffineMapIsPermutation(MlirAffineMap affineMap);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2020-11-05 02:08:34 +08:00
|
|
|
/// Returns the affine map consisting of the `resultPos` subset.
|
2020-11-09 08:49:36 +08:00
|
|
|
MLIR_CAPI_EXPORTED MlirAffineMap mlirAffineMapGetSubMap(MlirAffineMap affineMap,
|
|
|
|
intptr_t size,
|
|
|
|
intptr_t *resultPos);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2021-01-25 22:22:16 +08:00
|
|
|
/// Returns the affine map consisting of the most major `numResults` results.
|
|
|
|
/// Returns the null AffineMap if the `numResults` is equal to zero.
|
|
|
|
/// Returns the `affineMap` if `numResults` is greater or equals to number of
|
|
|
|
/// results of the given affine map.
|
2020-11-09 08:49:36 +08:00
|
|
|
MLIR_CAPI_EXPORTED MlirAffineMap
|
|
|
|
mlirAffineMapGetMajorSubMap(MlirAffineMap affineMap, intptr_t numResults);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2021-01-25 22:22:16 +08:00
|
|
|
/// Returns the affine map consisting of the most minor `numResults` results.
|
|
|
|
/// Returns the null AffineMap if the `numResults` is equal to zero.
|
|
|
|
/// Returns the `affineMap` if `numResults` is greater or equals to number of
|
|
|
|
/// results of the given affine map.
|
2020-11-09 08:49:36 +08:00
|
|
|
MLIR_CAPI_EXPORTED MlirAffineMap
|
|
|
|
mlirAffineMapGetMinorSubMap(MlirAffineMap affineMap, intptr_t numResults);
|
2020-09-14 22:52:22 +08:00
|
|
|
|
2021-06-24 17:21:12 +08:00
|
|
|
/// Apply AffineExpr::replace(`map`) to each of the results and return a new
|
|
|
|
/// new AffineMap with the new results and the specified number of dims and
|
|
|
|
/// symbols.
|
|
|
|
MLIR_CAPI_EXPORTED MlirAffineMap mlirAffineMapReplace(
|
|
|
|
MlirAffineMap affineMap, MlirAffineExpr expression,
|
|
|
|
MlirAffineExpr replacement, intptr_t numResultDims, intptr_t numResultSyms);
|
|
|
|
|
2021-03-31 17:33:08 +08:00
|
|
|
/// Returns the simplified affine map resulting from dropping the symbols that
|
|
|
|
/// do not appear in any of the individual maps in `affineMaps`.
|
|
|
|
/// Asserts that all maps in `affineMaps` are normalized to the same number of
|
|
|
|
/// dims and symbols.
|
|
|
|
/// Takes a callback `populateResult` to fill the `res` container with value
|
|
|
|
/// `m` at entry `idx`. This allows returning without worrying about ownership
|
|
|
|
/// considerations.
|
|
|
|
MLIR_CAPI_EXPORTED void mlirAffineMapCompressUnusedSymbols(
|
|
|
|
MlirAffineMap *affineMaps, intptr_t size, void *result,
|
|
|
|
void (*populateResult)(void *res, intptr_t idx, MlirAffineMap m));
|
|
|
|
|
2020-08-18 16:26:30 +08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif // MLIR_C_AFFINEMAP_H
|